为什么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,设置点击事件。

相关推荐
乐多_L1 小时前
使用vue3框架vue-next-admin导出表格excel(带图片)
前端·javascript·vue.js
纯粹要努力2 小时前
前端跨域问题及解决方案
前端·javascript·面试
HsuYang2 小时前
Vite源码学习(十二)——热更新(下)
前端·javascript·架构
csdn_aspnet2 小时前
JavaScript AJAX 库
javascript·ajax
胡桃不是夹子2 小时前
vue登陆下拉菜单
前端·javascript·vue.js
大G哥2 小时前
用DeepSeek来帮助学习three.js加载3D太极模形
开发语言·前端·javascript·学习·ecmascript
锐小制2 小时前
十分钟学习编写Ridge页面脚本
前端·javascript
太阳与星辰3 小时前
ECMAScript6------数组扩展
前端·ecmascript
丁总学Java5 小时前
Mac arm架构使用 Yarn 全局安装 Vue CLI
前端·javascript·vue.js
摸鱼也很难5 小时前
js安全开发值&dom&bom&xss重定向&安全实例
javascript·xss·idm·dom型xss