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)
上一篇 2022年5月3日 下午1:40
下一篇 2022年5月3日 下午1:40


相关推荐

  • 【CEGUI】CEGUI入门篇之初始化(一)[通俗易懂]

    【CEGUI】CEGUI入门篇之初始化(一)[通俗易懂]以下内容翻译自http://static.cegui.org.uk/docs/0.8.7/rendering_tutorial.html1、简介初始化CEGUI时,不管其渲染API或渲染引擎是什么,都包括三个基本步骤:(1)创建一个基于CEGUI::Renderer对象的实例。(2)创建CEGUI::System对象,参数为上一步创建的Renderer实例。(3)每一帧都调用CEGUI:

    2022年7月24日
    11
  • Redis lock_lock锁机制原理

    Redis lock_lock锁机制原理Redisson分布式锁原理1.工具类packagecom.meta.mall.common.utils;importlombok.extern.slf4j.Slf4j;importorg.redisson.api.RLock;importorg.redisson.api.RedissonClient;importorg.springframework.stereotype.Component;importjavax.annotation.Resource;import

    2022年10月15日
    4
  • C语言中数据的输出格式有哪些?

    C语言中数据的输出格式有哪些?C语言中数据的输出格式有哪些?(1)d(或i)格式符。用来输出十进制整数,有以下几种用法:①%d,按整型数据的实际长度输出。②%md,m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。③%ld(%mld也可),输出长整型数据。例如:longa=123456;printf("%ld",…

    2022年7月24日
    30
  • Python学习系列:PyCharm CE 安装与测试

    Python学习系列:PyCharm CE 安装与测试开坑啦开坑啦~最近比赛要用Python了,开始强行学习。Mac下PyCharmCE安装先去百度PyCharm,一个很好用IDE,下载免费版的就够用啦:https://www.jetbrains.com/pycharm/然后下载安装,这里就一步步走就好。重点是你的Python,Mac自带的是Python2PyCharm在新建项目的时候会自动识别。测试我们新建一个项目:设置…

    2022年8月29日
    8
  • js中settimeout()的用法详解_js中setattribute

    js中settimeout()的用法详解_js中setattributesetTimeout与setTimeInterval均为window的函数,使用中顶层window一般都会省去,这两个函数经常稍不留神就使用错了。setTimeout内的函数先不执行,隔一段时间后再执行,函数后面的数字是隔的时间,单位是毫秒(千分之一秒)比如:setTimeout(‘alert(“helloworld!”)’,400);setInterval()方法可按照

    2022年10月5日
    4
  • 三种最短路的总结

    三种最短路的总结

    2021年9月28日
    46

发表回复

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

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