Vue列表过滤

列表过滤:

<script>
    const vm = new Vue({
        data:{
            keyWord:"",
           persons:[
               {id:'1001',name:"张三",age:21},
               {id:'1002',name:"张飞",age:21},
               {id:'1003',name:"李四",age:21},
               {id:'1004',name:"王五",age:21}
           ],
            examplePerson:[]
        },
        watch:{
            keyWord: {
                immediate:true,
                handler(val) {
                    this.examplePerson = this.persons.filter((p)=>{
                        return p.name.indexOf(val) !== -1
                    })
                }
            }
        }
    })
    vm.$mount(".app");
</script>
<script>
    const vm = new Vue({
        data:{
            keyWord:"",
           persons:[
               {id:'1001',name:"张三",age:21},
               {id:'1002',name:"张飞",age:21},
               {id:'1003',name:"李四",age:21},
               {id:'1004',name:"王五",age:21}
           ],
        },
        computed:{
            examplePerson(){
                return this.persons.filter((p) => {
                    return p.name.indexOf(this.keyWord) !== -1
                })
            }
        }
    })
    vm.$mount(".app");
</script>

添加排序功能

<script>
    const vm = new Vue({
        data:{
            keyWord:"",
           persons:[
               {id:'1001',name:"张三",age:21},
               {id:'1002',name:"张飞",age:22},
               {id:'1003',name:"李四",age:23},
               {id:'1004',name:"王五",age:12}
           ],
        },
        computed:{
            examplePerson(){
                let array = this.persons.filter((p) => {
                    return p.name.indexOf(this.keyWord) !== -1
                });
                array.sort((p1,p2)=>{
                    return p1.age-p2.age //升序
                })
                return array;
            }
        }
    })
    vm.$mount(".app");
</script>
上一篇:python通过关键字获取txt文件整行,并将结果进行排序,方便做参数对比


下一篇:(一)、ElasticSearch简介