更改对象的read only属性

需求:

在项目开发中,拖拽左侧的数据新增到日历面板上,这时会调后端新增接口,但是我不想刷新日历组件,所以需要后面新增接口的回调返回新增这条数据的id,在新增接口回调中前端手动将id绑定到对应数据。

问题

info.event是日历单个event的所有属性,info.event下的属性是面板的自有属性,其它非自有属性都在info.event.extendedProps里面

直接使用 info.event.extendedProps.planId = res.data.iid

报错 Cannot assign to read only property 'planId' of object

planId是 read only属性,不能更改

解决办法

const newProps = cloneDeep(info.event.extendedProps)
Object.defineProperties(info.event, {
      extendedProps: {
        value: newProps,
        writable: true // 👈️ 将属性设置为可写
      }
 })
Object.assign(info.event.extendedProps, { planId: res.data.iid })

Object.defineProperties()
是 JavaScript 中的一个方法,它允许你一次性定义或修改一个对象上的多个属性。这个方法接收两个参数:要定义属性的对象和一个描述符对象,其中描述符对象的属性键是要定义的属性名,值是对应的属性描述符对象。

  • value:属性的值。
  • writable:如果为 true,属性的值可以被改变。
  • enumerable:如果为 true,属性可以被枚举(例如,通过 for...in 循环或 Object.keys() 方法)。
  • configurable:如果为 true,属性的类型可以被改变,属性也可以被删除。

这个处理能暂时改变extendedProps的值,但是在fullcalendar组件中,并不会影响内部的真实的extendedProps值

所以真正的对于这个fullcalendar的组件的方式是info.event.setExtendedProp('planId', res.data.iid)
组件提供了一个修改extendedProps的方法

image

posted @   嘿!那个姑娘  阅读(30)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2021-03-19 在express中获取post请求数据
2021-03-19 当直接下载或解压别人的node项目出现错误时,解决办法
2021-03-19 node.js创建项目
点击右上角即可分享
微信分享提示