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

前端面试真题集合(一)

一、Vue的响应式原理
Vue的响应式系统通过数据劫持和依赖追踪实现,核心流程如下:

  1. 数据劫持
    • Vue 2.x:使用Object.defineProperty递归遍历数据对象,将属性转换为getter/setter,拦截属性的读取和修改操作。

    • Vue 3.x:改用Proxy代理对象,支持动态属性添加和数组变化监听,性能更优且覆盖场景更广。

  2. 依赖收集与触发
    • 依赖收集(Getter触发):当组件渲染时访问数据属性,触发getter,将当前组件对应的Watcher存入Dep(依赖收集器)。

    • 更新触发(Setter触发):当数据被修改时,触发setterDep通知所有关联的Watcher执行视图更新或副作用函数。

  3. 虚拟DOM与批量更新
    数据变化后生成新的虚拟DOM树,通过Diff算法对比新旧树差异,仅更新必要的真实DOM节点,并通过异步队列(如nextTick)批量处理更新任务,减少重排重绘。


二、gettersetter的触发时机
• Getter触发:

• 当读取响应式数据属性时触发(如模板渲染、计算属性计算、手动读取值)。

• 示例:{{ user.name }}渲染时,会触发user.namegetter

• Setter触发:

• 当修改响应式数据属性时触发(如用户输入、异步请求结果赋值)。

• 示例:this.user.name = 'Alice'会触发setter,通知所有依赖视图更新。


三、refreactive的区别及.value的作用

  1. 设计目的
    ref:用于基本数据类型(如numberstring)和对象引用,通过Object.definePropertyRef对象包裹,确保响应性。

    reactive:专用于对象/数组,基于Proxy实现深层次响应式代理。

  2. .value的必要性
    ref将基本类型包装为{ value: ... }对象,访问时必须通过.value获取内部值,因为基本类型无法直接被Proxy代理。

    reactive直接代理对象,可直接访问属性(如state.count),无需.value

  3. 基本类型与引用类型的核心差异
    • 存储方式:基本类型值存储在栈内存,引用类型值存储在堆内存,变量存储的是引用地址。

    • 可变性:基本类型不可变(如let a=1; a=2是重新赋值),引用类型属性可变(如obj.name='Bob')。


四、Vue的Diff算法

  1. 核心策略
    • 同层比较:仅比较同级节点,避免跨层级对比(复杂度从O(n³)降至O(n))。

    • 双端指针:从新旧子节点的头部和尾部同时向中间遍历,优先处理相同节点。

    • Key优化:通过唯一key标识节点,减少不必要的DOM操作(如列表重排)。

  2. 具体步骤
    • 对比节点类型/标

相关文章:

  • QT聊天项目DAY06
  • 【开发心得】筑梦上海:项目风云录(16)
  • Workflow轻量级工作流引擎实现
  • C++高并发内存池ConcurrenMemoPool
  • mysql8.0.17以下驱动导致mybatis blob映射String乱码问题分析与解决
  • gis系统中如何提高shp大文件加载效率
  • B端可视化像企业数据的透视镜,看清关键信息
  • C 语 言 --- 指 针 3
  • jangow靶机笔记(Vulnhub)
  • 深度学习数据预处理:Dataset类的全面解析与实战指南
  • 在Windows创建虚拟环境如何在pycharm中配置使用
  • 【滑动窗口】最⼤连续 1 的个数 III(medium)
  • MLA(多头潜在注意力)原理概述
  • leetcode 2563. 统计公平数对的数目 中等
  • turtle库绘制进阶图形
  • 【Canvas与旗帜】标准英国米字旗
  • 深入解析进程与线程:区别、联系及Java实现
  • 【大模型框架】LLAMA-FACTORY使用总结
  • 【工控基础】工业相机设置中,增益和数字增益有什么区别?
  • 网络爬虫和前端相关知识
  • 鲜花妆上海,花香荟申城!2025上海国际花展开幕,龚正出席并启动花展
  • 复旦大学空间互联网研究院成立,将聚焦卫星互联网等领域
  • 皓元医药郑保富:共创、共赢、共享,跨域协作推动生物医药创新
  • 上海地铁5G信号全覆盖后网速如何?记者亲测有这些发现
  • 北京:义务教育阶段入学将积极为多孩家庭长幼随学创造条件
  • 2025年青年普法志愿者法治文化基层行活动启动