【转】Vue2.0 Vue.set的使用

2024-05-09 10:58

本文主要是介绍【转】Vue2.0 Vue.set的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里我定义了一个列表数据,我将通过三个不同的按钮来控制列表数据。

首先在列表中动态新增一条数据:

 

<!DOCTYPE html>
<html>
<head lang="en"><meta charset="UTF-8"><title></title>
</head>
<body>
<div id="app2">
<!--想了解这里key的作用请访问:(https://cn.vuejs.org/v2/api/#key)--><p v-for="item in items" :key="item.id">{{item.message}}</p><!--@click等价于v-on:click--><button class="btn" @click="btn1Click()">点我试试</button><br/>
</div><script src="../../dist/vue.min.js"></script>
<script>var vm2=new Vue({el:"#app2",data:{items:[{message:"Test one",id:"1"},{message:"Test two",id:"2"},{message:"Test three",id:"3"}]},methods:{btn1Click:function(){this.items.push({message:"动态新增"});//为data中的items动态新增一条数据}}});
</script>
</body>
</html>

这是我点击之前的列表:

 

这里写图片描述

点击之后列表新增了一条数据:

 

这里写图片描述

通过数组的变异方法(Vue数组变异方法)我们可以动态控制数据的增减,但是我们却无法做到对某一条数据的修改。这时候就需要Vue的内置方法来帮忙了~

Vue.set() 响应式新增与修改数据


此时我们需要知道Vue.set()需要哪些参数,官方API:Vue.set()

调用方法:Vue.set( target, key, value )

target:要更改的数据源(可以是对象或者数组)

key:要更改的具体数据

value :重新赋的值


我们依然用上面列表举例:

 

<!DOCTYPE html>
<html>
<head lang="en"><meta charset="UTF-8"><title></title>
</head>
<body>
<div id="app2"><p v-for="item in items" :key="item.id">{{item.message}}</p><button class="btn" @click="btn2Click()">动态赋值</button><br/><br/><button class="btn" @click="btn3Click()">为data新增属性</button>
</div><script src="../../dist/vue.min.js"></script>
<script>var vm2=new Vue({el:"#app2",data:{items:[{message:"Test one",id:"1"},{message:"Test two",id:"2"},{message:"Test three",id:"3"}]},methods:{btn2Click:function(){//Vue methods中的this 指向的是Vue的实例,这里可以直接在this中找到itemsVue.set(this.items,0,{message:"Change Test",id:'10'})},btn3Click:function(){var itemLen=this.items.length;Vue.set(this.items,itemLen,{message:"Test add attr",id:itemLen});}}});</script>
</body>
</html>

此时页面是这样

这里写图片描述

我点击第一个按钮后运行methods中的btn2Clcick方法,此时我要将Test one更改为Change Test

这里写图片描述

运行后的结果:此时列表中第一列的Test one已经变成了Change Test

 

这里写图片描述

这里得警惕一种情况:
当写惯了JS之后,有可能我会想改数组中某个下标的中的数据我直接this.items[XX]就改了,如:

 

btn2Click:function(){this.items[0]={message:"Change Test",id:'10'}}

我们来看看结果:

这里写图片描述

这种情况,是Vue文档中明确指出的注意事项,由于 JavaScript 的限制,Vue 不能检测出数据的改变,所以当我们需要动态改变数据的时候,Vue.set()完全可以满足我们的需求。

仔细看的同学会问了,这不是还有一个按钮吗,有什么用?

我们还是直接看:

这里写图片描述

这是初始的列表数据,数据里面有三个对象

点击之后:

这里写图片描述

这里可以看出,Vue.set()不光能修改数据,还能添加数据,弥补了Vue数组变异方法的不足

Tip:Vue.set()在methods中也可以写成this.$set()



作者:洛禾sunshime
链接:https://www.jianshu.com/p/c39d1c670d49
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

这篇关于【转】Vue2.0 Vue.set的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973219

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Springboot3 ResponseEntity 完全使用案例

《Springboot3ResponseEntity完全使用案例》ResponseEntity是SpringBoot中控制HTTP响应的核心工具——它能让你精准定义响应状态码、响应头、响应体,相比... 目录Spring Boot 3 ResponseEntity 完全使用教程前置准备1. 项目基础依赖(M

Java使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流