vue面试题,建议收藏

Vue面试题总结随着Vue.js的普及,越来越多的人选择使用Vue.js开发前端应用。但是,面试官总是会问一些常见的问题,这篇文章总结了Vue面试题,帮助你更好地准备面试。一、Vue的优点1.轻量级框架:只关注视图层,是一个构建数据的视图集合,大小只有几十kb。 2.简单易学:国人开发,中文文档,不存在语言障碍,易于理解和学习。 3.双向数据绑定:保留了Angular的特点,在数据操作方面更为简单。 4.组件化:保留了React的优点,实现了HTML的封装和重用,在构建单页面应用方面有着独特的优势。 5.视图,数据,结构分离:使数据的更改更为简单,不需要进行逻辑代码的修改,只需要操作数据就能完成相关操作。 6.虚拟DOM:DOM操作是非常耗费性能的,不再使用原生的DOM操作节点,极大解放DOM操作,但具体操作的还是DOM,不过是换了另一种方式。 7.运行速度更快:相比较与React而言,同样是操作虚拟DOM,就性能而言,Vue存在很大的优势。二、Vue中的组件通信1.父组件向子组件传递数据:通过props 2.子组件像父组件传递事件:$emit方法三、Vue中的指令1. v-show和v-if指令的共同点和不同点: -共同点:都能控制元素的显示和隐藏。 -不同点:实现本质方法不同,v-show本质就是通过控制CSS中的display设置为none,控制隐藏,只会编译一次;v-if是动态的向DOM树内添加或者删除DOM元素,若初始值为false,就不会编译了。而且v-if不停的销毁和创建比较消耗性能。 -总结:如果要频繁切换某节点,使用v-show(切换开销比较小,初始开销较大)。如果不需要频繁切换某节点使用v-if(初始渲染开销较小,切换开销比较大)。四、Vue中的CSS作用域1.如何让CSS只在当前组件中起作用?:在组件中的style前面加上scoped五、 Vue中的keep-alive组件1. keep-alive的作用:使被包含的组件保留状态,或避免重新渲染。六、Vue中的DOM操作1.如何获取DOM?:ref=“domName”用法:this.$refs.domName七、Vue中的指令1. v-model:双向数据绑定。 2. v-for:循环。 3. v-if v-show:显示与隐藏。 4. v-on:事件。 5. v-once:只绑定一次。八、Vue中的loader 1. vue-loader是什么?:vue文件的一个加载器,将template/js/style转换成js模块。 2.使用它的用途有哪些?:js可以写es6、style样式可以scss或less、template可以加jade等。九、为什么使用key? 1.需要使用key来给每个节点做一个唯一标识,Diff算法就可以正确的识别此节点。作用主要是为了高效的更新虚拟DOM。十、axios及安装1.什么是axios?:请求后台资源的模块。 2.安装方法:npm install axios --save 3.使用方法:js中使用import进来,然后.get或.post。返回在.then函数中如果成功,失败则是在.catch函数中。十一、v-model的使用1. v-model用于表单数据的双向绑定,其实它就是一个语法糖,这个背后就做了两个操作:v-bind绑定一个value属性;v-on指令给当前元素绑定input事件。十二、vue-cli项目中src目录每个文件夹和文件的用法1. assets文件夹:是放静态资源。 2. components:是放组件。 3. router:是定义路由相关的配置。 4. app.vue:是一个应用主组件。 5. main.js:是入口文件。十三、computed和watch的使用场景1. computed:当一个属性受多个属性影响的时候就需要用到computed。 2. watch:当一条数据影响多条数据的时候就需要用watch。十四、v-on可以监听多个方法吗? 1.可以,例如:v-on={click: ‘onClick’, dblclick: ‘onDblclick’}。十五、$nextTick的使用1.当你修改了data的值然后马上获取这个dom元素的值,是不能获取到更新后的值,你需要使用$nextTick这个回调,让修改后的data值渲染更新到dom元素之后在获取,才能成功。十六、为什么Vue组件中data必须是一个函数? 1.因为JavaScript的特性所导致,在component中,data必须以函数的形式存在,不可以是对象。十七、渐进式框架的理解1.主张最少;可以根据不同的需求选取不同的框架。
docx 文件大小:15.17KB