【备战春招】第8天 6-16 vue3用Proxy 实现响应式
2023/2/16 4:24:12
本文主要是介绍【备战春招】第8天 6-16 vue3用Proxy 实现响应式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
课程名称:前端框架及项目面试 聚焦Vue3/React/Webpack
课程章节:6-16 vue3用Proxy 实现响应式
课程讲师: 双越
课程内容:
6-16 vue3用Proxy 实现响应式
课程收获:
// 创建响应式 function reactive(target = {}) { if (typeof target !== 'object' || target == null) { // 不是对象或数组,则返回 return target } // 代理配置 const proxyConf = { get(target, key, receiver) { // 只处理本身(非原型的)属性 const ownKeys = Reflect.ownKeys(target) if (ownKeys.includes(key)) { console.log('get', key) // 监听 } const result = Reflect.get(target, key, receiver) // 深度监听 // 性能如何提升的? return reactive(result) }, set(target, key, val, receiver) { // 重复的数据,不处理 if (val === target[key]) { return true } const ownKeys = Reflect.ownKeys(target) if (ownKeys.includes(key)) { console.log('已有的 key', key) } else { console.log('新增的 key', key) } const result = Reflect.set(target, key, val, receiver) console.log('set', key, val) // console.log('result', result) // true return result // 是否设置成功 }, deleteProperty(target, key) { const result = Reflect.deleteProperty(target, key) console.log('delete property', key) // console.log('result', result) // true return result // 是否删除成功 } } // 生成代理对象 const observed = new Proxy(target, proxyConf) return observed } // 测试数据 const data = { name: 'zhangsan', age: 20, info: { city: 'beijing', a: { b: { c: { d: { e: 100 } } } } } } const proxyData = reactive(data)
谢谢老师,讲的非常细致,很容易懂。这一节学的是vue3用Proxy 实现响应式,为以后的学习打下了基础。
原来vue3能有这么多种性质,以及对vue3有了新的认识,期待后边的学习
这篇关于【备战春招】第8天 6-16 vue3用Proxy 实现响应式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-23【JS逆向百例】爱疯官网登录逆向分析
- 2024-12-21Vue3教程:新手入门到实践应用
- 2024-12-21VueRouter4教程:从入门到实践
- 2024-12-20Vue3项目实战:从入门到上手
- 2024-12-20Vue3项目实战:新手入门教程
- 2024-12-20VueRouter4项目实战:新手入门教程
- 2024-12-20如何实现JDBC和jsp的关系?-icode9专业技术文章分享
- 2024-12-20Vue项目中实现TagsView标签栏导航的简单教程
- 2024-12-20Vue3入门教程:从零开始搭建你的第一个Vue3项目
- 2024-12-20从零开始学习vueRouter4:基础教程