vue实现选择状态的变化

这里主要通过ES5的every()方法以及vue中computed属性实现:

话不多说,直接上代码....

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="../node_modules/vue/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        全选<input type="checkbox" v-model="checkAll">
        <hr>
        游泳:<input type="checkbox" v-model="check[0].fen"><br>
        跑步:<input type="checkbox" v-model="check[1].fen"><br>
        唱歌:<input type="checkbox" v-model="check[2].fen"><br>
    </div>
</body>
<script>
    let vm=new Vue({
        el:'#app',
        computed:{
            checkAll:{
                get(){
                    return this.check.every(p=>p.fen); //(根据下面的状态影响上面的状态)一开始就读取值---->  every()如果找到一个false就立即返回false,没有就返回true
                },
                set(val){
                    this.check.forEach(p=>p.fen=val); //(手动点击设置上面的状态)------>遍历下面的项,将其状态设置成和上面一样
                }
            }
        },
        data:{
            check:[{fen:true},{fen:true},{fen:true}]
        }
    })
</script>
</html>

猜你喜欢

转载自blog.csdn.net/liuhua_2323/article/details/83004985