vue實現(xiàn)全選功能
本文實例為大家分享了vue實現(xiàn)全選功能的具體代碼,供大家參考,具體內(nèi)容如下
全選思路
1、準(zhǔn)備標(biāo)簽,樣式,js,準(zhǔn)備數(shù)據(jù)
2、將數(shù)據(jù)循環(huán)展示在頁面上, 在li 里v-for
3、在全選框 v-model = "isAll" //總的狀態(tài)
4、小選框 v-model = "" //單個的狀態(tài)
5、小選影響全選 ... 定義計算屬性 isAll 統(tǒng)計小選框的狀態(tài), every查找數(shù)組里不符合條件的,直接返回false ...判斷每一個小選框的狀態(tài), 只要有一個小選框的狀態(tài)不為true 就是沒有被勾上, 那就返回false , 全選框的狀態(tài)就是false
6、全選影響小選... set(val) 設(shè)置全選的狀態(tài)(true/false)...然后就遍歷每個小選框看小選框的狀態(tài),讓它的狀態(tài)改為val全選的狀態(tài)
<template>
<div>
<span>全選:</span>
<input type="checkbox" v-model="isAll" />
<button @click="btn">反選</button>
<ul>
<li v-for="(obj, index) in arr" :key="index">
<input type="checkbox" v-model="obj.c" />
<span>{{ obj.name }}</span>
</li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
arr: [
{
name: "豬八戒",
c: false,
},
{
name: "孫悟空",
c: false,
},
{
name: "唐僧",
c: false,
},
{
name: "白龍馬",
c: false,
},
],
};
},
computed: {
isAll: {
//全選影響小選
set(val) {
//set(val) 設(shè)置全選的狀態(tài)(true/ false)
//我們手動設(shè)置了全選框的狀態(tài),就遍歷數(shù)組里的每個對象的c屬性, 也就是遍歷看每個小選框的狀態(tài),讓它的狀態(tài)改為 val 全選框的狀態(tài)
this.arr.forEach((obj) => (obj.c = val));
},
//小選框影響全選框
get() {
//判斷數(shù)組里的每一個對象的c屬性 它是不是等于true, 就是判斷每一個小選框的狀態(tài), 只要有一個小選框的狀態(tài)不為true 就是沒有被勾上, 那就返回false , 全選框的狀態(tài)就是false
// every口訣: 查找數(shù)組里"不符合"條件, 直接原地返回false
return this.arr.every((obj) => obj.c === true);
},
},
},
methods: {
btn() {
//實現(xiàn)反選
//遍歷數(shù)組里的每一項, 讓數(shù)組里對象的c屬性取反再賦值回去
this.arr.forEach((obj) => (obj.c = !obj.c));
},
},
};
</script>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于vuex強刷數(shù)據(jù)丟失問題解析
這篇文章主要介紹了關(guān)于vuex強刷數(shù)據(jù)丟失問題解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
vue 自定義指令directives及其常用鉤子函數(shù)說明
這篇文章主要介紹了vue 自定義指令directives及其常用鉤子函數(shù)說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01
解決vue路由發(fā)生了跳轉(zhuǎn)但是界面沒有任何反應(yīng)問題
這篇文章主要介紹了解決vue路由發(fā)生了跳轉(zhuǎn)但是界面沒有任何反應(yīng)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
Vue中的父子組件通訊以及使用sync同步父子組件數(shù)據(jù)
這篇文章主要介紹了Vue中的父子組件通訊以及使用sync同步父子組件數(shù)據(jù),對vue感興趣的同學(xué),可以參考下2021-04-04
淺析vue偵測數(shù)據(jù)的變化之基本實現(xiàn)
這里涉及到Vue一個重要特性:響應(yīng)式系統(tǒng)。數(shù)據(jù)模型只是普通的 JavaScript對象,當(dāng)我們修改時,視圖會被更新,而變化偵測是響應(yīng)式系統(tǒng)的核心2021-06-06

