一、Vue 更改数组中的值,页面不刷新问题

data{

hobby:["打游戏",“想静静”,“发呆”]

}

1、错误写法(页面不刷新):

this.hobby[0]="学习";

2、正确写法(页面刷新):

(1)方法1,调用列表操作函数更新数组数据 : this.hobby.splice(0,1,"学习");

(2)方法2,调用Vue的set方法更新数组数据:this.$set(this.hobby,0,"学习");

二、Vue监视数据的原理如下:

1、Vue 会监视数据中所有层次的数据

2、如何检测对象中的数据?

答:通过setter实现监视,且要在new Vue时就传入要监测的数据。

(1)对象中追加的属性,Vue 默认不做响应式处理;

(2)如需给后添加的属性做响应式,请使用如下API:

Vue.set(target,propertyName/Index,value);或 this.$set(target,propertyName/Index);

3、如何监测数组中的数据?

答:通过包裹数组更新元素的方法实现,本质就是做了两件事:

(1)调用原生对应的方法数组进行更新;

(2)重新解析模板,进行更新页面。

4、在Vue 修改数组中的某个元素,一定要用如下方法:

(1)使用这些API:push()、pop()、shift()、unshift()、splice()、sort()、rverse()

(2)Vue.set()或vm.$set()

push():往数组最后添加一个元素;

pop():删除数组最后一个元素;

shift():删除数组第一个元素;

unshift():往数组最前面添加一个元素

splice():操作某个元素,可修改数组中的元素

sort():排序

reverse():数组反转

5、特别注意:Vue.set()和vm.$set()不能给vm或vm的根数据对象添加属性!

6、直接操作数组,页面不更新;直接操作对象,页面更新

(1)this.student.hobby[0]="学习";(操作数组,页面不刷新)

(2)this.student.friend[0].name="张三";(操作对象,页面刷新)

视频讲解:https://www.bilibili.com/video/BV1Zy4y1K7SH?p=37&vd_source=60a28e8364654bee938864b1d19905ec

第35、36、37集

Vue 更改数组中的值,页面不刷新问题。解决方法+原理说明的更多相关文章

  1. vue更改数组中的值

    根据下标更改时 vm为新建的vue对象 ind为数组 第一个e为在数组ind中e索引位置 第二个e为更改为值e vm.$set(vm.ind,e,e) 常规更改 arr为数组 //添加 arr.pus ...

  2. WordPress更改“固定链接”后 ,页面出现404的解决方法

    一.Web服务器对应的是Nginx 解决方案:修改linux服务器下Nginx的配置文件,目录为:/usr/local/nginx/conf/nginx.conf, 也可以直接使用命令nginx -t ...

  3. vue项目中,更改数组元素的值,视图没有实时更新?

    问题背景: export default { data(){ showItems: [false, false, false, false] }, methods: { showItem(index) ...

  4. JS去除数组中重复值的四种方法

    JS去除数组中重复值的四种方法 1 /// <summary>            o[this[i]] = "";  }      }       newArr.p ...

  5. Vue 改变数组中对象的属性不重新渲染View的解决方案

    Vue 改变数组中对象的属性不重新渲染View的解决方案 在解决问题之前,我们先来了解下 vue响应性原理: Vue最显著的一个功能是响应系统-- 模型只是一个普通对象,修改对象则会更新视图.受到ja ...

  6. PHP array_count_values() 函数用于统计数组中所有值出现的次数。

    定义和用法 array_count_values() 函数用于统计数组中所有值出现的次数. 本函数返回一个数组,其元素的键名是原数组的值,键值是该值在原数组中出现的次数. 语法 array_count ...

  7. PHP 中替换若干字符串字串为数组中的值,不用循环,非常高效

    替换某个字符串中的一个或若干个字串为数组中某些值 php本身有自带的函数,可以不用循环非常高效的实现其效果: 实例代码:   $phrase  = "You should eat fruit ...

  8. php 计算多维数组中所有值的总和

    php 内置函数 array_sum() 函数返回数组中所有值的总和,只能返回一维数组的总和: 计算多维数组所有值的和就要自定义函数了: function get_sum($array) { $num ...

  9. PHP 使用用户自定义的比较函数对数组中的值进行排序

    原文:PHP 使用用户自定义的比较函数对数组中的值进行排序 usort (PHP 4, PHP 5) usort —      使用用户自定义的比较函数对数组中的值进行排序 说明       bool ...

  10. PHP usort 使用用户自定义的比较函数对数组中的值进行排序

    From: http://www.php100.com/cover/php/2395.html usort (PHP 4, PHP 5) usort — 使用用户自定义的比较函数对数组中的值进行排序 ...

随机推荐

  1. 2.2 在resources目录下,新建applicationContext.xml

    <?xml version="1.0" encoding="UTF-8"?> <beans> <!-- 这个bean标签的作用是, ...

  2. scrapy 爬取酷狗热门歌手音乐

    目录 声明 Hello,酷狗! 创建一个Scrapy项目 spider模块 分析前端界面 注意 items模块 pipeline模块 处理音频文件自定义下载路径 自定义下载图片路径 异步存入到数据库 ...

  3. 记录一次Python环境安装出现的问题(已安装java)

    之前是在其他电脑上安装python环境,没有问题. 换了一台电脑开始安装(注:已配置java环境) 安装包准备好 ( 这里使用的是python 3.6.5(64位) ,下载地址选择官网) 教程百度都有 ...

  4. SQLServer错误:expected a simple type, a tuple or a list

    dict_data = { 'request_id': request_id, 'original_id': request_body.original_id, 'unit_type': reques ...

  5. vue中的Swiper使用slideTo提示no function

    参考官网资料解决:

  6. 利用for循环同步执行异步方法

    //定义一个异步函数 const foo1 = (i) => { return new Promise((resolve, reject) => { setTimeout(() => ...

  7. 禅道服务崩溃 Can't init tc log

      0.环境 禅道 版本12.4.3 数据库 10.1.22-MariaDB SQL 服务器 192.168.0.82 centos 7 step 1.问题 磁盘爆满后,禅道在启动时报数据库 Can' ...

  8. M1芯片使用pod报错 *** for architecture arm64

    1.添加如下配置 pod 和 工程都需要修改 2.Podfile最后添加如下代码 post_install do |installer| installer.pods_project.build_co ...

  9. 若依gateway

    1.若依后端gateway模块配置白名单 顾名思义,就是允许访问的地址.且无需登录就能访问.在ignore中设置whites,表示允许匿名访问. 2. SpringCloud Gateway网关配置( ...

  10. Oracle常用的日期操作函数 to_char()和to_date

    https://www.cnblogs.com/zhangliang88/p/12924407.html