更改对象的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 @ 2024-03-19 11:14  嘿!那个姑娘  阅读(13)  评论(0编辑  收藏  举报