我需要从以'layout-'开头的元素中删除所有类
我尝试:
var regex = new RegExp('\b' + 'layout-' + '.*?\b', 'g');
$(el)[0].className = $(el)[0].className.replace(regex, '');
但它不起作用。解决方案可能在 jQuery 中。任何想法?
您在问题中发布的 RegExp 不起作用,因为\b
没有转义为\\b
. 因此,实际的 RegExp 正在变成/layout-.*?/g
而不是/\blayout-.*?\b/g
. 进行以下更改将起作用。
var regex = new RegExp('\\b' + 'layout-' + '.+?\\b', 'g');
你也可以像下面这样尝试。这会删除所有类似的类layout-X
var regex = /(\s)*(layout-.*?)(?=\s)/g;
$('#test')[0].className = $('#test')[0].className.replace(regex, '');
输入: class=sample layout-10 layout-9 sample1 slayout
输出: class=sample sample1 slayout
正则表达式解释:
\s
- 任何空白字符
(layout-.*?)
- 捕获所有值,例如 layout-X,其中 X 可以是任意字符任意次数
(?=\s)
- 向前看下一个空格字符(意思是直到单词的结尾)
正如musefan在评论中指出的那样,var regex = /\blayout-.+?\b/g;
也可以完成这项工作。