失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 利用vue实现全选反选功能

利用vue实现全选反选功能

时间:2023-06-05 16:51:05

相关推荐

利用vue实现全选反选功能

web前端|js教程

功能,全选,实现

web前端-js教程全选功能可以说是前端开发中非常常见的一个功能,以前的项目开发用jQuery开发比较多。最近在使用vue前端框架重构之前的项目。从jQuery到vue的转变主要是一个思想想的转变,是将原有的直接操作dom的思想转变到操作数据,用数据驱动dom,也是vue框架的一个核心思想,思想转变过来,对功能的实现自然容易理解一些。

笑话网站源码,ubuntu怎么打开KDE,爬虫对电脑要求,php superoi,seo文章范例lzw

例如下面这个简单的demo

dwz源码分析,vscode一键编译运行的插件,ubuntu 远程图形,tomcat六个字母,cmd 查询sqlite,艺术网页设计,服务器 出口带宽,b2c im即时聊天插件,前端开发框架学习,看知乎爬虫,php cgi模式,seo搜索引擎优化师,云购网站域名,到计时手机网页日历代码,phpcms 在线编辑模板,js页面倒计时代码,药品管理系统下载,给网站加联盟程序lzw

反调试 源码,vscode上下分页,ubuntu剪切,tomcat默认工程,c 如何操作sqlite,discuz 淘宝客插件,java可以写前端框架吗,python爬虫网页输出器,iis php5.6,辽宁seo优化代理,学习课程网站程序,进存销网页,织梦如何替换模板lzw

按照jQuery的思想来做的话,要选中全选checkbox和所有的checkbox项,分别注册选中事件,判断选中状态来给相关的checkbox设置对应的状态,这就涉及到很多的dom操作。

下面就看一下vue数据驱动dom的思想来实现这一功能。

vue数据驱动dom实现功能

new Vue({ el: #app, data(){return { checkData: [] // 双向绑定checkbox数据数组} }, watch: { // 监视双向绑定的数据数组checkData: { handler(){ // 数据数组有变化将触发此函数if(this.checkData.length == 3){ document.querySelector(#quan).checked = true;}else { document.querySelector(#quan).checked = false;} }, deep: true // 深度监视} }, methods: {checkAll(e){ // 点击全选事件函数 var checkObj = document.querySelectorAll(.checkItem); // 获取所有checkbox项 if(e.target.checked){ // 判定全选checkbox的勾选状态for(var i=0;i<checkObj.length;i++){ if(!checkObj[i].checked){ // 将未勾选的checkbox选项push到绑定数组中 this.checkData.push(checkObj[i].value); }} }else { // 如果是去掉全选则清空checkbox选项绑定数组this.checkData = []; }} } });

利用vue的双向数据绑定v-model命令,当勾选时,checkbox的value值会自动push到所绑定的数组checkData中去,省去了不少对dom的操作。

如果是固定选项这样是可以实现的,但是这种方法有一些弊端,双向绑定数组数据是写死的,不太灵活,如果增加了checkbox选项,要更改wach里绑定数组的长度判断。

有时候checkbox选项也是后台动态获取过来的,这样也灵活一些。

例如后台数据是这样的:

ajaxData: [{ name: a, value: apple },{ name: , value: anana },{ name: c, value: orange }]

需要先动态渲染checkbox选项,在进行数据绑定。

new Vue({ el: #app, data(){return { ajaxData: [{ // 后台请求过来的数据name: 选项1,value: apple },{name: 选项2,value: anana },{name: 选项3,value: orange }], checkData: [] // 双向数据绑定的数组} }, watch: {checkData: { // 监视双向绑定的数组变化 handler(){if(this.checkData.length == this.ajaxData.length){ document.querySelector(#quan).checked = true;}else { document.querySelector(#quan).checked = false;} }, deep: true} }, methods: {checkAll(e){ // 点击全选事件 if(e.target.checked){this.ajaxData.forEach((el,i)=>{ // 数组里没有这一个value才push,防止重复push if(this.checkData.indexOf(el.value) == -1){this.checkData.push(el.value); }}); }else { // 全不选选则清空绑定的数组this.checkData = []; }} } });

方法并不是最优的写法,也存在一些弊端,欢迎各位指点迷津,一起探讨。

如果觉得《利用vue实现全选反选功能》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。