最近面试 web 前端开发工程师老是问 vue 知识,所以在这里整理了一下 VueJs 面试题
一、对于 Vue 了解多少,什么是 Vuex,VueRouter
vuex 为状态管理,它集中存储管理应用的所有组件的状态,可以理解成一个全局仓库
VueRouter 是路由(spa)单页面应用的方式
二、为什么通过 vuex 的 motution 修改 state 中的参数就不会报错,而直接更改 state 中的参数就会报错
vue 2 取消冒泡全部 $emit 用 vuex 定义全局 state 组件修改 state 父组件访问 state 值
三、vue 中的 v -show 和 v -if 是做什么用的,两者区别是什么
v-if 是“真正的”条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件不太可能改变,则使用 v-if 较好。
四、vue 中父组件如何触发子组件的函数,子组件如何触发父组件的函数
父组件中获取子组件函数:$children、$refs
子组件中获取父组件函数:$on
五、vue-router 有哪几种导航钩子
有多种方式可以在路由导航发生时执行钩子:1. 全局钩子
2. 单个路由独享的
3. 组件级的
六、vue 页面的生命周期?(2+)
1. beforeCreate
2. created
3. beforeMount
4. mounted
5. beforeUpdate
6. updated
7. activated
8. deactivated
9. beforeDestroy
10.destroyed
七、mvvm 框架是什么? 它和其他框架 (jquery) 的区别是什么?哪些场景适合?
一个 model+view+viewModel 框架,数据模型 model,viewModel 连接两个 区别:vue 数据驱动,通过数据来显示视图层而不是节点操作。场景:数据操作比较多的场景,更加便捷
八、自定义指令(v-check、v-focus)的方法有哪些? 它有哪些钩子函数?还有哪些钩子函数参数?
全局定义指令:在 vue 对象的 directive 方法里面有两个参数,一个是指令名称,另外一个是函数。组件内定义指令:directives 钩子函数:bind(绑定事件触发)、inserted(节点插入的时候触发)、update(组件内相关更新)钩子函数参数:el、binding
九、active-class 是哪个组件的属性?嵌套路由怎么定义?
vue-router 模块的 router-link 组件。
十、怎么定义 vue-router 的动态路由?怎么获取传过来的动态参数?
在 router 目录下的 index.js 文件中,对 path 属性加上 /:id。使用 router 对象的 params.id
十一、v-model 是什么?怎么使用?vue 中标签怎么绑定事件?
可以实现双向绑定,指令(v-class、v-for、v-if、v-show、v-on)。
vue 的 model 层的 data 属性。绑定事件:<input @click=doLog() />
十二、axios 是什么?怎么使用?描述使用它实现登录功能的流程?
请求后台资源的模块。npm install axios - S 装好,然后发送的是跨域,需在配置文件中 config/index.js 进行设置。后台如果是 Tp5 则定义一个资源路由。js 中使用 import 进来,然后.get 或.post。返回在.then 函数中如果成功,失败则是在.catch 函数中
十三、Vue 的双向数据绑定原理是什么?
vue.js 是采用数据劫持结合发布者 - 订阅者模式的方式,通过 Object.defineProperty()来劫持各个属性的 setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。具体步骤:第一步:需要 observe 的数据对象进行递归遍历,包括子属性对象的属性,都加上 setter 和 getter
这样的话,给这个对象的某个值赋值,就会触发 setter,那么就能监听到了数据变化
第二步:compile 解析模板指令,将模板中的变量替换成数据,然后初始化渲染页面视图,并将每个指令对应的节点绑定更新函数,添加监听数据的订阅者,一旦数据有变动,收到通知,更新视图
第三步:Watcher 订阅者是 Observer 和 Compile 之间通信的桥梁,主要做的事情是:
1、在自身实例化时往属性订阅器 (dep) 里面添加自己
2、自身必须有一个 update()方法
3、待属性变动 dep.notice()通知时,能调用自身的 update()方法,并触发 Compile 中绑定的回调,则功成身退。第四步:MVVM 作为数据绑定的入口,整合 Observer、Compile 和 Watcher 三者,通过 Observer 来监听自己的 model 数据变化,通过 Compile 来解析编译模板指令,最终利用 Watcher 搭起 Observer 和 Compile 之间的通信桥梁,达到数据变化 -> 视图更新;视图交互变化(input) -> 数据 model 变更的双向绑定效果。
十四、请详细说下你对 vue 生命周期的理解?
总共分为 8 个阶段创建前 / 后,载入前 / 后,更新前 / 后,销毁前 / 后。创建前 / 后:在 beforeCreated 阶段,vue 实例的挂载元素 $el 和数据对象 data 都为 undefined,还未初始化。在 created 阶段,vue 实例的数据对象 data 有了,$el 还没有。载入前 / 后:在 beforeMount 阶段,vue 实例的 $el 和 data 都初始化了,但还是挂载之前为虚拟的 dom 节点,data.message 还未替换。在 mounted 阶段,vue 实例挂载完成,data.message 成功渲染。更新前 / 后:当 data 变化时,会触发 beforeUpdate 和 updated 方法。销毁前 / 后:在执行 destroy 方法后,对 data 的改变不会再触发周期函数,说明此时 vue 实例已经解除了事件监听以及和 dom 的绑定,但是 dom 结构依然存在
请说下封装 vue 组件的过程?首先,组件可以提升整个项目的开发效率。能够把页面抽象成多个相对独立的模块,解决了我们传统项目开发:效率低、难维护、复用性等问题。
然后,使用 Vue.extend 方法创建一个组件,然后使用 Vue.component 方法注册组件。子组件需要数据,可以在 props 中接受定义。而子组件修改好数据后,想把数据传递给父组件。可以采用 emit 方法。
十五、vue-loader 是什么?使用它的用途有哪些?
解析.vue 文件的一个加载器,跟 template/js/style 转换成 js 模块。
用途:js 可以写 es6、style 样式可以 scss 或 less、template 可以加 jade 等
十六、vuex 有哪几种属性?
有五种,分别是 State、Getter、Mutation、Action、Module