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

相关推荐
我是Superman丶2 小时前
【技巧】前端VUE用中文方法名调用没效果的问题
前端·javascript·vue.js
斯~内克2 小时前
Vue 3 中 watch 的使用与深入理解
前端·javascript·vue.js
lqj_本人4 小时前
鸿蒙OS&UniApp制作多选框与单选框组件#三方框架 #Uniapp
前端·javascript·uni-app
SHIPKING3937 小时前
【HTML】个人博客页面
javascript·css·html
junjun.chen06068 小时前
【在qiankun模式下el-dropdown点击,浏览器报Failed to execute ‘getComputedStyle‘ on ‘Window‘: parameter 1 is not o
前端·javascript·前端框架
課代表9 小时前
AcroForm JavaScript Promise 对象应用示例: 异步加载PDF文件
开发语言·javascript·pdf·promise·对象
zm9 小时前
服务器连接多客户端
java·javascript·算法
小屁孩大帅-杨一凡10 小时前
一个简单点的js的h5页面实现地铁快跑的小游戏
开发语言·前端·javascript·css·html
purpleseashell_Lili11 小时前
配置别名路径 @
javascript·react
这个一个非常哈11 小时前
VUE篇之自定义组件使用v-model
前端·javascript·vue.js