🔥每日一篇——23秋招VUE面经(9)

🔥每日一篇------23秋招VUE面经(9)

⭐说说$set

$set可以让我们通过key来设置数组或对象上的属性,并确保其可以被转换成响应式属性。

我们之前说过了响应式原理,如果还不清楚的请先去了解vue2响应式:小何的世界 (theluckyone.top)

先说 <math xmlns="http://www.w3.org/1998/Math/MathML"> s e t ,用法: ' v m . set,用法:`vm. </math>set,用法:'vm.set(target, key, value)`

对于数组: 当target为数组时,内部会先判断key与数组长度length的大小

  • 如果key大于数组长度,那么就要先修改数组length = key,然后通过在拦截器中重写过的splice方法将value插入到对应位置,这样在splice方法中,数组拦截器就会侦测到target的变化,并自动帮我们把这个新增的val转换成响应式的。
  • 如果key小于数组长度,那么这个key已经被侦测了变化,直接target[key] = val修改就好了

对于对象:

  • 首先先要获取对象上的__ob__属性,也就是Observer实例,在上面的文章中我们介绍过这个对象代表着对象已经被响应式监听
  • 再判断该对象是不是Vue实例(通过target._isVue来判断)或Vue实例的根数据对象(通过ob.vmCount来判断),如果是则不予处理
  • 如果不是响应式数据的情况(没有__ob__属性),就直接target.key = val,不需要多余处理
  • 最后处理响应式数据的情况,这种情况我们需要跟踪新增属性的变化,使用defineReactive为其定义getter/setter,最后执行target对应的依赖容器中notify方法触发变化通知

⭐说说$delete

$delete用于删除响应式数据中的某个属性,原理很简单,分数组和对象:

  • 删除对象上的属性:获取target上的__ob__实例,通过delete关键字删除后,调用__ob__.dep.notify()来通知watcher数据发生了变化
  • 删除数组上的值:使用splice将key指定的索引位置的元素删除即可,数组拦截器会自动向依赖发送通知

PS:与 <math xmlns="http://www.w3.org/1998/Math/MathML"> s e t 一样, set一样, </math>set一样,delete同样不可以在Vue实例或Vue实例的根数据对象上使用

相关推荐
qq_381338505 分钟前
React 18+ 并发特性深度解析:从原理到企业级性能优化实战
前端·react.js·性能优化
indexsunny5 分钟前
互联网大厂Java面试实录:Spring Boot到微服务的深入探讨
java·spring boot·微服务·面试·eureka·kafka·jwt
一只小阿乐8 分钟前
react中的zustand 模块化
前端·javascript·react.js·react状态管理·zustand
劳埃德福杰15 分钟前
Windows系统卸载Edge浏览器
前端·windows·edge
hzxpaipai15 分钟前
外贸网站制作:为何派迪科技做的网站性能与打开速度如此不错?
开发语言·前端·网络·科技·安全
久爱@勿忘16 分钟前
uniapp H5 图片压缩并且转blob
前端·javascript·uni-app
Dashingl16 分钟前
uni-app 页面传值 报错:TypeError: $t.setAttribute is not a function
前端·javascript·uni-app
weixin1997010801616 分钟前
《澎拜网商品详情页前端性能优化实战》
前端·性能优化
甄心爱学习18 分钟前
【项目实训】法律文书智能摘要系统2
前端·javascript·vue.js
m0_7381207220 分钟前
渗透基础知识ctfshow——Web应用安全与防护(第二章)
服务器·前端·安全·web安全·php