vue多级多选菜单组件开发

网友投稿 237 2023-07-01


vue多级多选菜单组件开发

本文实例为大家分享了vue多级多选菜单组件的制作方法,供大家参考,具体内容如下

要开发一个这样的多级多选菜单组件,功能是:

点击父标题栏可以打开与折叠子列表

点击父标题栏的勾选图标可以全选或取消子列表

点击子列表的勾选图标达到全选时,父标题栏的勾选图标自动勾选;反之,没达到全选时,父标题栏的勾选图标自动取消勾选

当所有父标题栏的勾选图标达到全选时,最底下那个全选框自动勾选;反之,没达到全选时,最底下那个全选框自动取消勾选

点击最底下那个全选框可以全选或取消全部的勾选图标

所以总结起来我们重点要利用子列表勾选了哪些项来计算出父标题与底下的全选框是自动勾选还是自动取消,并且父标题与底下的全选框在选择变化时子列表应有什么变化。要做到以上,实现过程是:

构建我们model层数据

datas : [

{

//用于判断是否展示子列表

isShowListItem : false,

//用于记录选中了哪些子项

selected : [],

//父标题

listTitle : "保利南悦湾",

//子列表

listItem : [

{

id : 1,

name : "李小龙"

},

{

id : 2,

name : "周星驰"

},

{

id : 3,

name : "周杰伦"

}

]

},

{

isShowListItem : false,

selected : [],

listTitle : "南庄万科城",

listItem : [

{

id : 4,

name : "大魔王"

},

{

id : 5,

name : "老妖怪"

}

]

}

]

记录子列表勾选了哪些项

子列表通过v-model=”data.selected”去双向绑定到selected数组中,当子列表项的checked发生变化时,就会把当前项的id记录到selected数组里去

type="checkbox"

:value="item.id"

v-model=http://"data.selected"

>

当父标题勾选变化时的处理方法

自动处理父标题勾选图标的变化

在HTML里,通过绑定:checked=”isTitleChecked(data)”,这时,每当其他项变化时,父标题都会调用一下isTitleChecked这个方法去判断一下这时自己的checked状态是true还是false,从而达到根据子项选中数目不同,父标题自动变化的目的。

通过@chahttp://nge=”changeTitleChecked(data,$event)”,每当父标题主动勾选或取消时触发

父标题HTML

class="list-input"

type="checkbox"

:checked="isTitleChecked(data)"

@change="changeTitleChecked(data,$event)"

>

父标题js

changeTitleChecked方法:当主动触发父标题的勾选图标时,如果这次触发chaeked的状态是true,则要把子列表项中没选中的全部选中,即将它们全部加进selected数组中;如果是false,则要把子列表项全部取消选中,即清空selected数组。

isTitleChecked方法:当子列表项全部选中时自动勾选父标题。

/**

* 当父标题状态变化时的处理方法

* @param data [当前项的data]

* @param event [当前项的event]

*/

changeTitleChecked : function (data,event) {

if (event.target.checked === true) {

data.listItem.forEach(function (item) {

data.selected.indexOf(item.id) === -1 && data.selected.push(item.id);

})

}else {

data.selected = [];

}

}

/**

* 判断父标题选择状态

* @param data [当前项的data]

* @returns {boolean}

*/

isTitleChecked : functiohttp://n (data) {

var _selected = data.selected;

var _listItem = data.listItem;

// 验证selected中是否含有全部的item的id 如果是 证明title要选中

return _listItem.every(function (item) {

return _selected.indexOf(item.id) != -1;

});

}

当底下的全选框变化时的处理方法

自动处理底下的全选框的变化

全选框HTML:

type="checkbox"

:checked="isAllChecked()"

@change="changeAllChecked($event)"

>

全选框JS:

changeAllChecked方法:当主动触发全选框时,如果checked为true,则将全部的子项都放进selected数组里;反之则清空全部selected数组。

isAllChecked 方法:判断selected数组的长度是否等于全部子项数,如果相等,则全选框checked状态设为true。

/**

* 全选框change事件的回调处理方法

* @param event

*/

changeAllChecked : function (event) {

if (evpADhbEment.target.checked === true) {

this.datas.forEach(function (data) {

data.listItem.forEach(function (item) {

data.selected.indexOf(item.id) === -1 && data.selected.push(item.id);

})

})

}else {

this.datas.forEach(function (data) {

data.selected = [];

})

}

}

/**

* 判断全选框选择状态

* @returns {boolean}

*/

isAllChecked : function () {

return this.datas.every(function (data) {

return data.selected.length === data.listItem.length;

});

}

本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:javaweb如何实现请求和响应
下一篇:vue开发心得和技巧分享
相关文章

 发表评论

暂时没有评论,来抢沙发吧~