vue面试题 今天药忘吃喽~ 2023-01-16 14:26 59阅读 0赞 ## vuejs 基础必备 ## **1、active-class 是哪个组件的属性?嵌套路由怎么定义** * active-class 是 vue-router 模块的 router-link 组件的属性 * 使用 children 定义嵌套路由 **2、怎么定义 vue-router 的动态路由? 怎么获取传过来的值** 在 router 目录下的 index.js 文件中,对 path 属性加上 /:id。 使用 router 对象的 params.id 获取 **3、vue-router 有哪几种导航钩子?** 三种, (1)、全局导航钩子 router.beforeEach(to, from, next), router.beforeResolve(to, from, next), router.afterEach(to, from ,next) (2)、组件内钩子 beforeRouteEnter, beforeRouteUpdate, beforeRouteLeave (3)、单独路由独享组件 beforeEnter **4、v-model 是什么?怎么使用? vue中标签怎么绑定事件** v-model 可以实现双向绑定, 绑定事件:<input @click="rdhub.cn" /> **5、axios 是什么?怎么使用?描述使用它实现登录功能的流程** axios 是请求后台资源的模块。 npm i axios -S 如果发送的是跨域请求,需在配置文件中 config/index.js 进行配置 **6、vuex 是什么?怎么使用?哪种功能场景使用它** vuex 是专门为 vue 开发的数据状态管理模式。组件之间数据状态共享 使用场景:音乐播放、登录状态、购物车 // 新建 store.js import vue from 'vue' import vuex form 'vuex' vue.use(vuex) export default new vuex.store({ //...rdhub.cn }) //main.js import store from './store' ... **7、mvvm 框架是什么?它和其他框架(jquery) 的区别是什么?哪些场景适合** mvvm 是 model + view + viewmodel 框架,通过 viewmodel 连接数据模型model 和 view 区别:vue 是数据驱动,通过数据来显示视图层而不是节点操用 场景:数据操作比较多的场景,更加快捷 **8、自定义指令(v-check, v-focus) 的方法有哪些? 它有哪些钩子函数? 还有哪些钩子函数参数** 全局定义指令:在 vue 对象的 directive 方法里面有两个参数, 一个是指令名称, 另一个是函数。 组件内定义指令:directives 钩子函数: bind(绑定事件出发)、inserted(节点插入时候触发)、update(组件内相关更新) 钩子函数参数: el、binding **9、说出至少 4 种 vue 当中的指令和它的用法** v-if(判断是否隐藏)、v-for(把数据遍历出来)、v-bind(绑定属性)、v-model(实现双向绑定) **10、vue-router 是什么?它有哪些组件** vue-router 是 vue 的路由插件, 组件:router-link router-view **11、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变更的双向绑定效果。 **12、请详细说下你对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结构依然存在 ## vuex 面试题 ## **1、有哪几种属性** 有 5 种,分别是 state、getter、mutation、action、module **2、vuex 的 store 特性是什么** (1) vuex 就是一个仓库,仓库里放了很多对象。其中 state 就是数据源存放地,对应于一般 vue 对象里面的 data (2) state 里面存放的数据是响应式的,vue 组件从 store 读取数据,若是 store 中的数据发生改变,依赖这相数据的组件也会发生更新 (3) 它通过 mapState 把全局的 state 和 getters 映射到当前组件的 computed 计算属性 **3、 vuex 的 getter 特性是什么** (1) getter 可以对 state 进行计算操作,它就是 store 的计算属性 (2) 虽然在组件内也可以做计算属性,但是 getters 可以在多给件之间复用 (3) 如果一个状态只在一个组件内使用,是可以不用 getters **4、vuex 的 mutation 特性是什么** action 类似于 muation, 不同在于:action 提交的是 mutation,而不是直接变更状态 action 可以包含任意异步操作 **5、vue 中 ajax 请求代码应该写在组件的methods中还是vuex 的action中** 如果请求来的数据不是要被其他组件公用,仅仅在请求的组件内使用,就不需要放入 vuex 的 state 里 如果被其他地方复用,请将请求放入 action 里,方便复用,并包装成 promise 返回 **5、不用 vuex 会带来什么问题** 可维护性会下降,你要修改数据,你得维护3个地方 可读性下降,因为一个组件里的数据,你根本就看不出来是从哪里来的 增加耦合,大量的上传派发,会让耦合性大大的增加,本来Vue用Component就是为了减少耦合,现在这么用,和组件化的初衷相背 ## 生命周期面试题 ## **1、什么是 vue 生命周期** vue 实例从创建到销毁的过程就是生命周期。 也就是从开始创建、初始化数据、编译模板、挂在 dom -> 渲染、更新 -> 渲染、写在等一系列过程 **2、vue生命周期的作用是什么** 生命周期中有多个事件钩子,让我们在控制整个 vue 实例的过程时更容易形成好的逻辑 **3、vue生命周期总共有几个阶段** 8个阶段:创建前/后、载入前/后、更新前/后、销毁前/后 **4、第一次页面加载会触发哪几个钩子** 第一次加载会触发 beforeCreate、created、beforeMount、mounted **5、DOM 渲染在哪个周期中就已经完成** mounted **6、简述每个周期具体适合哪些场景** 生命周期钩子的一些使用方法: beforecreate : 可以在这加个loading事件,在加载实例时触发 created : 初始化完成时的事件写在这里,如在这结束loading事件,异步请求也适宜在这里调用 mounted : 挂载元素,获取到DOM节点 updated : 如果对数据统一处理,在这里写上相应函数 beforeDestroy : 可以做一个确认停止事件的确认框 nextTick : 更新数据后立即操作dom # vue 必知面试题 # ## css 相关 ## **1 如何让CSS只在当前组件中起作用?** 在当前组件的style中加入scoped:`<style scoped>`,scoped 有限制在某范围的含义,如果不设置,容易引起样式错乱! 2 vue项目如何适配移动端? 一般会引入淘宝移动端布局库amfe-flexible,不过由于viewport单位得到众多浏览器的兼容,该库维护团队建议使用viewport来替代此方案。但使用viewport也需要解决兼容问题。 ## vue 核心库 ## 3 v-if和v-show的异同? * v-if指令是直接销毁和重建DOM达到让元素显示和隐藏的效果 * v-show指令是通过修改元素的displayCSS属性让其显示或者隐藏 4 组件之间的如何传值? * 父组件与子组件传值 * 父组件通过标签上面定义传值 * 子组件通过props方法接受数据 * 子组件向父组件传递数据 * 子组件通过$emit方法传递参数 5 页面如何跳转? * 声明式(标签跳转) * 编程式(借助vue-router) 6 vue-cli中怎样使用自定义的组件? * 在components目录新建你的组件文件; * 在需要用的页面(组件)中导入; * 注入到vue的组件的components属性上面; * 在template视图view中使用。 ### 请列谈谈Vue生命周期钩子函数? ### * vue 实例从创建到销毁的过程,就是生命周期; * 创建前/后: 在beforeCreate阶段,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实例的过程时更容易形成好的逻辑。 ### 谈谈 keep-alive? ### `<keep-alive></keep-alive>` 包裹动态组件时,会缓存不活动的组件实例, 主要用于保留组件状态或避免重新渲染,在activated生命周期函数可以做相应处理。 ### 在vue中如何使用插件? ### * 采用ES6的import ... from ...语法或CommonJSd的require()方法引入插件; * 使用全局方法Vue.use( plugin )使用插件,可以传入一个选项对象Vue.use(MyPlugin, \{ someOption: true \}); ### 为什么使用key? ### 当有相同标签名的元素切换时,需要通过 key 特性设置唯一的值来标记以让 Vue 区分它们,否则 Vue 为了效率只会替换相同标签内部的内容。 ### 为什么避免 v-if 和 v-for 用在一起? ### 当 Vue 处理指令时,v-for 比 v-if 具有更高的优先级,这意味着 v-if 将分别重复运行于每个 v-for 循环中。通过v-if 移动到容器元素,不会再重复遍历列表中的每个值。取而代之的是,我们只检查它一次,且不会在 v-if 为否的时候运算 v-for。 ## 状态管理库vuex ## ### 怎么使用vuex? ### * 在src下新建一个目录vuex; * 如果不用模块功能的话,在vuex下创建一个index.js文件; * 然后引入vuex, 创建相关的state,actions,getters, mutations并导出; * 在main.js中引入vuex并注入vue实例。 ### vuex的State特性 ### * vuex就是一个仓库,仓库里面放了很多对象。其中state就是数据源存放地,对应于一般Vue对象里面的data; * state里面存放的数据是响应式的,Vue组件从store中读取数据,若是store中的数据发生改变,依赖这个数据的组件也会发生更新; * 它通过mapState把全局的 state 和 getters 映射到当前组件的 computed 计算属性中; ### vuex的Getter特性 ### * getters 可以对State进行计算操作,它就是Store的计算属性 * 虽然在组件内也可以做计算属性,但是getters 可以在多组件之间复用 * 如果一个状态只在一个组件内使用,是可以不用getters ### 不用vuex会带来什么问题? ### * 可维护性会下降,想修改数据要维护三个地方; * 可读性会下降,因为一个组件里的数据,根本就看不出来是从哪来的; * 增加耦合,大量的上传派发,会让耦合性大大增加,本来Vue用Component就是为了减少耦合,现在这么用,和组件化的初衷相背; ## 其他 ## ### 怎么定义vue-router的动态路由以及如何获取传过来的动态参数? ### * 在router目录下的index.js文件中,对path属性加上/:id。 * 使用router对象的params.id。 ### vue-loader是什么?使用它的用途有哪些? ### * 根据官网的定义,vue-loader 是 webpack 的一个 loader,用于处理 .vue 文件。 * 使用vue-cli脚手架,作者已经配置好了基本的配置,开箱及用,你需要做的就是npm install 安装下依赖,然后就可以开发业务代码了。 ### 请说出vue.cli项目中src目录每个文件夹和文件的用法? ### * assets文件夹是放静态资源; * components是放组件; * router是定义路由相关的配置; * view视图;app.vue是一个应用主组件; * main.js是入口文件 # vue常见基础面试题总结篇 # **1.vue优点?** 答:轻量级框架:只关注视图层,是一个构建数据的视图集合,大小只有几十kb; 简单易学:国人开发,中文文档,不存在语言障碍 ,易于理解和学习; 双向数据绑定:保留了angular的特点,在数据操作方面更为简单; 组件化:保留了react的优点,实现了html的封装和重用,在构建单页面应用方面有着独特的优势; 视图,数据,结构分离:使数据的更改更为简单,不需要进行逻辑代码的修改,只需要操作数据就能完成相关操作; 虚拟DOM:dom操作是非常耗费性能的, 不再使用原生的dom操作节点,极大解放dom操作,但具体操作的还是dom不过是换了另一种方式; 运行速度更快:相比较与react而言,同样是操作虚拟dom,就性能而言,vue存在很大的优势。 **2.vue父组件向子组件传递数据?** 答:通过props **3.子组件像父组件传递事件**? 答:$emit方法 **4.v-show和v-if指令的共同点和不同点?** 答: 共同点:都能控制元素的显示和隐藏; 不同点:实现本质方法不同,v-show本质就是通过控制css中的display设置为none,控制隐藏,只会编译一次;v-if是动态的向DOM树内添加或者删除DOM元素,若初始值为false,就不会编译了。而且v-if不停的销毁和创建比较消耗性能。 总结:如果要频繁切换某节点,使用v-show(切换开销比较小,初始开销较大)。如果不需要频繁切换某节点使用v-if(初始渲染开销较小,切换开销比较大)。 **5.如何让CSS只在当前组件中起作用?** 答:在组件中的style前面加上scoped **6.的作用是什么?** 答:keep-alive 是 Vue 内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染。 **7.如何获取dom?** 答:ref=“domName” 用法:this.$refs.domName **8.说出几种vue当中的指令和它的用法?** 答:v-model双向数据绑定; v-for循环; v-if v-show 显示与隐藏; v-on事件;v-once: 只绑定一次。 1. **vue-loader是什么?使用它的用途有哪些?** 答:vue文件的一个加载器,将template/js/style转换成js模块。 用途:js可以写es6、style样式可以scss或less、template可以加jade等 **10.为什么使用key?** 答:需要使用key来给每个节点做一个唯一标识,Diff算法就可以正确的识别此节点。 作用主要是为了高效的更新虚拟DOM。 11.**axios及安装?** 答:请求后台资源的模块。npm install axios --save装好, js中使用import进来,然后.get或.post。返回在.then函数中如果成功,失败则是在.catch函数中。 12**.v-modal的使用。** 答:v-model用于表单数据的双向绑定,其实它就是一个语法糖,这个背后就做了两个操作: v-bind绑定一个value属性; v-on指令给当前元素绑定input事件。 **13.请说出vue.cli项目中src目录每个文件夹和文件的用法?** 答:assets文件夹是放静态资源;components是放组件;router是定义路由相关的配置; app.vue是一个应用主组件;main.js是入口文件。 14.**分别简述computed和watch的使用场景** 答:computed: 当一个属性受多个属性影响的时候就需要用到computed 最典型的栗子: 购物车商品结算的时候 watch: 当一条数据影响多条数据的时候就需要用watch 栗子:搜索数据 **15.v-on可以监听多个方法吗?** 答:可以,栗子:。 **16.$nextTick的使用** 答:当你修改了data的值然后马上获取这个dom元素的值,是不能获取到更新后的值, 你需要使用$nextTick这个回调,让修改后的data值渲染更新到dom元素之后在获取,才能成功。 **17.vue组件中data为什么必须是一个函数?** 答:因为JavaScript的特性所导致,在component中,data必须以函数的形式存在,不可以是对象。 组建中的data写成一个函数,数据以函数返回值的形式定义,这样每次复用组件的时候,都会返回一份新的data,相当于每个组件实例都有自己私有的数据空间,它们只负责各自维护的数据,不会造成混乱。而单纯的写成对象形式,就是所有的组件实例共用了一个data,这样改一个全都改了。 **18.渐进式框架的理解** 答:主张最少;可以根据不同的需求选择不同的层级; **19.Vue中双向数据绑定是如何实现的**? 答:vue 双向数据绑定是通过 数据劫持 结合 发布订阅模式的方式来实现的, 也就是说数据和视图同步,数据发生变化,视图跟着变化,视图变化,数据也随之发生改变; 核心:关于VUE双向数据绑定,其核心是 Object.defineProperty()方法。 **20.单页面应用和多页面应用区别及优缺点** 答:单页面应用(SPA),通俗一点说就是指只有一个主页面的应用,浏览器一开始要加载所有必须的 html, js, css。所有的页面内容都包含在这个所谓的主页面中。但在写的时候,还是会分开写(页面片段),然后在交互的时候由路由程序动态载入,单页面的页面跳转,仅刷新局部资源。多应用于pc端。 多页面(MPA),就是指一个应用中有多个页面,页面跳转时是整页刷新 单页面的优点: 用户体验好,快,内容的改变不需要重新加载整个页面,基于这一点spa对服务器压力较小;前后端分离;页面效果会比较炫酷(比如切换页面内容时的专场动画)。 单页面缺点: 不利于seo;导航不可用,如果一定要导航需要自行实现前进、后退。(由于是单页面不能用浏览器的前进后退功能,所以需要自己建立堆栈管理);初次加载时耗时多;页面复杂度提高很多。 **21.v-if和v-for的优先级** 答:当 v-if 与 v-for 一起使用时,v-for 具有比 v-if 更高的优先级,这意味着 v-if 将分别重复运行于每个 v-for 循环中。所以,不推荐v-if和v-for同时使用。 如果v-if和v-for一起用的话,vue中的的会自动提示v-if应该放到外层去。 22.assets和static的区别 答:相同点:assets和static两个都是存放静态资源文件。项目中所需要的资源文件图片,字体图标,样式文件等都可以放在这两个文件下,这是相同点 不相同点:assets中存放的静态资源文件在项目打包时,也就是运行npm run build时会将assets中放置的静态资源文件进行打包上传,所谓打包简单点可以理解为压缩体积,代码格式化。而压缩后的静态资源文件最终也都会放置在static文件中跟着index.html一同上传至服务器。static中放置的静态资源文件就不会要走打包压缩格式化等流程,而是直接进入打包好的目录,直接上传至服务器。因为避免了压缩直接进行上传,在打包时会提高一定的效率,但是static中的资源文件由于没有进行压缩等操作,所以文件的体积也就相对于assets中打包后的文件提交较大点。在服务器中就会占据更大的空间。 建议:将项目中template需要的样式文件js文件等都可以放置在assets中,走打包这一流程。减少体积。而项目中引入的第三方的资源文件如iconfoont.css等文件可以放置在static中,因为这些引入的第三方文件已经经过处理,我们不再需要处理,直接上传。 **23.vue常用的修饰符** 答:.stop:等同于JavaScript中的event.stopPropagation(),防止事件冒泡; .prevent:等同于JavaScript中的event.preventDefault(),防止执行预设的行为(如果事件可取消,则取消该事件,而不停止事件的进一步传播); .capture:与事件冒泡的方向相反,事件捕获由外到内; .self:只会触发自己范围内的事件,不包含子元素; .once:只会触发一次。 **24.vue的两个核心点** 答:数据驱动、组件系统 数据驱动:ViewModel,保证数据和视图的一致性。 组件系统:应用类UI可以看作全部是由组件树构成的。 25.vue和jQuery的区别 答:jQuery是使用选择器() 选 取 D O M 对 象 , 对 其 进 行 赋 值 、 取 值 、 事 件 绑 定 等 操 作 , 其 实 和 原 生 的 H T M L 的 区 别 只 在 于 可 以 更 方 便 的 选 取 和 操 作 D O M 对 象 , 而 数 据 和 界 面 是 在 一 起 的 。 比 如 需 要 获 取 l a b e l 标 签 的 内 容 : )选取DOM对象,对其进行赋值、取值、事件绑定等操作,其实和原生的HTML的区别只在于可以更方便的选取和操作DOM对象,而数据和界面是在一起的。比如需要获取label标签的内容:)选取DOM对象,对其进行赋值、取值、事件绑定等操作,其实和原生的HTML的区别只在于可以更方便的选取和操作DOM对象,而数据和界面是在一起的。比如需要获取label标签的内容:(“lable”).val();,它还是依赖DOM元素的值。 Vue则是通过Vue对象将数据和View完全分离开来了。对数据进行操作不再需要引用相应的DOM对象,可以说数据和View是分离的,他们通过Vue对象这个vm实现相互的绑定。这就是传说中的MVVM。 1. **引进组件的步骤** 答: 在template中引入组件; 在script的第一行用import引入路径; 用component中写上组件名称。 **27.delete和Vue.delete删除数组的区别** 答:delete只是被删除的元素变成了 empty/undefined 其他的元素的键值还是不变。Vue.delete 直接删除了数组 改变了数组的键值。 **28.SPA首屏加载慢如何解决** 答:安装动态懒加载所需插件;使用CDN资源。 **29.Vue-router跳转和location.href有什么区别** 答:使用location.href=’/url’来跳转,简单方便,但是刷新了页面; 使用history.pushState(’/url’),无刷新页面,静态跳转; 引进router,然后使用router.push(’/url’)来跳转,使用了diff算法,实现了按需加载,减少了dom的消耗。 其实使用router跳转和使用history.pushState()没什么差别的,因为vue-router就是用了history.pushState(),尤其是在history模式下。 1. **vue slot** 答:简单来说,假如父组件需要在子组件内放一些DOM,那么这些DOM是显示、不显示、在哪个地方显示、如何显示,就是slot分发负责的活。 **31.你们vue项目是打包了一个js文件,一个css文件,还是有多个文件?** 答:根据vue-cli脚手架规范,一个js文件,一个CSS文件。 32.Vue里面router-link在电脑上有用,在安卓上没反应怎么解决? 答:Vue路由在Android机上有问题,babel问题,安装babel polypill插件解决。 33.Vue2中注册在router-link上事件无效解决方法 答: 使用@click.native。原因:router-link会阻止click事件,.native指直接监听一个原生事件。 34.RouterLink在IE和Firefox中不起作用(路由不跳转)的问题 答: 方法一:只用a标签,不适用button标签;方法二:使用button标签和Router.navigate方法 35.axios的特点有哪些 答:从浏览器中创建XMLHttpRequests; node.js创建http请求; 支持Promise API; 拦截请求和响应; 转换请求数据和响应数据; 取消请求; 自动换成json。 axios中的发送字段的参数是data跟params两个,两者的区别在于params是跟请求地址一起发送的,data的作为一个请求体进行发送 params一般适用于get请求,data一般适用于post put 请求。 36.请说下封装 vue 组件的过程? 答:1. 建立组件的模板,先把架子搭起来,写写样式,考虑好组件的基本逻辑。(os:思考1小时,码码10分钟,程序猿的准则。) 1. 准备好组件的数据输入。即分析好逻辑,定好 props 里面的数据、类型。 2. 准备好组件的数据输出。即根据组件逻辑,做好要暴露出来的方法。 3. 封装完毕了,直接调用即可 **37.params和query的区别** 答:用法:query要用path来引入,params要用name来引入,接收参数都是类似的,分别是this.r o u t e . q u e r y . n a m e 和 t h i s . route.query.name和this.route.query.name和this.route.params.name。 url地址显示:query更加类似于我们ajax中get传参,params则类似于post,说的再简单一点,前者在浏览器地址栏中显示参数,后者则不显示 注意点:query刷新不会丢失query里面的数据 params刷新 会 丢失 params里面的数据。 **38.vue初始化页面闪动问题** 答:使用vue开发时,在vue初始化之前,由于div是不归vue管的,所以我们写的代码在还没有解析的情况下会容易出现花屏现象,看到类似于\{ \{message\}\}的字样,虽然一般情况下这个时间很短暂,但是我们还是有必要让解决这个问题的。 首先:在css里加上\[v-cloak\] \{ display: none; \}。 如果没有彻底解决问题,则在根元素加上style=“display: none;” :style="\{display: ‘block’\}" **39.vue更新数组时触发视图更新的方法** 答:push();pop();shift();unshift();splice(); sort();reverse() 40.vue常用的UI组件库 答:Mint UI,element,VUX **41.vue修改打包后静态资源路径的修改** 答:cli2版本:将 config/index.js 里的 assetsPublicPath 的值改为 ‘./’ 。 build: \{ … assetsPublicPath: ‘./’, … \} cli3版本:在根目录下新建vue.config.js 文件,然后加上以下内容:(如果已经有此文件就直接修改) module.exports = \{ publicPath: ‘’, // 相对于 HTML 页面(目录相同) \} # 生命周期函数面试题 # **1.什么是 vue 生命周期?有什么作用?** 答:每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做 生命周期钩子 的函数,这给了用户在不同阶段添加自己的代码的机会。(ps:生命周期钩子就是生命周期函数)例如,如果要通过某些插件操作DOM节点,如想在页面渲染完后弹出广告窗, 那我们最早可在mounted 中进行。 **2.第一次页面加载会触发哪几个钩子?** 答:beforeCreate, created, beforeMount, mounted 3.简述每个周期具体适合哪些场景 答:beforeCreate:在new一个vue实例后,只有一些默认的生命周期钩子和默认事件,其他的东西都还没创建。在beforeCreate生命周期执行的时候,data和methods中的数据都还没有初始化。不能在这个阶段使用data中的数据和methods中的方法 **created:data 和 methods都已经被初始化好了,如果要调用 methods 中的方法,或者操作 data 中的数据,最早可以在这个阶段中操作** beforeMount:执行到这个钩子的时候,在内存中已经编译好了模板了,但是还没有挂载到页面中,此时,页面还是旧的 mounted:执行到这个钩子的时候,就表示Vue实例已经初始化完成了。此时组件脱离了创建阶段,进入到了运行阶段。 如果我们想要通过插件操作页面上的DOM节点,最早可以在和这个阶段中进行 beforeUpdate: 当执行这个钩子时,页面中的显示的数据还是旧的,data中的数据是更新后的, 页面还没有和最新的数据保持同步 updated:页面显示的数据和data中的数据已经保持同步了,都是最新的 beforeDestory:Vue实例从运行阶段进入到了销毁阶段,这个时候上所有的 data 和 methods , 指令, 过滤器 ……都是处于可用状态。还没有真正被销毁 destroyed: 这个时候上所有的 data 和 methods , 指令, 过滤器 ……都是处于不可用状态。组件已经被销毁了。 **4.created和mounted的区别** 答:created:在模板渲染成html前调用,即通常初始化某些属性值,然后再渲染成视图。 mounted:在模板渲染成html后调用,通常是初始化页面完成后,再对html的dom节点进行一些需要的操作。 **5.vue获取数据在哪个周期函数** 答:一般 created/beforeMount/mounted 皆可. 比如如果你要操作 DOM , 那肯定 mounted 时候才能操作. 6.请详细说下你对vue生命周期的理解? 答:总共分为8个阶段创建前/后,载入前/后,更新前/后,销毁前/后。 创建前/后: 在beforeCreated阶段,vue实例的挂载元素e l 和 ∗ ∗ 数 据 对 象 ∗ ∗ d a t a 都 为 u n d e f i n e d , 还 未 初 始 化 。 在 c r e a t e d 阶 段 , v u e 实 例 的 数 据 对 象 d a t a 有 了 , el和**数据对象**data都为undefined,还未初始化。在created阶段,vue实例的数据对象data有了,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路由面试题 # **1.mvvm 框架是什么?** 答:vue是实现了双向数据绑定的mvvm框架,当视图改变更新模型层,当模型层改变更新视图层。在vue中,使用了双向绑定技术,就是View的变化能实时让Model发生变化,而Model的变化也能实时更新到View。 **2.vue-router 是什么?它有哪些组件** 答:vue用来写路由一个插件。router-link、router-view **3.active-class 是哪个组件的属性?** 答:vue-router模块的router-link组件。children数组来定义子路由 **4.怎么定义 vue-router 的动态路由? 怎么获取传过来的值?** 答:在router目录下的index.js文件中,对path属性加上/:id。 使用router对象的params.id。 **5.vue-router 有哪几种导航钩子?** 答:三种, 第一种:是全局导航钩子:router.beforeEach(to,from,next),作用:跳转前进行判断拦截。 第二种:组件内的钩子 第三种:单独路由独享组件 **6.$route 和 $router 的区别** 答:r o u t e r 是 V u e R o u t e r 的 实 例 , 在 s c r i p t 标 签 中 想 要 导 航 到 不 同 的 U R L , 使 用 router是VueRouter的实例,在script标签中想要导航到不同的URL,使用router是VueRouter的实例,在script标签中想要导航到不同的URL,使用router.push方法。返回上一个历史history用$router.to(-1) $route为当前router跳转对象。里面可以获取当前路由的name,path,query,parmas等。 **7.vue-router的两种模式** 答:hash模式:即地址栏 URL 中的 \# 符号; history模式:window.history对象打印出来可以看到里边提供的方法和记录长度。利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法。(需要特定浏览器支持)。 8.vue-router实现路由懒加载( 动态加载路由 ) 答:三种方式 第一种:vue异步组件技术 ==== 异步加载,vue-router配置路由 , 使用vue的异步组件技术 , 可以实现按需加载 .但是,这种情况下一个组件生成一个js文件。 第二种:路由懒加载(使用import)。 第三种:webpack提供的require.ensure(),vue-router配置路由,使用webpack的require.ensure技术,也可以实现按需加载。这种情况下,多个路由指定相同的chunkName,会合并打包成一个js文件。 vuex常见面试题 1.vuex是什么?怎么使用?哪种功能场景使用它? 答:vue框架中状态管理。在main.js引入store,注入。 新建了一个目录store.js,…… export 。 场景有:单页应用中,组件之间的状态。音乐播放、登录状态、加入购物车 2.vuex有哪几种属性? 答:有五种,分别是 State、 Getter、Mutation 、Action、 Module state => 基本数据(数据源存放地) getters => 从基本数据派生出来的数据 mutations => 提交更改数据的方法,同步! actions => 像一个装饰器,包裹mutations,使之可以异步。 modules => 模块化Vuex 3.Vue.js中ajax请求代码应该写在组件的methods中还是vuex的actions中? 答:如果请求来的数据是不是要被其他组件公用,仅仅在请求的组件内使用,就不需要放入vuex 的state里。
相关 面试题——vue面试题总结 vue面试题总结 1.vue的特点是什么 1.国人开发的轻量级框架 2.双向数据绑定,在数据操作方面更为简单 3.视图,数据,结构分析,不需要进行逻辑代码的修改 た 入场券/ 2023年01月18日 11:29/ 0 赞/ 430 阅读
相关 Vue面试题 > 1.对MVVM的理解 M:model层,在model层对数据进行操作和修改数据 V:视图层 VM:监听模型数据的改变和控制视图行为。相当于模型层和视图层 女爷i/ 2022年12月22日 11:17/ 0 赞/ 213 阅读
相关 vue面试题 为什么props是单向绑定的? > 所有prop都使得其父子prop之间形成了一个单向下行绑定:父级prop的更新会向下流动到子组件中,但是反过来则不行。每次父级组件发生变更 た 入场券/ 2022年11月17日 10:18/ 0 赞/ 212 阅读
相关 vue面试题 vue.js是什么? 是一套构建用户界面的 渐进式框架 vuex是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用 曾经终败给现在/ 2022年05月10日 01:03/ 0 赞/ 157 阅读
相关 Vue面试题 1. Vue中的MVVM模式 ![在这里插入图片描述][70] 即 Model-View-ViewModel Model是数据层,View是视图层,ViewMod 水深无声/ 2022年05月07日 05:56/ 0 赞/ 404 阅读
相关 Vue 面试题 Vue面试题 1、Vue总结: vue的使用方式有两种 方式一:像jQuery一样引入使用--vue的特性都可以使用,双向数据绑定 妖狐艹你老母/ 2022年04月13日 15:15/ 0 赞/ 284 阅读
相关 Vue面试题 VUE 面试题 一.对于MVVM的理解? MVVM 是 Model-View-ViewModel 的缩写。 Model代表数据模型,也可以在Model中定义数据修改 超、凢脫俗/ 2022年02月28日 06:18/ 0 赞/ 339 阅读
相关 VUE面试题 VUE 1. MVVM如何实现模板绑定,依赖是如何收集的? 2. vue2中的diff算法是怎样实现的? 3. 请详细说出vue生命周期的执行过程 4 ╰半橙微兮°/ 2022年01月30日 15:34/ 0 赞/ 277 阅读
相关 vue面试题 vue面试题 1.Vue和react的相同与不同 相同点: 都支持服务器端渲染 都有virtual DOM,组件化开发,通过props参数进行父子组件数据的 太过爱你忘了你带给我的痛/ 2021年12月08日 16:03/ 0 赞/ 387 阅读
相关 vue面试题 1.vuex中异步在哪里写,可以在mutation里面吗,为什么? Mutation 必须是同步函数 一条重要的原则就是要记住 mutation 必须是同步函数。为什么 ゞ 浴缸里的玫瑰/ 2021年12月05日 02:31/ 0 赞/ 361 阅读
还没有评论,来说两句吧...