jQuery过滤函数regexp

时间:2013-10-23 23:23:04

标签: jquery regex

有人可以解释为什么我的元素没有过滤吗?

这是写在书中的内容,他很遗憾如果假元素将被删除 并将显示带有true的元素:

$('li').filter(function() { return this.innerHTML.match(/^\d+$/)})

我只需要用14.15过滤li(我希望结果只有14.15)!

http://jsfiddle.net/crew1251/MYXYX/

<ul id="list">
    <li>raz</li>
    <li>asdf 14.15</li>
    <li>tri</li>
    <li>chetire_Tri</li>
    <li>pyat</li>


</ul>


$('li').filter(function () {
    return this.innerHTML.match(/^\d+$/);
});

2 个答案:

答案 0 :(得分:6)

如果要查找包含数字的li,请执行以下操作

var listWithDigits = $('li').filter(function () {
    return this.innerHTML.match(/\d+/);
    // return this.innerHTML.match(/\d+$/); // returns lis that end with digits
    // return this.innerHTML.match(/^\d+/); // returns lis that start with digits
    // return this.innerHTML.match(/^\d+$/); // returns lis that contain only digits
});
console.log(listWithDigits.length); // 1

您当前的正则表达式失败,因为它只接受仅包含数字的li,因为您已使用^$

包裹了正则表达式

http://jsfiddle.net/MYXYX/1/

答案 1 :(得分:1)

你使用了错误的模式,你必须删除锚点:

$('li').filter(function () {
    return $(this).html().match(/\d/);
});

请注意,您不需要测试多个数字,因此+量词是无用的。