iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue.$set失效的原因以及解决方案
  • 934
分享到

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

2023-06-20 14:06:41 934人浏览 薄情痞子
摘要

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

这篇文章主要讲解了“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失效的原因以及解决方案这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Vue.$set失效的原因以及解决方案

本文链接: https://www.lsjlt.com/news/297513.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作