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.的作⽤是什么?
jquery框架面试题答: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;导航不可⽤,如果⼀定要导航需要⾃⾏实现前进、后退。(由于是单页⾯不能⽤浏览器的前进后退功能,所以需要⾃⼰建⽴堆栈管理);初次加载时耗时多;页⾯复杂度提⾼很多。
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是使⽤选择器(
)选取DOM对象,对其进⾏赋值、取值、事件绑定等操作,其实和原⽣的HTML的区别只在于可以更⽅便的选取和操(“lable”).val();,它还是依赖DOM元素的值。
Vue则是通过Vue对象将数据和View完全分离开来了。对数据进⾏操作不再需要引⽤相应的DOM对象,可以说数据和View是分离的,他们通过Vue对象这个vm实现相互的绑定。这就是传说中的MVVM。
26. 引进组件的步骤
答: 在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模式下。
30. vue slot
答:简单来说,假如⽗组件需要在⼦组件内放⼀些DOM,那么这些DOM是显⽰、不显⽰、在哪个地⽅显⽰、如何显⽰,就是slot分发负责的活。
31.你们vue项⽬是打包了⼀个js⽂件,⼀个css⽂件,还是有多个⽂件?
答:根据vue-cli脚⼿架规范,⼀个js⽂件,⼀个CSS⽂件。
32.Vue⾥⾯router-link在电脑上有⽤,在安卓上没反应怎么解决?
答:Vue路由在Android机上有问题,babel问题,安abel 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分钟,程序猿的准则。)
2. 准备好组件的数据输⼊。即分析好逻辑,定好 props ⾥⾯的数据、类型。
3. 准备好组件的数据输出。即根据组件逻辑,做好要暴露出来的⽅法。
4. 封装完毕了,直接调⽤即可
37.params和query的区别
route.query.name和this.
答:⽤法:query要⽤path来引⼊,params要⽤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;” :
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版本:在根⽬录下新建fig.js ⽂件,然后加上以下内容:(如果已经有此⽂件就直接修改)
publicPath: ‘’, // 相对于 HTML 页⾯(⽬录相同) }
⽣命周期函数⾯试题
1.什么是 vue ⽣命周期?有什么作⽤?
答:每个 Vue 实例在被创建时都要经过⼀系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运⾏⼀些叫做 ⽣命周期钩⼦ 的函数,这给了⽤户在不同阶段添加⾃⼰的代码的机会。(ps:⽣命周期钩⼦就是⽣命周期函数)例如,如果要通过某些插件操作DOM节点,如想在页⾯渲染完后弹出⼴告窗, 那我们最早可在mounted 中进⾏。
2.第⼀次页⾯加载会触发哪⼏个钩⼦?
答:beforeCreate, created, beforeMount, mounted
3.简述每个周期具体适合哪些场景
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论