当前位置: 首页 > wzjs >正文

百度用户服务中心入口韶山seo快速排名

百度用户服务中心入口,韶山seo快速排名,wordpress转中文版,美国主机教育网站建设一、什么是响应式? 想象一个 Excel 表格:当单元格 A1 的值变化时,依赖 A1 的公式(如 SUM(A1, B1))会自动重新计算。Vue3 的响应式系统正是实现了这种“自动更新”的能力——当数据变化时,依赖它的视图或计…

一、什么是响应式?

想象一个 Excel 表格:当单元格 A1 的值变化时,依赖 A1 的公式(如 SUM(A1, B1))会自动重新计算。Vue3 的响应式系统正是实现了这种“自动更新”的能力——当数据变化时,依赖它的视图或计算属性会自动更新。


二、Vue3 响应式的核心实现

1. 底层工具:Proxy 与 Reflect

Vue3 使用 Proxy 代替 Vue2 的 Object.defineProperty,因为它能拦截对象的所有操作(如属性读取、新增、删除等),而无需预先定义属性149。

const obj = { a: 1 };
const proxy = new Proxy(obj, {get(target, key) {console.log('读取属性:', key);return Reflect.get(target, key); // 使用 Reflect 保证 this 指向正确},set(target, key, value) {console.log('设置属性:', key, value);return Reflect.set(target, key, value);}
});

2. 响应式对象:reactive()

reactive() 函数将普通对象转为响应式对象,内部通过 Proxy 实现:

function reactive(target) {return new Proxy(target, {get(target, key) {track(target, key); // 收集依赖const res = Reflect.get(target, key);// 递归处理嵌套对象return isObject(res) ? reactive(res) : res;},set(target, key, value) {Reflect.set(target, key, value);trigger(target, key); // 触发更新return true;}});
}

关键点

  • 深层响应:嵌套对象会被递归代理1。

  • 避免重复代理:通过 WeakMap 缓存已代理对象10。


3. 副作用函数:effect()

副作用函数(如渲染函数)会在依赖的响应式数据变化时重新执行:

let activeEffect;
function effect(fn) {const _effect = () => {activeEffect = _effect; // 标记当前正在执行的副作用函数fn();activeEffect = null;};_effect(); // 立即执行一次以收集依赖
}// 示例
effect(() => {console.log('数据变化了:', state.a);
});

4. 依赖收集与触发更新

(1) 数据结构
  • targetMapWeakMap,键为响应式对象,值为 depsMap

  • depsMapMap,键为对象的属性名,值为 dep(依赖集合)。

  • depSet,存储所有依赖该属性的副作用函数210。

(2) track():收集依赖

在读取属性时,将当前副作用函数加入依赖集合:

const targetMap = new WeakMap();
function track(target, key) {if (!activeEffect) return;let depsMap = targetMap.get(target);if (!depsMap) targetMap.set(target, (depsMap = new Map()));let dep = depsMap.get(key);if (!dep) depsMap.set(key, (dep = new Set()));dep.add(activeEffect);
}
(3) trigger():触发更新

在设置属性时,执行所有依赖该属性的副作用函数:

function trigger(target, key) {const depsMap = targetMap.get(target);if (!depsMap) return;const dep = depsMap.get(key);dep && dep.forEach(effect => effect());
}

三、Vue3 对比 Vue2 的优势49

特性Vue2 (Object.defineProperty)Vue3 (Proxy)
检测新增属性需手动调用 Vue.set()自动支持
数组索引修改需重写数组方法直接通过下标修改即可
嵌套对象处理需递归初始化按需代理(惰性处理)
性能初始化时递归遍历所有属性动态代理,按需收集依赖

四、实战示例

1. 基础响应式

const state = reactive({ count: 0 });
effect(() => {console.log('count 值变为:', state.count);
});
state.count++; // 触发控制台输出

2. 嵌套对象

const obj = reactive({ foo: { bar: 1 } 
});
effect(() => {console.log(obj.foo.bar); // 深层属性仍可响应
});
obj.foo.bar = 2; // 触发更新

五、总结

Vue3 的响应式系统通过 Proxy 拦截对象操作,结合 依赖收集(track) 与 触发更新(trigger) 实现了高效的数据绑定。相比 Vue2,它解决了动态属性、数组操作等痛点,且性能更优。理解其核心原理有助于更好地使用 Vue3 开发复杂应用。

想深入学习可参考:Vue3 响应式官方文档

http://www.dtcms.com/wzjs/73716.html

相关文章:

  • 建设网站去工信部备案需要什么资料关键字搜索
  • 企业网站搭建价格免费的黄冈网站有哪些
  • 做一名优秀网站设计师计划考研培训
  • 深圳宝安医院的网站建设优化网站视频
  • 外贸网站制作需求域名检测查询
  • 如何建设个人的网站知名的建站公司
  • 中国建设工程协会网站前端seo怎么优化
  • 免费网站生成湘潭关键词优化服务
  • 做货代的可以在哪些网站打广告哪个平台可以随便发广告
  • 无锡网站建设要多少钱网店如何推广自己的产品
  • 网站关键词百度自然排名优化国外搜索引擎排名
  • 南阳专业做网站公司uc浏览器网页版入口
  • 网页制作基础任务教程慕课版答案泉州seo报价
  • 如何在国外网站做翻译兼职北京建站工作室
  • 设计素材网站蜂环球网广东疫情最新消息
  • 化妆品购物网站排名游戏推广员拉人犯法吗
  • 扁平化购物网站模板东莞推广平台有哪些
  • 要想提高网站排名应该如何做网站收录一般多久
  • 西安高端网站建设首选百度竞价是什么意思?
  • 找人搭建网站多少钱网站seo去哪个网站找好
  • 获取网站域名宁波网络推广产品服务
  • 湖北省建设工程造价管理协会网站互联网行业都有哪些工作
  • 网上买吃的网站做代理营销策略ppt
  • 网站里的个人中心下拉列表怎么做搜索引擎优化的含义和目标
  • 电子商务网站开发基本流程图海南百度推广中心
  • 网站阵地建设百度指数分析
  • 怎样用vps做网站怎么搜索关键词
  • 北京网站优化步网络营销环境分析
  • 企业建网站作用十大禁止安装应用入口
  • 长宁区网站建设设计话色网站建设