前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vue的响应式原理面试_vue面试题目

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

作者头像
全栈程序员站长
发布2022-08-18 19:27:18
3860
发布2022-08-18 19:27:18
举报

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

Vue的响应式原理

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

依赖技术的分析和学习

  • 首先,来看一个最简单的Vue响应式例子:
代码语言:javascript
复制
 <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是如何知道要通知哪些人,界面发生刷新?
      • 发布者订阅者模式
代码语言:javascript
复制
    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.cn/135185.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月3,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vue的响应式原理
    • 依赖技术的分析和学习
      • 通过图解理解过程
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档