vue的响应式原理面试_vue面试题目

vue的响应式原理面试_vue面试题目coderwhyVue面试题-vue响应式原理笔记

大家好,又见面了,我是你们的朋友全栈君。

Vue的响应式原理

  • 数据发生改变,界面跟着更新,并不是理所当然的,Vue内部是做了很多封装的

依赖技术的分析和学习

  • 首先,来看一个最简单的Vue响应式例子:
 <div id="app">
        {
  
  {message}}
 </div>
   <script src='./js/vue.js'></script>
    <script> const app = new Vue({ 
      el: '#app', data: { 
      message: '哈哈哈哈', name: 'coderYYY' } }) </script>
  • 分析
    • 1.app.message修改数据,Vue内部是如何监听message数据的改变?
      • Vue2 -> object.defineProperty -> 监听对象属性的改变
      • Vue3 -> Proxy
    • 2.当数据发生改变,Vue是如何知道要通知哪些人,界面发生刷新?
      • 发布者订阅者模式
    const obj = { 
   
            message: '哈哈哈哈',
            name: 'yyy'
        }
        // 1.监听值的改变 -> Object.defineProperty(属性所在的对象,要添加或者修改的对象属性,属性描述符)
        Object.keys(obj).forEach(key => { 
   
            let value = obj[key]

            Object.defineProperty(obj, key, { 
   
                set(newValue) { 
   
                    console.log('监听' + key + '改变');
                    // 告诉谁?谁用告诉谁?谁在用?
                    // 根据解析html代码,获取到哪些人有用属性
                    // 张三/李四/王五 在用
                    value = newValue
                    // dep.notify()// 通知
                },
                get() { 
   
                    // 谁用一次就会调用一次get
                    // 张三: get -> update
                    // 李四: get -> update
                    // 王五: get -> update
                    console.log('获取' + key + '对应的值');
                    return value
                }
            })
        })
        // 2.发布者订阅者模式
        // 发布者
        class Dep { 
    // 存储所有对属性有依赖的东西
            constructor() { 
   
                this.subscribe = [] // subscribe 订阅 这个数组记录谁要订阅属性
            }
            addSub(watcher) { 
   
                this.subscribe.push(watcher)
            }
            notify(){ 
   
                this.subscribe.forEach(item=>{ 
   
                    item.update()
                })
            }
        }
        const dep = new Dep()
        // 订阅者
        class Watcher { 
   
            constructor(name) { 
   
                this.name = name;
            }
            update() { 
   
                console.log(this.name + '发生update');
            }
        }
        const w1 = new Watcher('张三')
        dep.addSub(w1)
        const w2 = new Watcher('李四')
        dep.addSub(w2)
        const w3 = new Watcher('王五')
        dep.addSub(w3)
        dep.notify()

在这里插入图片描述
在这里插入图片描述

通过图解理解过程

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135185.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • H3C交换机配置telnet

    H3C交换机配置telnet1、telnet配置方法(常用方法):&lt;H3C&gt;sysSystemView:returntoUserViewwithCtrl+Z.[H3C]telnetserverenable   //使能telnet服务[H3C]user-interfacevty0   //设置telnet[H3C-ui-vty0-4]authentication-modenone[H…

    2022年6月20日
    45
  • leetcode链表问题_反转一个单链表

    leetcode链表问题_反转一个单链表给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。示例 1:输入:head = [1,2,3,4,5], left = 2, right = 4输出:[1,4,3,2,5]示例 2:输入:head = [5], left = 1, right = 1输出:[5] 提示:链表中节点数目为 n1 <= n <= 500-500

    2022年8月9日
    4
  • 精华篇:数组指针

    精华篇:数组指针一.数组指针1.定义:数组指针,指的是数组名的指针,即数组首元素地址的指针。即是指向数组的指针。例:int(*p)[10];p即为指向数组的指针,又称数组指针。2.特性:…

    2022年7月3日
    31
  • 趣味编程游戏_全脑开发训练100个游戏

    趣味编程游戏_全脑开发训练100个游戏在信息技术迅猛发展的时代,操纵计算机,与电脑对话的能力已经成了事实上的技能标配,也已经深深地融入了我们每个人的生活当中。游戏行业也不例外,近几年,随着全民编程的热潮,许多游戏厂商也纷纷把编程融入自己的游戏当中,甚至推出了许多专门为编程爱好者/编程学习者制作的编程解密游戏。今天要推荐的九个游戏,可谓风格各异,老少咸宜,不论你是对编程完全陌生的新手,还是硬核老鸟,一定能找到一款适合你的游戏。话…

    2022年4月19日
    98
  • 局域网 广域网 网际网络[通俗易懂]

    局域网 广域网 网际网络[通俗易懂]网络的分类

    2022年10月19日
    9
  • origin同时画多个图_origin图形重叠

    origin同时画多个图_origin图形重叠http://www.xici.net/d116347704.htm这个文章叙述的不错

    2022年9月21日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号