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

商城网站有哪些功能网站开发中常见的安全漏洞

商城网站有哪些功能,网站开发中常见的安全漏洞,找项目去哪个平台,报名网站开发多钱前言 Vue的响应式系统是基于数据劫持加发布订阅者模式实现的#xff0c;数据响应式就是建立响应式数据与依赖的关系 (调用了响应式数据的操作之间的关系) vue2使用Object.defineProperty进行数据拦截,而Vue3使用Proxy进行数据拦截是es6中新加的api,比Object.defineProperty解…前言 Vue的响应式系统是基于数据劫持加发布订阅者模式实现的数据响应式就是建立响应式数据与依赖的关系 (调用了响应式数据的操作之间的关系) vue2使用Object.defineProperty进行数据拦截,而Vue3使用Proxy进行数据拦截是es6中新加的api,比Object.defineProperty解除了很多限制,性能更加优秀 Proxy 利用Proxy代理对象进行数据劫持 Proxy的基本使用 const testobj { count: 0 }; const proxy new Proxy(testobj, { get(target, key) { console.log(触发get) return Reflect.get(target, key) }, set(target, key, value) { console.log(触发set) return Reflect.set(target, key, value) }, }); console.log(proxy.count) // 触发get proxy.count 1 // 触发set在Vue3中,会通过拦截 get 和 set 操作来实现依赖收集和触发依赖。当我们访问响应式对象的属性时会触发 get 操作此时 Vue3 会将当前的依赖(effect)项添加到依赖列表中当我们修改响应式对象的属性时会触发 set 操作此时 Vue3 会遍历依赖列表调用每个依赖项的更新函数对视图进行更新。 所以先定义依赖类,需要有数据结构来存储依赖, effect副作用函数,这个函数在响应式数据发生变化时会被自动触发从而执行相关的操作。可以完善effect副作用函数来控制响应式数据 // 定义的依赖类 class ReactiveEffect{private _fn_;constructor(fn){this._fn_ fn}run(){activeEffect thisthis._fn_()} } let activeEffect; //effect副函数 //传入一个直接执行的函数 function effect(fn){const _effect new ReactiveEffect(fn)_effect.run() }当访问响应式对象的属性时会添加一个依赖项并将当前的 activeEffect 类保存到一个 effects 集合中而 effects 集合则以 target 对象为键以保存在该对象上的依赖项的列表为值。这也就是track收集依赖。 为什么用WeakMap做数据结构呢weakMap重要在它的弱字,WeakMap 中的键是弱引用的,意味着当键不再被其他地方引用时垃圾回收器可以自动清除这些键对应的值。可以优化性能 const targetMap new WeakMap()//收集依赖function track(target, key) {let depsMap targetMap.get(target)if (!depsMap) {depsMap new Map()targetMap.set(target, depsMap)}let dep depsMap.get(key);if (!dep) {dep new Set()depsMap.set(key, dep)}dep.add(activeEffect) } //简化下代码 function track(target, key) {const depsMap targetMap.get(target) || new Map();targetMap.set(target, depsMap);const dep depsMap.get(key) || new Set();depsMap.set(key, dep);dep.add(activeEffect);}trigger触发依赖是当响应式对象属性修改时,系统会遍历依赖项列表逐个执行保存在其中的 activeEffect 类代表了对应依赖项的操作。 function trigger(target,key) {const depsMap targetMap.get(target)const deps depsMap.get(key)for(const effect of deps){effect.run()} }这下可以根据上述实现一波reactive实现 let activeEffect; function isObject(raw) { if (raw null) { return false } else if (typeof raw object || typeof raw function) { return true } else { return false } } function reactive(raw){if (!isObject(raw)) {console.warn(${raw} not object)return raw}return new Proxy(raw,{get(target, key) {const res Reflect.get(target, key)track(target,key)return res},set(target,key,value){const res Reflect.set(target, key, value)trigger(target,key,value)return res //这是个布尔值} }) } //实现依赖类和effect函数 class ReactiveEffect{_fn_;constructor(fn){this._fn_ fn}run(){activeEffect this;this._fn_();}}function effect(fn){const _effect new ReactiveEffect(fn)_effect.run()} const targetMap new WeakMap()//收集依赖 function track(target, key) {let depsMap targetMap.get(target)if (!depsMap) {depsMap new Map()targetMap.set(target, depsMap)}let dep depsMap.get(key);if (!dep) {dep new Set()depsMap.set(key, dep)}dep.add(activeEffect)}//触发依赖 function trigger(target,key) {const depsMap targetMap.get(target)const deps depsMap.get(key)for(const effect of deps){effect.run() } }
http://www.zqtcl.cn/news/951548/

相关文章:

  • 北京 网站建设 知乎上海公司买新能源车
  • 成都微网站wordpress 购买
  • 网站开发一般要用到哪些软件软件开发工程师机构
  • dj网站开发建设网站备案 换空间
  • 网站建设哪家最好网站开发怎么报价
  • app 微商城网站建设网站建设流程百科
  • 网站短期培训学校小说网站怎么建设的
  • 最简单的免费网站制作模板电子商务 网站系统
  • 网站域名备案授权书网站建设长春
  • 网站维护主要从哪几个方面做seo营销的概念
  • 北京网站建设营销网站策划案4500
  • 网站建设售后培训wordpress 过滤html
  • 湖北森泰建设集团有限公司网站国外产品设计网站推荐
  • 网站建设与代运营产品介绍排版网页设计教程
  • 音乐网站排名搜索引擎网络推广方法
  • asp.net 企业网站昆明高端seo怎么做
  • 图书馆网站建设需求方案企业网站背景图片
  • 网站app的作用做家教网站资质
  • 资源网站搭建北京app网站建设
  • 天津做宠物饲料的网站wordpress添加注册页面模板
  • 网站建设公司石家庄php网站开发报价
  • 国外免费网站服务器链接cpa自己做网站
  • 手机网站的优缺点2024中国企业500强
  • 黄河道网站建设网站设计标语
  • 企业网站建设范文wordpress 5.1
  • 网站 河北 备案 慢设计一个营销方案
  • 网站建设培训合肥品牌设计案例
  • 建网站注册免费云服务器
  • 可以做网站的公司有哪些聊天软件开发厂家有哪些
  • 正规网站建设公司一般要多少钱婚纱网站有哪些