Loading

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>
posted @ 2021-10-05 21:17  IamHzc  阅读(110)  评论(0编辑  收藏  举报