【Vue】响应式与数据劫持

目录

前言

响应式

Vue的响应式是如何实现的

数据劫持

Vue中的data属性都具有响应式

Vue后期添加的属性如何使其具有响应式

数组的响应式处理

如何使用数组下标去修改可以具有响应式呢


前言

什么是响应式?数据劫持是什么?Vue响应式是如何实现的?

响应式

什么是响应式呢?在修改data后,页面自动改变/刷新。这就是响应式

javascript 复制代码
<div class="app">
        <h1>{{msg}}</h1>
        a<input type="text" v-model="num1">
        b<input type="text" v-model="num2">
        结果:{{results()}}
    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'响应式与数据劫持',
                num1:'',
                num2:''
            },
            methods:{
                results(){
                   return this.num1*this.num2
                }
            }
        })
    </script>

当data中的num1和num2改变时,页面也会自动刷新改变

Vue的响应式是如何实现的

想知道Vue的响应式是如何实现的,我们先要了解一下数据劫持

数据劫持

在前面的文章中我们提到过数据代理机制,其中是使用了Object.defineProperty,其中配置了getter方法和setter方法,其中getter方法为数据代理,而我们这里要介绍的是setter方法,数据劫持。由前面可知,getter方法是当我们查看数据时触发的,而setter方法是我们修改数据时就会触发,而响应式是当data中的数据发生改变是,页面自动发生改变,所以说当我们修改属性值时,setter方法被自动调用,而setter方法不仅修改了属性值,而且还重新渲染了页面,setter方法就像半路劫持一样,所以称为数据劫持

Vue中的data属性都具有响应式

在原有的代码基础上,在data中增加一个属性a,属性a是对象,里面有属性b

javascript 复制代码
 data:{
                msg:'响应式与数据劫持',
                num1:'',
                num2:'',
                a:{
                    b:''
                }
            },

查看Vue实例可得

Vue会给data中的所有属性,以及属性中的属性,都会添加响应式

Vue后期添加的属性如何使其具有响应式

我们给属性a追加一个属性email

javascript 复制代码
 vm.a.email="[email protected]"

可以看出追加的属性是不具有响应式的

那如何使其具有响应式

Vue.set(目标对象,'属性名',值)

vm.$set(目标对象,'属性名',值)

修改上述代码

javascript 复制代码
 Vue.set(vm.a,'email','[email protected]')
 vm.$set(vm.a,'address','[email protected]')

数组的响应式处理

javascript 复制代码
<div class="app">
        <h1>{{msg}}</h1>
        {{arr1[0].name}}<br>
        {{arr1[1].name}}<br>
        {{arr1[2].name}}<br><br>
        {{arr2[0]}}<br><br>
        {{arr2[1]}}<br><br>
        {{arr2[2]}}<br><br>

    </div>
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                msg:'响应式与数据劫持',
                arr1:[
                    {id:'1',name:'lisi',age:20},
                    {id:'2',name:'wangwu',age:22},
                    {id:'3',name:'zhangsan',age:23},
                ],
                arr2:['1','2','3']
            },
        })
 
    </script>

使用数组下标修改属性值

可知,直接使用数组下标去修改属性值是没有响应式的

如何使用数组下标去修改可以具有响应式呢

Vue.set(数组对象,'index',值)

vm.$set(数组对象,'index',值)

2.调用Vue提供的7个API

  • push()
  • pop()
  • reverse()
  • splice()
  • shift()
  • unshift()
  • sort()
相关推荐
liangshanbo12151 分钟前
深入讲解 CSS 选择器权重及实战
前端·css
cg50176 分钟前
Spring Boot 中的自动配置原理
java·前端·数据库
尘寰ya6 分钟前
前端面试-React篇
前端·react.js·面试
vvilkim7 分钟前
React 高级特性与最佳实践
前端·javascript·react.js
拉不动的猪7 分钟前
vue与react中监听的简单对比
前端·javascript·面试
涵信8 分钟前
第七节:React HooksReact 18+新特性-并发模式(Concurrent Mode)解决了什么问题?
前端·javascript·react.js
冴羽14 分钟前
SvelteKit 最新中文文档教程(21)—— 最佳实践之图片
前端·javascript·svelte
纪元A梦24 分钟前
华为OD机试真题——跳格子3(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·javascript·c++·python·华为od·go·华为od机试题
BillKu1 小时前
遵守 Vue3 的单向数据流原则:父组件传递对象 + 子组件修改对象属性,安全地实现父子组件之间复杂对象的双向绑定示例代码及讲解
javascript·vue.js·elementui
李鸿耀1 小时前
Flex布局完全指南,Flexbox 在线演示工具推送
前端·flexbox