当前栏目
Vue前端面试2021-016
1、简述用过Vue指令,并阐述这些指令的含义
v-text/v-html 用于渲染数据 v-once 用于一次性加载数据 v-show/v-if 用于条件判断渲染数据 v-if /v-for 用于程序流程控制 v-bind 动态操作属性 v-on 绑定操作事件 v-model 表单数据绑定
2、Vue实例中的data为什么是一个对象,组件中的data为什么是一个返回对象的函数?
Vue开发的应用一般都是单页面应用,通常情况下只有唯一一个Vue实例,所以实例中的数据可以在当前项目中共享,所以Vue实例中的data是一个对象 Vue组件的出现,是为了组件中的视图和数据可以复用,被复用的组件在不同的复用位置可能在操作不同的数据,所以每个组件的data数据必须互相独立,所以组件中的data是一个函数,函数内部返回一个只能让当前组件使用的对象数据
3、Vue实例中,数组通过push()/pop()函数的数据更新可以完成数据双向渲染,为什么通过[索引]的形式增加数据不会引起数据双向渲染?应该怎么解决?
Vue中的数据双向绑定底层是通过数据劫持实现的,数据劫持中如果对目标对象数据进行更新操作就会自动调用set()函数完成数据赋值和视图的更新;但是如果数据是查询操作的时候会自动调用get()函数完成数据获取; 数组通过push()/pop()函数是一种显式的数据更新操作,所以会自动完成数据同步渲染;通过[索引]的形式本质上获取数据的操作,所以不会调用set()函数完成数据同步渲染 如果必须通过索引的形式完成数据的更新并且要同步渲染,Vue2.x版本中可以通过Vue提供的vm.$set()或者Vue.set()函数完成数据双向同步
4、讲述Vue中都有哪些生命周期?
- 创建阶段 beforeCreate: 实例创建前 created:实例创建后 beforeMount: 虚拟DOM渲染前 mounted: 虚拟DOM渲染之后
- 运行阶段 beforeUpdate: 数据更新前 updated: 数据更新后
- 销毁阶段 beforeDestory: 实例销毁前 destroyed: 实例销毁后
- 缓存组件生命周期 activated:组件激活 deactivated:组件失活
5、v-for指令循环中为什么要使用key属性?
v-for指令主要用于循环展示户数,通过key属性可以将视图中的数据进行唯一性渲染,保障数据的正确渲染展示
6、简述组件的缓存如何实现?实现缓存的好处是什么?
组件的缓存通过<keep-alive>进行包含,组件在切换过程中就不会频繁的创建和销毁,在一定程度上节省了系统资源同时提高了运行效率; 被缓存的组件中如果要执行数据更新,可以通过缓存组件的activated和deactivated生命周期完成
相关文章
- 前端面试 【JavaScript】— typeof 是否能正确判断类型?
- 前端面试 【JavaScript】— instanceof 能否判断基本数据类型?
- 前端面试 【JavaScript】— 能不能手动实现一下 instanceof 的功能?
- 前端面试 【JavaScript】— Object.is和=== 有什么区别?
- 前端面试 【JavaScript】— JS中类型转换有哪几种?
- 前端面试 【JavaScript】— == 和 ===有什么区别?
- 前端面试 【JavaScript】— 对象转原始类型是根据什么流程运行的?
- JavaScript 的 parseInt() 函数
- javascript实现两个数字进行组合
- JS监听键盘按键
- 大前端开发中的路由管理之五:Flutter篇
- Javascript的DOM操作
- 在Vue项目中使用WebSocket技术
- 新手向:前端程序员必学基本技能——调试JS代码
- React 毁了 Web 开发!
- 「JS 逆向百例」cnki 学术翻译 AES 加密分析
- 商标注册域名后缀用什么?商标和域名有哪些区别?
- 网站建设流程是怎样的?需要看重哪些细节?
- 网站域名商标注册流程是什么?网站域名商标有什么用?
- 如何建设一个实用性强的网站 网站上线后如何运营