🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
>[success] # computed ~~~ 1.对计算属性操作,只给计算属性一个函数,默认这个函数是在取值的时候触发 的,这个函数是get函数 2.设置值set(){},取值get(){} 3.当checkedbox 是input的一个type类型,也就是说当作为计算属性,点击的时 候,其实触发的是他的set方法又因为,计算属性默认是get方法,所以就需要去 定义它的set。 ~~~ >[danger] ##### 案例 ~~~ <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style> body, ul, li { margin: 0; padding: 0; list-style: none; } .list-body li:nth-child(even) { background: yellow; } .list-body li:nth-child(odd) { background: #fff; } .list-body li:hover { background: green; } .list-body li.checkedColor { background: green; } </style> <script src="../src/vue.js"></script> <script> let data = [ { id:Date.now()+Math.random(), name: '邓紫棋', song: '泡沫', checked: true, album: 10 }, { id:Date.now()+Math.random(), name: '王杰', song: '泡沫', checked: true, album: 10 }, { id:Date.now()+Math.random(), name: '邓紫棋', song: '泡沫123', checked: false, album: 10 } ] </script> </head> <body> <div class="wrap" id="app"> <div class="baidu"> <ul class="list list-head"> <li> <div> <input type="checkbox" v-model='isCheckedAll' />全选 </div> <span>歌单</span> <span>歌手</span> <span>专辑</span> </li> </ul> <ul class="list list-body"> <li v-for="item in songList" > <div> <input v-model="item.checked" type="checkbox"> </div> <span>{{item.song}}</span> <span>{{item.name}}</span> <span>{{item.album}}</span> </li> </ul> <div class="select"> <span class="selectAll"> <span>统计:</span> </span> </div> </div> {{isCheckedAll}} </div> <script> new Vue({ el: '#app', data: { songList: data }, computed: { /* 对计算属性操作 只给计算属性一个函数,默认这个函数是在取值的时候触发的,这个函数是get函数 设置值 set(){} 取值 get(){} */ isCheckedAll:{ get(){ console.log('取值'); return this.songList.every(function(item){ return item.checked }); }, set(newValue){ console.log('设置值了'); console.log(newValue); this.songList.forEach(item => item.checked = newValue) } } } }) </script> </body> </html> ~~~