前端每日一题(10.18题目+10.17答案)

人生不止有技术

共 861字,需浏览 2分钟

 · 2022-10-24


前端猎手
 链接每一位开发者,让编程更有趣儿!
关注


哈喽,大家好

我是法医


快来和法医一起看看

今天的前端每日一题吧


10月18日~面试题:


10月17日~参考答案:


说一下在 Vue2.x 中如何检测数组的变化?

Vue2.x 中实现检测数组变化的方法,是将数组的常用方法进行了重写。Vue 将 data 中的数组进行了原型链重写,指向了自己定义的数组原型方法。这样当调用数组 api 时,可以通知依赖更新。如果数组中包含着引用类型,会对数组中的引用类型再次递归遍历进行监控。这样就实现了监测数组变化。

流程:

  1. 初始化传入 data 数据执行 initData
  2. 将数据进行观测 new Observer
  3. 将数组原型方法指向重写的原型
  4. 深度观察数组中的引用类型

有两种情况无法检测到数组的变化。

  • 当利用索引直接设置一个数组项时,例如 vm.items[indexOfItem] = newValue
  • 当修改数组的长度时,例如 vm.items.length = newLength

不过这两种场景都有对应的解决方案。

  • 利用索引设置数组项的替代方案
//使用该方法进行更新视图
vm.$set,Vue.set的一个别名
vm.$set(vm.items, indexOfItem, newValue)
  • 修改数组的长度的替代方案
//使用该方法进行更新视图
Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)


每天都会有一道面试题,大家的积极参与和讨论,是我继续下去的动力,希望大家踊跃互动,共同进步!保持学习,每天进步一点点!


大家可以将自己的想法在评论区留言,答案我会在明天每日一题中公布!



RECOMMEND


推荐阅读

   

我的年中总结:生活可能就是这样,看似平淡,也始终向前

坚持的最高境界——善护念

一入“远程”终不悔,有人欢喜有人愁

程序员的快乐到底是什么?

程序猿终身学习有必要吗?这篇文章就是最好的答案

2022程序员跳槽不完全指南


浏览 8
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报