更改对象的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的方法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2021-03-19 在express中获取post请求数据
2021-03-19 当直接下载或解压别人的node项目出现错误时,解决办法
2021-03-19 node.js创建项目