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

最终效果如图

功能描述

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

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

实现思路

当表格在编辑状态的时候在页面进行click监听,判断点击区域是否为编辑区域,若是不是编辑区域实现保存功能并取消click监听bash

功能点一:页面监听与取消接听

// 经过addEventListener与removeEventListener实现
document.addEventListener("click", function, false);
document.removeEventListener("click", function, false);
复制代码

功能点二:判断点击区域是否为可编辑区域

该功能点有必定难度,首先你须要判断点击区域是否为表格区域,其次你要判断点击的区域是否为编辑状态的呢一行。因此我分为两步去实现框架

一、判断点击区域是否为表格区域

该功能点经过contains接口实现。判断条件为tableDom.contains(target);该接口能够判断target是否为tableDom的子节点。dom

// 首先经过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。 代码以下post

// 开始监听
document.addEventListener("click",
    (this.bindClick = e => {
      ...
    })
);

// 取消监听
document.removeEventListener("click", this.bindClick);
复制代码

本篇文章参考了https://www.cnblogs.com/sefaultment/p/11749802.htmlui

相关文章
相关标签/搜索