<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>列表过滤</title>
    <script type="text/javascript" src="../vue.js"></script>
</head>
<body>
<div id="root">
    <!--    遍历列表-->
    <h2>人员列表</h2>
    <input type="text" placeholder="输入关键词" v-model="keyword">
    <ul>
        <li v-for="(data, index) in filterData" :key="data.id">
            {{data.name}} - {{data.age}} - {{data.sex}}
        </li>

    </ul>
</div>
</body>
<script type="text/javascript">
    Vue.config.productionTip = false
    // 使用watch实现
    // const vm = new Vue({
    //     el: "#root",
    //     data: {
    //         keyword: '',
    //         listData: [
    //             {id: 1, name: '马冬梅', age: 18, sex: '女'},
    //             {id: 2, name: '周冬雨', age: 19, sex: '女'},
    //             {id: 3, name: '周杰伦', age: 20, sex: '男'},
    //             {id: 4, name: '温兆伦', age: 21, sex: '男'}
    //         ],
    //         filterData: []
    //     },
    //     watch: {
    //         // keyword(val) {
    //         //     this.listData = this.listData.filter((p) => {
    //         //         return p.name.indexOf(val) !== -1
    //         //     })
    //         // }
    //         keyword: {
    //             immediate: true,
    //             handler(val) {
    //                 this.filterData = this.listData.filter((p) => {
    //                     return p.name.indexOf(val) !== -1
    //                 })
    //             }
    //         }
    //     }
    // })

    // 使用computed实现
    const vm = new Vue({
        el: "#root",
        data: {
            keyword: '',
            listData: [
                {id: 1, name: '马冬梅', age: 18, sex: '女'},
                {id: 2, name: '周冬雨', age: 19, sex: '女'},
                {id: 3, name: '周杰伦', age: 20, sex: '男'},
                {id: 4, name: '温兆伦', age: 21, sex: '男'}
            ],
        },
        computed: {
            filterData() {
                return this.listData.filter((p) => {
                    return p.name.indexOf(this.keyword) !== -1
                })
            }
        }
    })

</script>
</html>