zoukankan      html  css  js  c++  java
  • vue 中 $set与$delete的使用

    对于对象

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

    var vm = new Vue({
      data:{
        a:1
      }
    })
    
    // `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="170px" v-model="parKey" class="margin_r20"></el-input>参数值:
                  <el-input style="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>
                  </li>
                </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 // 不是响应性的

    秒收目录站https://www.tomove.com.cn

    vm.items[indexOfItem] = newVue
    // 可以采用下面2种方法实现响应式
    Vue.set(vm.items, indexOfItem, newValue) || vm.$set(vm.items, indexOfItem, newValue)
    vm.items.splice(indexOfItem, 1, newValue)
    
    vm.items.length = newLength
    // 可以采用下面方法实现响应式
    vm.items.splice(newLenght)
  • 相关阅读:
    MyBatis 基础搭建及架构概述
    Effective Java
    Effective Java
    Spring注解?啥玩意?
    Spring 中的Null-Safety
    Spring Resource框架体系介绍
    内部类的用法
    一文了解ConfigurationConditon接口
    详解状态压缩动态规划算法
    【硬核】使用替罪羊树实现KD-Tree的增删改查
  • 原文地址:https://www.cnblogs.com/qianxiaox/p/13704865.html
Copyright © 2011-2022 走看看