Vue3与Vue2对比及面试关键点解析
需积分: 0 201 浏览量
更新于2024-08-03
收藏 10KB MD 举报
"本文涵盖了2023年Vue.js面试中的关键知识点,包括Vue 3与Vue 2的差异、CSS选择器及其优先级、BFC(块级格式化上下文)的概念及触发条件,以及跨域解决方案和HTTP2与HTTP1的区别。"
Vue 3与Vue 2的区别:
1. **Diff算法的改进+TreeSharing优化**:Vue 3在更新虚拟DOM时采用了更高效的算法,减少了不必要的DOM操作,同时引入了TreeSharing,使得组件树的复用性更强,提高了性能。
2. **双向绑定使用ES6 Proxy**:Vue 2中使用`v-model`实现双向绑定,而在Vue 3中,它改为了使用ES6的Proxy对象,可以直接监听对象属性的变化,更加灵活和高效。
3. **原生支持TypeScript**:Vue 3原生支持TypeScript,提供了更好的类型检查和开发体验,提升了代码的可维护性。
4. **Composition API**:Vue 3引入了Composition API,允许开发者将逻辑组件化,提高代码的可重用性和组织性,降低了组件间的耦合度。
5. **移除`this`问题**:Vue 3中的setup函数不再需要`this`关键字来访问数据和方法,而是通过组合API直接使用,简化了代码结构。
CSS选择器及其优先级:
CSS选择器的优先级由四个数字组成,依次代表!important、内联样式、ID选择器和类/属性/伪类选择器、元素选择器/伪元素选择器的权重。权重总和越高,选择器的优先级越高。
1. `!important`:具有最高优先级,无论其他权重如何,都会被应用。
2. 内联样式:权重1000,直接在元素上设置的style属性。
3. ID选择器:权重100,如`#example`。
4. 类、属性、伪类选择器:权重10,如`.example`、`[type="text"]`、`:hover`。
5. 元素选择器、伪元素选择器:权重1,如`div`、`::before`。
6. 关系选择器、通配符选择器:权重0,如`>`、`*`。
BFC(块级格式化上下文):
1. BFC是一个独立的布局环境,其中的元素布局不受外部元素影响。
2. 触发BFC的条件包括根元素、浮动元素、绝对定位元素、内联块元素、表格单元格、表格标题、overflow不为visible的块元素、弹性盒以及display为flow-root或column-span: all的元素。
跨域解决方案:
1. **JSONP**:通过动态插入`<script>`标签,利用回调函数实现跨域数据请求。
2. **Nginx反向代理**:通过配置Nginx服务器,将前端请求转发至其他域名,从而解决跨域问题。
3. **postMessage**:在不同源的窗口间传递消息,实现跨域通信。
4. **document.domain**:如果主域相同,可以设置`document.domain`为相同的值,实现同源策略的跨子域。
5. **脚手架代理**:在开发环境下,前端构建工具如Vue CLI可以通过配置代理服务器绕过跨域限制。
HTTP2与HTTP1的区别:
1. **二进制分帧**:HTTP2使用二进制格式传输数据,相比HTTP1.x的文本格式更高效和健壮。
2. **多路复用**:HTTP2允许在一个TCP连接上并发处理多个请求,解决了HTTP1.x的阻塞问题,提高了页面加载速度。
3. **头部压缩**:HTTP2使用HPACK算法压缩请求和响应头,减少了网络传输的数据量。
4. **服务端推送**:HTTP2支持服务端主动推送资源给客户端,无需客户端发起请求,提前加载可能需要的内容。
2023-10-28 上传
2023-05-06 上传
2023-06-28 上传
2023-09-21 上传
2023-04-03 上传
2023-05-11 上传
2023-08-12 上传
2023-09-02 上传
2023-07-29 上传
ifHappyEveryDay@
- 粉丝: 3115
- 资源: 10
最新资源
- 深入浅出:自定义 Grunt 任务的实践指南
- 网络物理突变工具的多点路径规划实现与分析
- multifeed: 实现多作者间的超核心共享与同步技术
- C++商品交易系统实习项目详细要求
- macOS系统Python模块whl包安装教程
- 掌握fullstackJS:构建React框架与快速开发应用
- React-Purify: 实现React组件纯净方法的工具介绍
- deck.js:构建现代HTML演示的JavaScript库
- nunn:现代C++17实现的机器学习库开源项目
- Python安装包 Acquisition-4.12-cp35-cp35m-win_amd64.whl.zip 使用说明
- Amaranthus-tuberculatus基因组分析脚本集
- Ubuntu 12.04下Realtek RTL8821AE驱动的向后移植指南
- 掌握Jest环境下的最新jsdom功能
- CAGI Toolkit:开源Asterisk PBX的AGI应用开发
- MyDropDemo: 体验QGraphicsView的拖放功能
- 远程FPGA平台上的Quartus II17.1 LCD色块闪烁现象解析