vue.set this.$set的作用

news2025/1/12 16:08:46

Vue.set 的作用就是在构造器外部操作构造器内部的数据、属性或者方法

当一个对象在vue中是响应式的,如果仅仅使用普通的方式向这个对象添加或修改这个属性的值,是不会触发视图更新的

但是使用 vue.set 或者 this.$set 的方式可以使得新添加的属性也是响应式的,并触发视图更新
例如:

通过Vue.set处理通过数组下标修改数组属性值时,页面不渲染问题

需求: 在列表里要通过按钮的点击控制手机号码列是显示正常的号码还是显示星号******

首先想到的实现方式就是给表格的每条数据增加一个 showFlag 属性,showFlag:true 显示正常的手机号,showFlag:false 显示星号*****,点击按钮就修改该条数据的showFlag的值

代码:

<template>
    <div>
        <div
            v-for="(item,index) in List"
            :key="index"
            class="phone"
        >
            <span v-if="item.showFlag">{{item.name}}--{{item.phone}}</span>
            <span v-else>{{item.name}}--***********</span>
            <button @click="changeState(index)">点我改变状态</button>
        </div>
    </div>
</template>

方法:

<script>
export default {
    //数据
    data() {
        return {
            List: [],
        }
    },
    created() {
        this.getList()
    },
    methods: {
        //显示手机号点的点击方法
        changeState(i) {
            this.List[i].showFlag = !this.List[i].showFlag
            console.log('showFlag:',this.List[i].showFlag);
 
        },
        //获取列表数据的方法
        getList() {
            this.List = [
                { name: '小明', phone: 13579000001 },
                { name: '小红', phone: 13579000002 }
            ]
            this.List.map(item => {
                item.showFlag = true
                console.log(item);
            })
        }
    },
}
</script>


这时:点击这条数据的按钮,页面显示并不会从数字变换成*****

当点击按钮1时,通过数组下标来更改 showFlag 的值成功,但是页面并没有重新渲染,模板没有被重新解析;

产生问题的原因:Vue2并不支持数组下标的响应式,也就是说Vue2检测不到通过下标更改数组的值。

解决办法:使用Vue官网提供的方法更改数组下标的值

changeState(i) {
            this.List[i].showFlag = !this.List[i].showFlag
            console.log(`按钮${i + 1}的 showFlag:`, this.List[i].showFlag);
            //增加下面这行
            this.$set(this.List, i, this.List[i])
        },

再举个例子:

需求:点击上移按钮实现div上移一个,点击下移按钮实现div下移一个

<div v-for="(item,index) in tabList">
    <div>{{ item.title}}</div>
    <div class="work-item-img">
        <img @click="moveUp(index)" src="../../assets/w上移.png" alt="" />
	    <img @click="moveDown(index)" src="../../assets/w/下移.png" alt="" />
    </div>
</div>

方法:

	data(){
       return {
        tabList: [
				{
					id: 2,
					title: '应用',
				},
				{
					id: 1,
					title: '统计',
				}
			],
        }
    }
		//上移
		moveUp(index) {
			if (index == 0) return
			let W = this.tabList[index]
			this.$set(this.tabList, index, this.tabList[index - 1])
			this.$set(this.tabList, index - 1, W)
		},
		moveDown(index) {
			if (index == this.tabList.length - 1) return
			let W = this.tabList[index]
			this.$set(this.tabList, index, this.tabList[index + 1])
			this.$set(this.tabList, index + 1, W)
		},

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/615868.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ARM AMBA AXI 入门 2 - AXI协议中的BURST】

文章目录 1.1 突发传输简介1.1.1 AXI4 突发传输控制信号1.1.1.1 AxLEN 突发传输长度1.1.1.2 AxSIZE 突发传输宽度1.1.1.3 AxBURST 突发传输类型 1.1.2 AXI 传输实例 1.1 突发传输简介 在地址总线上进行一次地址传输后&#xff0c;进行多次数据传输( data transfer&#xff09;…

GPT4 在医学任务表现-Capabilities of GPT-4 on Medical Challenge Problems

微软和openai在2023年4月的论文。 Capabilities of GPT-4 on Medical Challenge Problems 数据集介绍 USMLE Self Assessments&#xff1a;问题&#xff0c;有表格 USMLE Sample Exam&#xff1a;pdf&#xff0c;有图片 MedQA&#xff1a;多语种多选&#xff0c; PubMedQA…

基于Python的接口自动化-pymysql模块操作数据库

目录 引言 一、PyMySQL安装 二、Python操作数据库 写在最后 引言 在进行功能或者接口测试时常常需要通过连接数据库&#xff0c;操作和查看相关的数据表数据&#xff0c;用于构建测试数据、核对功能、验证数据一致性&#xff0c;接口的数据库操作是否正确等。 因此&#x…

MES系统选择指南:企业如何选择适合需求的MES管理系统?

MES&#xff08;Manufacturing Execution System&#xff09;管理系统是一种用于生产管理的软件系统&#xff0c;可以帮助企业提高生产效率、降低成本和提高质量。然而&#xff0c;不同类型的MES管理系统适用于不同类型的企业需求&#xff0c;因此选择适合自己企业需求的MES管理…

基于瑞芯微芯片RK3399学习

同是soc&#xff0c;参加新星计划学习下大佬的思路 sys系统 针对&#xff1a;&#xff08;内核&#xff09;1.1、通过sysfs清楚了解设备的系统状况的学习 通过了解sys目录和文件了解嵌入式设备的系统状况。 sysfs把连接在系统上的设备和总线组织成为一个分级的文件&#xff0c…

全国职业院校技能大赛信息安全管理与评估赛题一

