使用Vue.set()方法实现响应式修改数组数据

在页面中显示数组数据时发现了一个问题,当在methods方法中修改数组数据后,虽然数组已经发生改变,但是改变后的数据并没有渲染到页面上。这是因为在VUE中,如果在实例创建之后添加新的属性或者改变属性到实例上,它将不会触发视图更新。

而Vue.set()方法能够确保响应式对象被创建后仍然是响应式的,同时触发视图更新,动态响应数据的变化。

用法如下:

Vue.set(object,index,value)

object:要更改的数据源(数组或对象)

index:数据的索引(第几项)

value:修改后的值

 

实例

      <div v-for="(item,index) in state">
        <div class="student">
        <span>
          <img src="./../../../assets/icon.jpg">
          <span>小五</span>
        </span>
          <span><button @click="attence(index)">{{item}}</button></span>
        </div>
      </div>

该页面的考勤情况数据来源于一个数组,点击以后,考勤情况将会发生改变。

data(){
        return{
          id:1,
          state:['未知','未知','未知','未知','未知','未知','未知','未知','未知']
        }
      },
      methods:{
        attence:function(num){
          if(this.state[num]=='未知'){
            Vue.set(this.state,num,'出勤');
          }
          else if(this.state[num]=='出勤'){
            Vue.set(this.state,num,'请假');
          }
          else if(this.state[num]=='请假'){
            Vue.set(this.state,num,'缺勤');
          }
          else if(this.state[num]=='缺勤'){
            Vue.set(this.state,num,'未知');
          }
        }
      }

在这段代码中,数组中的数据初始值全都是未知,点击按钮以后,attence()方法会根据传入的参数改变数组中的值,传入的参数是几就改变第几项的数据。页面将会及时对数据变化作出响应,渲染出来。

 

注:该方法也可用来增加数据,只需将第二项的索引值赋为数组的长度,第三项为增加的数据值。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值