前端面试准备

135 阅读2分钟

问题1:Ajax Fetch Axios 的区别?

  • Ajax: Asynchronous Javascript and XML 是一种技术统称
  • Fetch: 一个具体的API
    • 浏览器原生API 用于网络请求
    • 和XMLHttpRequest一个级别
    • 语法简洁 支持Promise
  • Axios: 一个第三方库
    • 网络请求Library(Vue,Nodejs使用多)
    • 内部可用 XML Fetch 实现

*lib和API的区别
第三方库可用有很多个,API的数量比较少通常一两个

问题2: JS数据类型

  1. 新增的类型
  2. 原始和引用数据类型
  3. 存储位置不同
  4. 堆栈数据结构
  5. 堆栈操作系统

1.新增的类型

Symbol: 代表独一无二且不可变的数据类型,解决了可能出现的全局变量冲突的问题
BigInt: 数字类型的数据, 可用表示任意精度格式的整数, 使用BigInt可以安全的存储和操作大整数(超过Number表示的安全整数范围)

2.原始和引用数据类型

  1. 栈: 原始数据类型(Undefined, Null, Boolean, Number, String)
  2. 堆: 引用数据类型(对象, 数组和函数)

3. 存储位置不同

原始数据类型直接存储在栈(stack)中的简单数据段

  • 占据空间小
  • 大小固定
  • 频繁使用\

引用类型存储在堆(heap)中的对象

  • 占据空间大
  • 大小不固定
  • 存储在栈中影响程序运行的性能
  • 引用类型在栈中存储指针, 该指针指向堆中该实体的起始位置
  • 解释器寻找引用值时, 会首先检索栈中的地址, 再从从堆中获取实体

4. 堆栈数据结构

栈: 先进后出 堆: 优先队列, 按照优先级进行排序, 优先级可以按照大小规定

5. 堆栈操作系统

  1. 栈: 内存由编译器自动分配释放, 存放函数的参数值,局部变量的值等
  2. 堆: 内存一般由开发者分配释放, 开发者不释放则程序结束时可能由垃圾回收机制回收

3. React vs Vue

  1. 相同点
  • 支持 virtual DOM
  • 支持响应式和组件化的视图组件
  • 核心库 路由和状态管理分离
  • 支持JSX 移动端都支持原生渲染
  1. 不同点
  • 预编译
    • React 可以通过Prepack优化JS代码
    • Vue 可以静态分析template 构造AST树 通过PatchFlags标记节点变化类型
  • 渲染
    • React 通过 shouldComponentUpdate / setState, 使用 PureComponent等对比前后状态和属性, 手动决定是否渲染来优化
    • Vue 推荐模板语法, 自动追踪组件依赖, 精确渲染状态改变的组件
  • 状态管理工具
    • React 使用 react-dedux
    • Vue 使用 vuex