相关文章推荐
满身肌肉的高山  ·  vue 报错 ...·  3 月前    · 
谈吐大方的电池  ·  Vue的methods方法中调用另一个方法及 ...·  1 月前    · 
爱吹牛的香烟  ·  vue使用quill编辑器自定义附件上传方法 ...·  1 月前    · 
怕考试的木耳  ·  软件分享库合集链接汇总推荐_蓝奏云软件分享链 ...·  9 月前    · 
精明的日记本  ·  江西省发布第三批非法集资严重失信人名单 ...·  1 年前    · 
奔放的梨子  ·  Creating Word ...·  2 年前    · 
奔跑的苦咖啡  ·  地藏菩萨本愿经讲记(第十三卷)·  2 年前    · 
愤怒的菠萝  ·  异兽魔都(林田球创作的系列漫画)_搜狗百科·  2 年前    · 
Code  ›  vue 中 $set与$delete的使用开发者社区
delete vue
https://cloud.tencent.com/developer/article/1649064
飞奔的山羊
2 年前
作者头像
tianyawhl
0 篇文章

vue 中 $set与$delete的使用

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > 前端之攻略 > vue 中 $set与$delete的使用

vue 中 $set与$delete的使用

作者头像
tianyawhl
发布 于 2020-06-22 15:34:23
784 0
发布 于 2020-06-22 15:34:23
举报

对于对象

Vue无法检测property的添加或移除,由于Vue会在初始化实例时对property执行getter/setter转换,所以propterty必须在data对象上存在才能让Vue将它转换为响应式的。例如

var vm = new Vue({
  data:{
// `vm.a` 是响应式的
vm.b = 2
// `vm.b` 是非响应式的

对于已经创建的实例,Vue不允许添加根级别的响应式属性,但是可以使用

Vue.set(vm.someObject, "b" ,2)

也可以使用vm.$set实例方法,这也是全局Vue.set方法的别名

this.$set(this.someObject, "b", 2)

如果为已有的对象赋值多个新property

this.someObject = Object.assign({},this.someObject,{a:1,b:2})

例子

            <div class>
              <el-input style="width:170px" v-model="parKey" class="margin_r20"></el-input>参数值:
              <el-input style="width:170px" v-model="parName" class="margin_r10"></el-input>
              <el-button type="primary" size="medium" @click="addPar">增加</el-button>
            </div>参数列表
            <ul class="parList">
              <li v-for="(value, name, index) in AddEditeDialog.netTypeParam" :key="index">
                {{name}} : {{value}}
                <el-button size="mini" round @click="delPar(name)" class="pull-right">删除</el-button>
            </ul>
    addPar() {
      this.parKey = this.parKey.trim();
      this.parName = this.parName.trim();    
      this.$set(this.AddEditeDialog.netTypeParam, this.parKey, this.parName);
      // 不能写成this.AddEditeDialog.netTypeParam[this.parKey] = this.parKey
      this.parKey = "";
      this.parName = "";
    delPar(name) {
      this.$delete(this.AddEditeDialog.netTypeParam, name);
    },

对于数组

Vue不能检测以下数组的变动

vm.items[indexOfItem] = newValue
vm.items.length = newLength
var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
vm.items[1] = 'x' // 不是响应性的
vm.items.length = 2 // 不是响应性的
vm.items[indexOfItem] = newVue
// 可以采用下面2种方法实现响应式
 
推荐文章
满身肌肉的高山  ·  vue 报错 ReferenceError: exports is not defined - 兔&&大梅
3 月前
谈吐大方的电池  ·  Vue的methods方法中调用另一个方法及this指向问题_vue中实现methods一个方法调用另外一个方法
1 月前
爱吹牛的香烟  ·  vue使用quill编辑器自定义附件上传方法,并根据上传附件名称生成链接_quill 上传附件
1 月前
怕考试的木耳  ·  软件分享库合集链接汇总推荐_蓝奏云软件分享链接网站汇总手机 - 骑士助手
9 月前
精明的日记本  ·  江西省发布第三批非法集资严重失信人名单 _ 防范金融风险 _ 南昌县人民政府
1 年前
奔放的梨子  ·  Creating Word Application using Excel VBA: Run-time error '429': ActiveX component can't create obje
2 年前
奔跑的苦咖啡  ·  地藏菩萨本愿经讲记(第十三卷)
2 年前
愤怒的菠萝  ·  异兽魔都(林田球创作的系列漫画)_搜狗百科
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号