2021Vue前端⾯试题总结(含答案)
怎么定义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是⼊⼝⽂件
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: 只绑定⼀次。
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中的
jquery是什么选择器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问题,安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 如何监听数组变化
答案:
Object.defineProperty 不能监听数组变化
重新定义原型,重写push pop 等⽅法,实现监听
Proxy 可以原⽣⽀持监听数组变化
37、请描述响应式原理
答案:
监听data变化,监听data属性getter,setter(包括数组)参考: 第3点
组件渲染和更新的流程:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论