首页 > web前端 > js教程 > 正文

JavaScript中filter函数的详细介绍

黄舟
发布: 2017-12-06 11:29:19
原创
5679 人浏览过

相信学习过JavaScript的vue的小伙伴们都知道filter函数,但是又有很多的小伙伴对filter也是不知所以然,知道的了可能也是模棱两可的,那我们今天就给大家详细介绍下JavaScript中filter函数!

看到示例中网格组件的时候,被一段嵌套代码搞的晕头转向,多方求助(segmentful提问)之后才将将理解,特此记录,以备后续查询:

查看全部代码点击此处

部分代码片段:

<p style="margin-top: 5px; margin-bottom: 14px; line-height: normal;">data = data.filter(function (row) {<br/>    return <a href="http://www.php.cn/wiki/60.html" target="_blank">Object</a>.keys(row).some(function (key) {<br/>        return String(row[key]).toLowerCase().<br/>        indexOf(filterKey) > -1;<br/>    });<br/>});<br/><br/>data = [<br/>    { name: &#39;Chuck Norris&#39;, power: Infinity },<br/>    { name: &#39;Bruce Lee&#39;, power: 9000 },<br/>    { name: &#39;Jackie Chan&#39;, power: 7000},<br/>    { name: &#39;Jet Li&#39;, power: 8000 }<br/>]<br/></p>
登录后复制

注:在这里filterKey表示的是在input中输入的字符串,这里假设输入ck

这里的row表示的是data[i],以第一行为例执行代码,row{ name: &#39;Chuck Norris&#39;, power: Infinity },那么Object.keys(row) = [&#39;name&#39;, &#39;power&#39;], key表示namepower。首先是namerow[&#39;name&#39;] = &#39;Chuck Norris&#39;, 这个字符串中包含字符串&#39;ck&#39;,所以返回true,不需要执行power,那么rowdata[0]返回到新的数组,继续遍历下面的数据。如果row[&#39;name&#39;]不包括此字符串,那么需要遍历row[&#39;power&#39;],如果都为false,不返回row,继续遍历。

整段代码涉及到vue的数据绑定,但是由于我还处于懵懂的状态就不记录了。

一只前端小白,如果您发现本文有什么错误或者理解不到位的地方,希望不吝赐教。

最近在正在学习vue,看到示例中网格组件的时候,被一段嵌套代码搞的晕头转向,多方求助(segmentful提问)之后才将将理解,特此记录,以备后续查询:

查看全部代码点击此处

部分代码片段:

data = data.filter(function (row) {
    return Object.keys(row).some(function (key) {
        return String(row[key]).toLowerCase().
        indexOf(filterKey) > -1;
    });
});

data = [
    { name: &#39;Chuck Norris&#39;, power: Infinity },
    { name: &#39;Bruce Lee&#39;, power: 9000 },
    { name: &#39;Jackie Chan&#39;, power: 7000},
    { name: &#39;Jet Li&#39;, power: 8000 }
]
登录后复制

注:在这里filterKey表示的是在input中输入的字符串,这里假设输入ck

这里的row表示的是data[i],以第一行为例执行代码,row{ name: 'Chuck Norris', power: Infinity },那么Object.keys(row) = ['name', 'power'], key表示namepower。首先是namerow['name'] = 'Chuck Norris', 这个字符串中包含字符串'ck',所以返回true,不需要执行power,那么rowdata[0]返回到新的数组,继续遍历下面的数据。如果row['name']不包括此字符串,那么需要遍历row['power'],如果都为false,不返回row,继续遍历。

整段代码涉及到vue的数据绑定,但是由于我还处于懵懂的状态就不记录了。

总结:

本文通过实例代码详细介绍了关于JavaScript中filter函数,相信小伙伴们对此也有了进一步的了解,希望对你的工作有所帮助!

相关推荐:

ajax的简单应用和filter的编写方法

CSS3的filter属性详细介绍

servlet与filter的url-pattern设置方式及映射规则

以上是JavaScript中filter函数的详细介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!