全国职业院校技能大赛 高等职业教育组 信息安全管理与评估 赛题一 模块一 网络平台搭建与设备安全防护 赛项时间 共计180分钟。 赛项信息 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 第一阶段 网络平台搭建与设备安全防护 任务1 网络平台搭建 XX:XX- XX:XX 50 任务…

第6章SpringMVC的RESTful

一、RESTful 1.RESTful简介 REST&#xff1a;Representational State Transfer&#xff0c;表现层资源状态转移 ①资源 将服务器看作是由很多离散的资源组成。每个资源是服务器上一个可命名的抽象概念 ②资源的表述 源的表述可以有多种格式&#xff0c;例如HTML/XML/JSON…

yolo v5

参考 睿智的目标检测56——Pytorch搭建YoloV5目标检测平台 原理 前处理 网络结构 整体思想 思想框架 特征提取-特征加强-预测先验框对应的物体情况。 改进部分 1、主干部分&#xff1a;使用了Focus网络结构&#xff0c;具体操作是在一张图片中每隔一个像素拿到一个值&…

118. 杨辉三角解题思路

文章目录 题目解题思路 题目 给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 示例 1: 输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例 2: 输入: num…

【Java基础】集合List/Set/Map

零、重点 初始大小加载因子扩容大小底层机制ArrayList101(存满)1.5倍动态数组&#xff0c;Arrays.copyof()HashMap160.752.0倍 jdk1.7及其之前&#xff1a;数组单向链表&#xff08;有扩容死锁问题&#xff09; jdk1.8及其之后&#xff1a;Node 数组 单向Node链表 红黑树 …

大专苦学 37 天,5 轮面试,6 小时灵魂拷问,含泪拿下阿里 offer~

先纠正一下大家的错误认知&#xff0c;大专学历不是不能进大厂&#xff0c;只不过很难罢了&#xff0c;比如阿里就有很多大专学历的人&#xff1b;学历低想进大厂很难的&#xff0c;不光需要的技术足够厉害&#xff0c;还需要有合适的内推人&#xff08;人脉&#xff09;以及恰…

机器的眼睛:漫谈机器视觉(文末送书)

眼睛是人心灵的窗户&#xff0c;我们可以通过凝视对方的眼神来理解他人。当有一天你走过一道需要刷脸才能通过的大门&#xff0c;突然间看到一个冰冷的摄像头在凝视着你的时候&#xff0c;你是否也曾若有所思地看着它&#xff0c;心中充满了疑惑——它是如何工作的&#xff1f;…

苹果颠覆性新品取代iPhone,5万元新电脑告别 Intel

今日凌晨苹果正式举行了 WWDC23 Apple 全球开发者大会。 和往年相比 WWDC23 可以说是倍受关注&#xff0c;在召开前就有号称革命性产品问世的消息。 场面如此壮观&#xff0c;今年到底苹果又带来了什么引领时代的玩意&#xff1f; 革命性产品又是否能接力乔布斯时代&#xff…

day06——朴素贝叶斯算法

朴素贝叶斯算法 一、什么是朴素贝叶斯分类方法二、概率基础知识1&#xff0c;联合概率2&#xff0c;条件概率 三、贝叶斯公式1&#xff0c;公式2&#xff0c;拉普拉斯平滑系数 四、API五、实操案例&#xff1a;20类新闻分类代码 六、总结 一、什么是朴素贝叶斯分类方法 朴素贝…

漫谈大数据 - 如何设计业务埋点方案与数据采集应用

业务埋点和数据分析是在用户行为和业务数据上进行跟踪、收集和分析的关键方法&#xff0c;用于了解用户行为模式、改进产品和服务&#xff0c;并做出数据驱动的决策。 全文1.5万字&#xff0c;建议阅读时间35min。 目录 业务埋点 埋点的重要性 埋点的类型 全埋点 代码埋点…

springboot3自动装配机制原理(小白也看得懂)

springbootApplication注解 实现自动装配的核心就是EnableAutoConfiguration。(springboot就是通过此注解实现自动装配机制&#xff0c;主要作用就是让springboot去扫描默认的配置类&#xff0c;如果没有这个类的话&#xff0c;springboot只会默认扫描启动类下包中各个类的注解…

nuxt3项目在宝塔上使用pm2放到服务器

最近在将nuxt3项目扔到服务器上的时候遇到了一些问题&#xff0c;发现打包后的nuxt项目与正常的vue文件有些差别&#xff0c;缺失了index.html文件。 这边就记录下nuxt3项目是怎么放到服务器上的&#x1f914; 一、打包nuxt3项目 执行对应的打包命令 yarn build 二、找…

Electron详解(一):基本介绍

文章目录 一、electron简介二、发展历史三、electron优缺点四、electron和Qt的对比五、使用electron开发的实际案例六、electron 的原理 一、electron简介 Electron&#xff08;官网&#xff1a;https://www.electronjs.org/zh/&#xff09;是由Github开发&#xff0c;用HTML&…

17:00面试,还没10分钟就出来了,问的实在是太...

从外包出来&#xff0c;没想到死在另一家厂子 自从加入这家公司&#xff0c;每天都在加班&#xff0c;钱倒是给的不少&#xff0c;所以也就忍了。没想到8月一纸通知&#xff0c;所有人不许加班&#xff0c;薪资直降30%&#xff0c;顿时有吃不起饭的赶脚。 好在有个兄弟内推我去…

CVE-2022-30887

文章目录 CVE-2022-30887一、漏洞介绍二、渗透步骤1、打开网站2、登录网站3、shell4、文件上传5、查看flag CVE-2022-30887 一、漏洞介绍 多语言药房管理系统 (MPMS) 是用 PHP 和 MySQL 开发的, 该软件的主要目的是在药房和客户之间提供一套接口&#xff0c;客户是该软件的主要…