为什么event事件无法被序列化到本地存储

此问题出现的场景:

今天为要做一个记住用户上一次选择的task,按正常思路就是localStorage 存储这一次的所有入参,然后下一次init时候调用一下。但是发现有一个入参是$event 序列化之后拿出来少了很多属性。

原因:

事件(Event)对象通常包含特定于浏览器的属性,例如目标元素和鼠标位置。这些属性不能被序列化为 JSON 格式或其他格式,因此事件对象本身也无法被序列化。如果您需要在客户端和服务器之间传递事件数据,您可以将事件属性提取到一个普通的 JavaScript 对象中,然后将该对象序列化。

简单理解就是:event包含了对当前dom的引用,dom无法被序列化

解决方案:

好的,举个例子来说,假设您有一个鼠标单击事件的处理程序,您需要将事件数据发送到服务器以进行处理。您可以创建一个普通的 JavaScript 对象,将事件属性作为对象属性添加进去,然后将该对象序列化为 JSON 格式或其他格式。例如:

TypeScript 复制代码
element.addEventListener('click', function(event) {
  var eventData = {
    type: event.type,
    target: event.target.tagName,
    x: event.clientX,
    y: event.clientY
  };
  
  // 将 eventData 发送到服务器
  // ...
});

在这个例子中,我们将事件类型、目标元素的标签名以及鼠标位置提取到一个普通的 JavaScript 对象 `eventData` 中,并将其发送到服务器。这样就避免了直接将整个事件对象序列化的问题。

我自己的解决方案:

给调用方法的dom元素加上id,localStorage只存id,等下一次组件初始化时候,querySelecter此dom,设置点击事件。

相关推荐
jaywongX15 分钟前
Base64编码原理:二进制数据与文本的转换技术
前端·javascript·vue
天天扭码33 分钟前
深入讲解Javascript中的常用数组操作函数
前端·javascript·面试
猿究院_xyz34 分钟前
跟着尚硅谷学vue-day5
前端·javascript·vue.js·前端框架·html
Aniugel1 小时前
JavaScript高级面试题
javascript·设计模式·面试
小希爸爸1 小时前
3、中医基础入门和养生
前端·javascript·后端
天天扭码2 小时前
🔥 别再用 class 了!JS 原型链才是 YYDS
前端·javascript·面试
一天睡25小时2 小时前
React与Vue表单的对比差异
前端·javascript
在澳门喝茶的芦竹2 小时前
React高阶组件——React.momo
javascript·react.js
WEI_Gaot2 小时前
ES6 模板字符串
前端·javascript