vue-property-decorator Prop失效问题排查记录

问题说明

近期遇见一非常诡异的问题,vue-property-decorator声明的porp初始值,竟然赋不上了,直接上图:

代码实现如下:

上游组件通过beHidden控制hide显隐,并且也有加初始值。

结果跑起来在项目里一看:

beHidden已经顺利赋值了,但是hide没有,也就是undefined。非常诡异,遂排查。

排查过程

直接进入断点,找到beHiddenhidden的赋值

可以看到这个类刚初始化的时候,beHidden是已经被赋值了的,但是经过神秘逻辑

js 复制代码
c(this, "beHidden", void 0),

之后,等到将beHidden赋值给hide的时候,beHidden就变为undefined了。

那么问题就定位到了,这个神秘的代码又是什么呢?

看看压缩前的代码,发现了这个:

js 复制代码
_defineProperty(this, "beHidden", void 0);

function _defineProperty(obj, key, value) {
  key = _toPropertyKey(key);
  if (key in obj) {
    Object.defineProperty(obj, key, {
      value: value,
      enumerable: true,
      configurable: true,
      writable: true
    });
  } else {
    obj[key] = value;
  }
  return obj;
}

然后就定位到了 @babel/plugin-proposal-class-propertiesbabel.dev/docs/babel-...

简直了,感情是 @babel/plugin-proposal-class-properties把Class里没赋初值的数据都给赋值为void 0了。

解决方案

感觉寄了,这依赖是cli-plugin-babel引入的,好像也没法处理呀。只能先加watch处理了,反正新项目也直接vue3了。继续深究也意义不大了。

js 复制代码
@Watch("beHidden", { immediate: true })
    onBeHidden(nv: boolean) {
        this.hide = nv;
    }
相关推荐
绝世唐门三哥5 分钟前
React---数组浅拷贝之slice的使用
前端·reactjs
傅里叶11 分钟前
Flutter开发的app,实现Google 登录
前端·flutter
天理小学渣19 分钟前
JavaScript_基础教程_自学笔记
开发语言·javascript·笔记
angerdream25 分钟前
最新版vue3+TypeScript开发入门到实战教程之生命周期函数
javascript·vue.js
胖橘28 分钟前
适用于Vue3的高集成度文件预览组件,支持多种类型的文件
前端·vue.js·开源
我叫黑大帅29 分钟前
🚀 JS 最常用的性能优化 防抖和节流
前端·javascript·面试
啊丫丫30 分钟前
【深入浅出地学习Vue】——vue2
前端·vue.js
求知若饥31 分钟前
webpage-channel 让不同页面通信像组件通信一样简便
前端·typescript·node.js
图扑软件37 分钟前
图扑 HT 帧动画 | 3D 动态渲染设计与实现
前端·javascript·3d·动画·数字孪生
终端鹿1 小时前
Pinia 与 Vue Router 权限控制实战(衔接Pinia基础篇)
前端·javascript·vue.js