文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue.$set失效的原因以及解决方案

2023-06-20 14:45

关注

这篇文章主要讲解了“Vue.$set失效的原因以及解决方案”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue.$set失效的原因以及解决方案”吧!

偶然在项目中发现Vue.$set失效

Vue.$set失效的原因以及解决方案

有这样一个需求 添加数据过滤用 左边是控件选择 中间是条件 右边是值

因为会根据控件不同渲染不同的值选项控件

<el-form inline >      <el-form-item >        <el-select v-model="data[props.prop]" @change="data[props.value] = ''">          <el-option            v-for="item in controls"            :key="item.id"            :value="item.id"            :label="item.label">          </el-option>        </el-select>      </el-form-item>      <el-form-item >        <el-select v-model="data[props.type]">          <el-option            v-for="item in condition"            :key="item.code"            :value="item.code"            :label="item.name"          ></el-option>        </el-select>      </el-form-item>      <el-form-item >        <FormControl v-if="control" :control="control" :value="data[props.value]" @input="onValueChange" ></FormControl>        <el-input v-else :value="data[props.value]" @input="onValueChange"></el-input>      </el-form-item>      <el-form-item>        <el-button type="primary" icon="el-icon-plus" @click="add"></el-button>      </el-form-item>    </el-form>
{  props:{    props: {      type: Object,      default: () => ({        prop: 'prop',        value: 'value',        type: 'type'      })    }  },  data(){    return {      data:{              }    }  },  methods:{    onValueChange(val){      this.$set(this.data, this.props.value, val)    }  }  //...}

代码片段

由于控件ID的不确定性 所有 data并不能提前预设好key  自然无法响应 所以在onValueChange 使用了this.$set动态添加数据实现响应

Vue.$set失效的原因以及解决方案

复现可以发现 值输入框内的数据并不能实时响应

明明用了$set却不能响应 一番排查后发现只要切换控件后 value值就不能响应 但是只要在切换前随便输入点啥 再切换就没问题

又是一番排查后发现

<el-select v-model="data[props.prop]" @change="data[props.value] = ''">

删除@change事件后故障解决

问题出现在 data[props.value] = ''

遂查看Vue源码

//vue/src/core/observer/index.js 源码片段  export function set (target: Array<any> | Object, key: any, val: any): any {  if (process.env.NODE_ENV !== 'production' &&    (isUndef(target) || isPrimitive(target))  ) {    warn(`Cannot set reactive property on undefined, null, or primitive value: ${(target: any)}`)  }  if (Array.isArray(target) && isValidArrayIndex(key)) {    target.length = Math.max(target.length, key)    target.splice(key, 1, val)    return val  }  if (key in target && !(key in Object.prototype)) {    target[key] = val    return val  }  const ob = (target: any).__ob__  if (target._isVue || (ob && ob.vmCount)) {    process.env.NODE_ENV !== 'production' && warn(      'Avoid adding reactive properties to a Vue instance or its root $data ' +      'at runtime - declare it upfront in the data option.'    )    return val  }  if (!ob) {    target[key] = val    return val  }  defineReactive(ob.value, key, val)  ob.dep.notify()  return val}

可以发现 在defineReactive之前 判断了key是否存在于对象之内 若存在就跳过了

坑就在这 多次翻阅Vue.$set文档并未发现$set不能为已存在的key添加监测对象

删除 data[props.value] = ''  改为 onValueChange('') 完美解决问题

Vue.$set失效的原因以及解决方案

总结

Vue.$set之前一定要对象内key不存在 不然只会更新值 并不会为该Key添加响应监测

感谢各位的阅读,以上就是“Vue.$set失效的原因以及解决方案”的内容了,经过本文的学习后,相信大家对Vue.$set失效的原因以及解决方案这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