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 相关文章推荐
可实现多表单提交的javascript函数
Aug 01 Javascript
尝试在让script的type属性等于text/html
Jan 15 Javascript
JavaScript导航脚本判断当前导航
Jul 12 Javascript
JavaScript 字符串数字左补位,右补位,取固定长度,截位扩展函数代码
Mar 25 Javascript
jQuery实现下拉菜单的实例代码
Jun 19 jQuery
Angular.js中数组操作的方法教程
Jul 31 Javascript
浅谈vux之x-input使用以及源码解读
Nov 04 Javascript
js中位运算的运用实例分析
Dec 11 Javascript
基于vue通用表单解决方案的思考与分析
Mar 16 Javascript
详解vue的数据劫持以及操作数组的坑
Apr 18 Javascript
Vue实现剪切板图片压缩功能
Feb 04 Javascript
关于element的表单组件整理笔记
Feb 05 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
收藏的一个php小偷的核心程序
2007/04/09 PHP
PHPMyAdmin 快速配置方法
2009/05/11 PHP
php数组函数序列之sort() 对数组的元素值进行升序排序
2011/11/02 PHP
解析isset与is_null的区别
2013/08/09 PHP
php+webSoket实现聊天室示例代码(附源码)
2017/02/17 PHP
不同浏览器对回车提交表单的处理办法
2010/02/13 Javascript
jQuery实现的类flash菜单效果代码
2010/05/17 Javascript
node.js中的fs.truncateSync方法使用说明
2014/12/15 Javascript
jquery渐隐渐显的图片幻灯闪烁切换实现方法
2015/02/26 Javascript
JavaScript把数组作为堆栈使用的方法
2015/03/20 Javascript
javascript格式化指定日期对象的方法
2015/04/21 Javascript
Ubuntu系统下Angularjs开发环境安装
2016/09/01 Javascript
js仿小米手机上下滑动效果
2017/02/05 Javascript
bootstrap弹出层的多种触发方式
2017/05/10 Javascript
NodeJS实现微信公众号关注后自动回复功能
2017/05/31 NodeJs
vue axios同步请求解决方案
2017/09/29 Javascript
jQuery实现鼠标响应式淘宝动画效果示例
2018/02/13 jQuery
详解node登录接口之密码错误限制次数(含代码)
2019/10/25 Javascript
小程序双头slider选择器的实现示例
2020/03/31 Javascript
Python的Django框架使用入门指引
2015/04/15 Python
python读文件保存到字典,修改字典并写入新文件的实例
2018/04/23 Python
Python中创建二维数组
2018/10/17 Python
浅谈Python中eval的强大与危害
2019/03/13 Python
详解python中的线程与线程池
2019/05/10 Python
python属于软件吗
2020/06/18 Python
用pushplus+python监控亚马逊到货动态推送微信
2021/01/29 Python
HTML5实现应用程序缓存(Application Cache)
2020/06/16 HTML / CSS
俄罗斯设计师家具购物网站:The Furnish
2019/12/01 全球购物
台湾专柜女包:KINAZ
2019/12/26 全球购物
银行毕业实习自我鉴定
2013/09/19 职场文书
建筑工程专业毕业生自荐信
2013/10/19 职场文书
人事档案接收函
2014/01/12 职场文书
2014年信息中心工作总结
2014/12/17 职场文书
离职信范本
2015/06/23 职场文书
新学期开学寄语2016
2015/12/04 职场文书
Nginx开源可视化配置工具NginxConfig使用教程
2022/06/21 Servers