从品牌网站建设到网络营销策划,从策略到执行的一站式服务
vue点击页面空白处实现保存功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
创新互联建站是一家专业提供仪陇企业网站建设,专注与网站建设、成都网站建设、成都h5网站建设、小程序制作等业务。10年已为仪陇众多企业、政府机构等服务。创新互联专业的建站公司优惠进行中。
功能描述
双击表格一行实现表格编辑,点击空白处实现保存。
表格可编辑相关文章在可编辑表格
实现思路
当表格在编辑状态的时候在页面进行click监听,判断点击区域是否为编辑区域,如果不是编辑区域实现保存功能并取消click监听
功能点一:页面监听与取消接听
// 通过addEventListener与removeEventListener实现 document.addEventListener("click", function, false); document.removeEventListener("click", function, false);
功能点二:判断点击区域是否为可编辑区域
该功能点有一定难度,首先你需要判断点击区域是否为表格区域,其次你要判断点击的区域是否为编辑状态的呢一行。所以我分为两步去实现
1、判断点击区域是否为表格区域
该功能点通过 contains 接口实现。判断条件为 tableDom.contains(target);该接口可以判断target是否为tableDom的子节点。
// 首先通过addEventListener 传入点击的dom区域 document.addEventListener( "click", e => { this.judgeClickDom(e); }, false ); // this.bindClick是为了取消监听,下文会进行描述 // 判断点击是否为table区域 judgeClickDom(e) { const { target } = e; let tableDom = document.getElementsByClassName("table"); // getElementsByClassName获取到的是数组,一定要有下标不然会报错 // 如果我们点击的区域在表格外保存数据 if (!tableDom[0].contains(target)) { this.saveTableData(); } },
2.判断点击区域是否为编辑状态的那一行
该功能借助了element框架, 如何标记编辑状态行,在可编辑表格中已有介绍
取消监听
由于我们监听click时使用的是箭头函数,没有函数名或者函数表达式,所以在取消监听的时候会出现问题。 我的解决方案是给他绑定一个全局变量bindClick。 代码如下
// 开始监听 document.addEventListener("click", (this.bindClick = e => { ... }) ); // 取消监听 document.removeEventListener("click", this.bindClick);
关于vue点击页面空白处实现保存功能问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图