vue使用vant中的checkbox實(shí)現(xiàn)全選功能
本文實(shí)例為大家分享了vue使用vant中的checkbox實(shí)現(xiàn)全選功能的具體代碼,供大家參考,具體內(nèi)容如下
<template>
<div class="visiblePeople">
<topbar />
<ul class="list clear_float">
<li v-for="(item, index) in people" :key="index">
<van-checkbox
v-model="item.flag"
class="listli"
></van-checkbox>
<div class="right">
<p>{{ item.name }}</p>
<p>{{ item.id }}</p>
</div>
</li>
</ul>
<div class="bottom">
<div class="left">
<van-checkbox v-model="allcheck" class="all">全選</van-checkbox>
</div>
<button @click="jump">確定</button>
</div>
</div>
</template>
<script>
export default {
data() {
return {
people: [
{ id: "002", name: "陳陽", flag: true },
{
id: "003",
name: "王苗苗",
flag: true,
},
{
id: "004",
name: "張梁俊",
flag: true,
},
{
id: "005",
name: "劉路",
flag: true,
},
],
};
},
methods: {
//點(diǎn)擊確定后跳轉(zhuǎn)回新增合同頁面
jump() {
this.$router.push("/addContract");
},
//單選按鈕切換
// change(index) {
// this.people[index].flag = !this.people[index].flag;
// console.log(this.people[index].flag);
// },
},
computed:{
allcheck:{
get(){
//取值
//every方法,數(shù)組中每一項(xiàng)都滿足一個(gè)條件返回true
return this.people.every(item=>item.flag)
},
set(newValue){
//設(shè)置值
console.log('觸發(fā)set方法')
this.people.map(item=>item.flag=newValue)
}
},
filterAll(){
return this.people.filter(item=>item.flag).length
},
count(){
let checkedList=this.people.filter(item=>item.flag)
return checkedList.length.reduce((total,item)=>{
return total+item.num
},0)
}
}
};
</script>
<style lang="less" scoped>
.list {
background: #f8f9fb;
height: 574px;
li {
height: 56px;
margin: 10px 0 10px 0;
float: left;
img {
width: 19px;
height: 19px;
float: left;
margin: 13px;
&.on {
display: block;
}
&.off {
display: none;
}
}
.listli {
float: left;
margin: 19px 13px 0 13px;
}
.right {
float: left;
background: #ffffff;
width: 328px;
height: 56px;
padding: 0px 0 0 13px;
box-sizing: border-box;
p:nth-of-type(1) {
font-size: 15px;
font-family: PingFang SC;
font-weight: 400;
color: #000000;
line-height: 29px;
}
p:nth-of-type(2) {
font-size: 13px;
font-family: PingFang SC;
font-weight: 400;
color: #666666;
line-height: 14px;
}
}
}
}
.bottom {
height: 50px;
position: fixed;
bottom: 0;
.left {
width: 237px;
background: #ffffff;
height: 100%;
float: left;
img {
width: 18px;
float: left;
margin: 18px 13px 0 18px;
&.on {
display: block;
}
&.off {
display: none;
}
}
.all {
margin: 17px 0 0 14px;
}
p {
float: left;
font-size: 13px;
font-family: PingFang SC;
font-weight: 400;
color: #333333;
margin-top: 18px;
}
}
button {
float: left;
width: 138px;
height: 50px;
line-height: 50px;
background: #336afa;
color: #ffffff;
}
}
</style>
本次遇到的問題是自己一開始沒發(fā)現(xiàn)在people數(shù)組里面,定義的每一項(xiàng)flag的值設(shè)置的類型為字符串型即flag="true",導(dǎo)致一開始進(jìn)入頁面全部無論值為true還是false,復(fù)選框都是選中效果,修改之后便沒有了此問題。
關(guān)于vue.js組件的教程,請(qǐng)大家點(diǎn)擊專題vue.js組件學(xué)習(xí)教程進(jìn)行學(xué)習(xí)。
更多vue學(xué)習(xí)教程請(qǐng)閱讀專題《vue實(shí)戰(zhàn)教程》
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue cli3.x打包后如何修改生成的靜態(tài)資源的目錄和路徑
這篇文章主要介紹了vue cli3.x打包后如何修改生成的靜態(tài)資源的目錄和路徑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue?eslint報(bào)錯(cuò):Component?name?“xxxxx“?should?always?be?
新手在使用腳手架時(shí)總會(huì)報(bào)各種錯(cuò),下面這篇文章主要給大家介紹了關(guān)于vue?eslint報(bào)錯(cuò):Component?name?“xxxxx“?should?always?be?multi-word.eslintvue的4種解決方案,需要的朋友可以參考下2022-07-07
vue+axios+element ui 實(shí)現(xiàn)全局loading加載示例
今天小編就為大家分享一篇vue+axios+element ui 實(shí)現(xiàn)全局loading加載示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue3封裝一個(gè)帶動(dòng)畫的關(guān)閉按鈕示例詳解
這篇文章主要為大家介紹了vue3封裝一個(gè)帶動(dòng)畫的關(guān)閉按鈕示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
在vue中使用inheritAttrs實(shí)現(xiàn)組件的擴(kuò)展性介紹
這篇文章主要介紹了在vue中使用inheritAttrs實(shí)現(xiàn)組件的擴(kuò)展性介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12
vue父組件與子組件之間的數(shù)據(jù)交互方式詳解
最近一直在做一個(gè)vue移動(dòng)端商城的實(shí)戰(zhàn),期間遇到一個(gè)小小的問題,值得一說,下面這篇文章主要給大家介紹了關(guān)于vue父組件與子組件之間數(shù)據(jù)交互的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11

