vue点击页面空白处实现保存功能


Posted in Javascript onNovember 06, 2019

vue点击页面空白处实现保存功能 

功能描述

双击表格一行实现表格编辑,点击空白处实现保存。

表格可编辑相关文章在可编辑表格

实现思路

当表格在编辑状态的时候在页面进行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点击页面空白处实现保存功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
msn上的tab功能Firefox对childNodes处理的一个BUG
Jan 21 Javascript
jQuery 源码分析笔记(6) jQuery.data
Jun 08 Javascript
由ReactJS的Hello world说开来
Jul 02 Javascript
js实现登陆遮罩效果的方法
Jul 28 Javascript
javascript实现移动端上的触屏拖拽功能
Mar 04 Javascript
js字符串引用的两种方式(必看)
Sep 18 Javascript
JavaScript、C# URL编码、解码总结
Jan 21 Javascript
js实现功能比较全面的全选和多选
Mar 02 Javascript
javascript数据结构中栈的应用之符号平衡问题
Apr 11 Javascript
Vue路由history模式解决404问题的几种方法
Sep 29 Javascript
js计时事件实现圆形时钟
Mar 25 Javascript
微信小程序开发数据缓存基础知识辨析及运用实例详解
Nov 06 Javascript
vue  elementUI 表单嵌套验证的实例代码
Nov 06 #Javascript
微信小程序网络请求实现过程解析
Nov 06 #Javascript
vue 自定义右键样式的实例代码
Nov 06 #Javascript
vue elementUI 表单校验的实现代码(多层嵌套)
Nov 06 #Javascript
vue 解决computed修改data数据的问题
Nov 06 #Javascript
微信小程序页面渲染实现方法
Nov 06 #Javascript
微信小程序页面间传递数组对象方法解析
Nov 06 #Javascript
You might like
YB217、YB235、YB400浅听
2021/03/02 无线电
PHP5权威编程阅读学习笔记 附电子书下载
2012/07/05 PHP
php如何调用webservice应用介绍
2012/11/24 PHP
PHP编程实现阳历转换为阴历的方法实例
2017/08/08 PHP
javascript定时变换图片实例代码
2013/03/17 Javascript
extjs 分页使用jsp传递数据示例
2014/07/29 Javascript
javascript手工制作悬浮菜单
2015/02/12 Javascript
jQuery仿天猫实现超炫的加入购物车
2015/05/04 Javascript
js+html5实现canvas绘制镂空字体文本的方法
2015/06/05 Javascript
JS实现淘宝支付宝网站的控制台菜单效果
2015/09/28 Javascript
javascript原生ajax写法分享
2016/04/10 Javascript
使用store来优化React组件的方法
2017/10/23 Javascript
vue中v-for循环给标签属性赋值的方法
2018/10/18 Javascript
express启用https使用小记
2019/05/21 Javascript
详解vuex之store源码简单解析
2019/06/13 Javascript
JavaScript生成随机验证码代码实例
2019/09/28 Javascript
python实现划词翻译
2020/04/23 Python
Python在不同目录下导入模块的实现方法
2017/10/27 Python
python处理csv中的空值方法
2018/06/22 Python
Python如何使用k-means方法将列表中相似的句子归类
2019/08/08 Python
使用pyinstaller逆向.pyc文件
2019/12/20 Python
python GUI库图形界面开发之PyQt5多线程中信号与槽的详细使用方法与实例
2020/03/08 Python
python里glob模块知识点总结
2021/01/05 Python
css3实现3d旋转动画特效
2015/03/10 HTML / CSS
西海岸男士和男童服装:Johnnie-O
2018/03/15 全球购物
英国受欢迎的运动鞋和街头服装商店:Footasylum
2018/06/12 全球购物
澳洲CFL商城:CHEMIST FOR LESS(中文)
2021/02/28 全球购物
架构师岗位职责
2013/11/18 职场文书
初中生物教学反思
2014/01/10 职场文书
小学教师事迹材料
2014/01/13 职场文书
技术经济专业求职信
2014/09/03 职场文书
九九重阳节致辞
2015/07/31 职场文书
java解析XML详解
2021/07/09 Java/Android
java泛型通配符详解
2021/07/25 Java/Android
前端JavaScript大管家 package.json
2021/11/02 Javascript
Win11 Beta 预览版 22621.575 和 22622.575更新补丁KB5016694发布(附更新内容大全)
2022/08/14 数码科技