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中万恶的function实例分析
May 25 Javascript
JQuery扩展插件Validate 1 基本使用方法并打包下载
Sep 05 Javascript
javascript对select标签的控制(option选项/select)
Jan 31 Javascript
Node.js的Koa框架上手及MySQL操作指南
Jun 13 Javascript
微信小程序实现带刻度尺滑块功能
Mar 29 Javascript
Angular.js实现动态加载组件详解
May 28 Javascript
vue如何集成raphael.js中国地图的方法示例
Aug 15 Javascript
详解VueRouter进阶之导航钩子和路由元信息
Sep 13 Javascript
Vue创建头部组件示例代码详解
Oct 23 Javascript
webpack4+react多页面架构的实现
Oct 25 Javascript
vue移动端城市三级联动组件使用详解
Jul 26 Javascript
关于在LayUI中使用AJAX提交巨坑记录
Oct 25 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
浅析get与post的一些特殊情况
2014/07/28 PHP
PHP实现上传多图即时显示与即时删除的方法
2017/05/09 PHP
thinkPHP5框架auth权限控制类与用法示例
2018/06/12 PHP
不常用但很实用的PHP预定义变量分析
2019/06/25 PHP
自动更新作用
2006/10/08 Javascript
JavaScript中几种常见排序算法小结
2011/02/22 Javascript
JavaScript获取页面上某个元素的代码
2011/03/13 Javascript
通过length属性判断jquery对象是否存在
2013/10/18 Javascript
firefox下jquery ajax返回object XMLDocument处理方法
2014/01/26 Javascript
window.location 对象所包含的属性
2014/10/10 Javascript
js通过iframe加载外部网页的实现代码
2015/04/05 Javascript
jQuery插件简单实现方法
2015/07/18 Javascript
vue 每次渲染完页面后div的滚动条保持在最底部的方法
2018/03/17 Javascript
Vue如何实现响应式系统
2018/07/11 Javascript
详解Vue依赖收集引发的问题
2019/04/22 Javascript
微信小程序上线发布流程图文详解
2019/05/06 Javascript
基于jquery实现的tab选项卡功能示例【附源码下载】
2019/06/10 jQuery
vue实现分页的三种效果
2020/06/23 Javascript
[01:15]PWL S2开团时刻第二期——他们杀 我就白给
2020/11/25 DOTA
深入理解Python 代码优化详解
2014/10/27 Python
Python的面向对象思想分析
2015/01/14 Python
python+django+sql学生信息管理后台开发
2018/01/11 Python
python模块smtplib学习
2018/05/22 Python
python web自制框架之接受url传递过来的参数实例
2018/12/17 Python
Python基础知识点 初识Python.md
2019/05/14 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
2020/03/09 Python
解决jupyter notebook 出现In[*]的问题
2020/04/13 Python
numpy的Fancy Indexing和array比较详解
2020/06/11 Python
苏格兰在线威士忌商店:The Whisky Barrel
2019/05/07 全球购物
Belvilla法国:休闲度假房屋出租
2020/10/03 全球购物
个人应聘自我评价分享
2013/11/18 职场文书
《雨霖铃》听课反思
2014/02/13 职场文书
大学社团计划书
2014/05/01 职场文书
党的群众路线对照检查材料思想汇报(学校)
2014/10/04 职场文书
初中生物教学反思
2016/02/20 职场文书
在虚拟机中安装windows server 2008的图文教程
2022/06/28 Servers