不努力code 2023-03-15 15:32 采纳率: 60%
浏览 22
已结题

vue中更新数组下标一个

vue2代码:


methods:{
             test(){
                    //this.arr[0] = {name:"new"} //这个不会更新视图
                    this.arr[0].name = "new" //这个会更新视图
                    
                }
         }

我知道vue2中更新的数组方法是:
重写的七大原生方法: push 、pop、shift 、unshift 、splice 、sort 、reverse
或者vue2中响应的Vue.set()方法

我知道更改下标不会产生视图更新
我大概能理解上面的代码为什么会更新,但是,不是很明白,怎么表述

  • 写回答

4条回答 默认 最新

  • 归来巨星 前端领域新星创作者 2023-03-15 15:46
    关注


    参照下原理
    你可以简单理解成 get set 监听的是 . 属性的变化
    他并没有去监听数组的下标,他只是没有处理数组的变化,并不是不能监听数组下内容的变化,但是有时层级过深或者后续新增的属性,并不能做到实时响应(这种就是层级过深的情况,无法监听)

    或者你从template里面直接去渲染了一个数组 v-for,然后 click=(scope.row),这个row不就是数组对象下的某个对象吗?那为什么[{}],{}内容变化,视图就可以直接更新呢?不用太纠结这些东西,再有这些其实数据已经变化了,只是视图没有变更,用$focusUpdate()重载一下也可以

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 4月4日
  • 已采纳回答 3月27日
  • 创建了问题 3月15日

悬赏问题

  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启