Vue底层原理之变化侦测 —— 让对象每一个属性都变得“可侦测”(一)

简介: 笔记

1. 说在前面


1.1 Vue的两大特性


组件系统:把页面抽象成多个相对独立的模块,实现代码重用,提高开发效率和代码质量,便于代码维护。

数据驱动:宗旨是以数据驱动,减少dom操作。

数据可以理解为状态,视图即是用户所见页面,它是动态变化的,根据用户的操作或者后台数据变化来,状态变化视图(也就是页面)也会随之改变,所以我们得到了这样一个公式:

7.png

state是状态输入,页面UI是得到的结果,状态改变,页面随之改变,这便是数据驱动视图。

state与UI是用户所定义,render()是固定的,所以这也是Vue扮演的角色。

那么,Vue怎么知道state变化了呢?😧😧

1.2 变化侦测的定义


我们期望出现的结果是:Vue能够监听到数据的变化,既而改变视图。

变化侦测即是追踪数据状态,一旦数据变化,就去更新视图。


2. 使Object数据“可侦测”


2.1 单个属性监听


如果我们要监听以下对象的某个属性:

let obj = {
  name: '小明',
  age: 18
}

众所周知,我们可以对这个对象里的任意属性进行增删改查等诸多操作,那么,我们如何才能知道:操作的具体属性是哪个,操作完的结果变成了什么?😣😣

  • 接下来,轮到Object.defineProperty() 出场了
let value = '小明';
Object.defineProperty(obj,  "name", {
    get: function() {
           console.log("取值")
           return value;
       },
     set: function(val) {
         console.log(`新值${value}`)
         value = val
     }
})

这样便可以知道name属性的变化,读取和操作都能监听到11.png


image.png


  • name 属性我们可以监测到变化与读取,但是age属性是不行的
  • 数据虽有变化,但是没法捕获,这显然是不对的,(就好像我娶了几个漂亮老婆,不发朋友圈让大家知道,炫耀一番,心里总是不舒服的

image.png


3. 让对象所有属性都变成“可观测”


  • 代码如下:

observer.js 实现

  • 为了让obj里的每一个数据都变得可观测,我们可以写一个专门负责侦听的类,代码如下:
  • 注释也写的明明白白的,别忘了给个三连(给大家拜年了🙏🙏🙏)
export class Observer {
    // 初始化
    constructor(value) {
        this.value = value
        if(Array.isArray(value)){
            // 数组的逻辑
        }else{
            // 对象的逻辑
            this.walk(value)
        }
    }
    // 先考虑对象
    // 具体的操作
    walk(obj) {
        const keys = Object.keys(obj)  // []
        for(let i = 0; i < keys.length; i++){
            defineReactive(obj, keys[i])
        }
    }
}
// 让一个对象转化成可观测对象
function defineReactive(obj, key, val){
    // 减少一个变量 
    if(arguments.length === 2){
        val = obj[key] // 当前项的值 => 基本类型?引用类型
    }
    // 引用类型,递归深层对象
    if(typeof val === "object"){
        new Observer(val)
    }
    Object.defineProperty(obj, key, {
        enumerable: true, // 可枚举
        configurable: true, // 可删除
        get() {
            console.log(`${key}属性被读取${val}`)
            return val
        },
        set(newVal){
            if(val === newVal){
                return
            }
            console.log(`${key}属性被修改了,值为${newVal}`)
            val = newVal
        }
    })
}


4.测试及使用


  • 代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <h2>如何让对象中的每一个属性都能够被观测?</h2>
    <script type="module">
        import { Observer } from './observer.js'
        let obj =  new Observer({
            name: '小明',
            age: 18,
            demo: {
                a: 111,
                b: 'str'
            }
        })
        console.log(obj.value.name)
        console.log(obj.value.age)
        console.log(obj.value.demo.a)
        obj.value.age = 20
    </script>
</body>
</html>

效果在这里👇👇👇


image.png


目录
相关文章
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
35 1
|
2月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
36 1
|
2月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
2月前
|
JavaScript
Vue 双向数据绑定原理
Vue的双向数据绑定通过其核心的响应式系统实现,主要由Observer、Compiler和Watcher三个部分组成。Observer负责观察数据对象的所有属性,将其转换为getter和setter;Compiler解析模板指令,初始化视图并订阅数据变化;Watcher作为连接Observer和Compiler的桥梁,当数据变化时触发相应的更新操作。这种机制确保了数据模型与视图之间的自动同步。
|
2月前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
2月前
|
缓存 JavaScript 搜索推荐
Vue SSR(服务端渲染)预渲染的工作原理
【10月更文挑战第23天】Vue SSR 预渲染通过一系列复杂的步骤和机制,实现了在服务器端生成静态 HTML 页面的目标。它为提升 Vue 应用的性能、SEO 效果以及用户体验提供了有力的支持。随着技术的不断发展,Vue SSR 预渲染技术也将不断完善和创新,以适应不断变化的互联网环境和用户需求。
89 9
|
2月前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
67 0
|
3月前
|
监控 JavaScript 开发者
在 Vue 中,子组件为何不可以修改父组件传递的 Prop,如果修改了,Vue 是如何监控到属性的修改并给出警告的
在 Vue 中,子组件不能直接修改父组件传递的 Prop,以确保数据流的单向性和可预测性。如果子组件尝试修改 Prop,Vue 会通过响应式系统检测到这一变化,并在控制台发出警告,提示开发者避免这种操作。
|
3月前
|
JavaScript 前端开发 API
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
34 0
|
3月前
|
缓存 JavaScript Serverless
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
179 0

热门文章

最新文章