Element-Plus的ClickOutside指令导致内存泄漏

引起内存泄漏的源码如下

js 复制代码
var startClick = void 0;
var seed = 0;

!_vue2.default.prototype.$isServer && (0, _dom.on)(document, 'mousedown', function (e) {
  return startClick = e;
});

该内存泄漏该如何解决呢?

答案是不需要解决, 因为当鼠标点击任何其他地方时, 上述游离节点会被回收。 因为鼠标点击时,会再次触发document上绑定的mousedown事件, 此时startClick会被赋值新的值。从而startClick和游离节点解除绑定, 游离节点被正常回收。

当然最好的解决是在回调函数内部加上一层判断。对于没有绑定该指令的元素就不要给startClick赋值了。

官网反馈

github.com/element-plu...

相关推荐
子醉21 小时前
推荐一种适合前端开发使用的解决本地跨域问题的办法
前端
Niyy_21 小时前
前端一个工程构建多个项目,记录一次工程搭建
前端·javascript
xiangxiongfly91521 小时前
CSS link标签
前端·css
快乐非自愿1 天前
常用设计模式:工厂方法模式
javascript·设计模式·工厂方法模式
岁月宁静1 天前
AI 多模态全栈应用项目描述
前端·vue.js·node.js
十年磨一剑~1 天前
html+js开发一个测试工具
javascript·css·html
nn_(nana)1 天前
修改文件权限--- chmod ,vi/vim,查看文件内容,yum-软件包管理器,systemctl管理系统服务
前端
汪汪队立大功1231 天前
JavaScript是怎么和html元素关联起来的?
开发语言·javascript·html
烛阴1 天前
从零开始掌握C#核心:变量与数据类型
前端·c#