vue实现全选反选

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>全选反选</title>
<script src="js/vue.js"></script>
</head>
<body>
<h1>全选反选</h1>
<div id="vm1">
<label><input type="checkbox" v-model="allData.parCheck" @change="allSelect()">{{allData.text}}</label>
<ul>
<li v-for="item in checkData">
<label><input type="checkbox" v-model="item.isCheck" @change="singleSelect()">{{item.text}}</label>
</li>
</ul>
</div>
<script>
var vm1=new Vue({
el:'#vm1',
data:{
allData:{text:'全选',parCheck:false},
checkData:[
{text:'苹果',isCheck:false},
{text:'香蕉',isCheck:false},
{text:'西瓜',isCheck:false}
]
},
methods:{
//全选
allSelect:function(){
var vm1=this;
vm1.checkData.forEach(function(item){
item.isCheck=vm1.allData.parCheck;
})
},
//单选
singleSelect:function(){
var vm1=this;
var selectData=vm1.checkData.filter(function(item){
return item.isCheck==true;
})
selectData.length==vm1.checkData.length? vm1.allData.parCheck=true:vm1.allData.parCheck=false;
}
}
})
</script>
</body>
</html>

原文地址:https://www.cnblogs.com/xiongy/p/7856751.html