vue常见⾯试题
⼀、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
react router dom文档
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: 只绑定⼀次。
9. 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;导航不可⽤,如果⼀定要导航需要⾃⾏实现前进、后退。(由于是单页⾯不能⽤浏览器的前进后退功能,所以需要⾃⼰建⽴堆栈管理);初次加载时耗时多;页⾯复杂度提⾼很多。