vue的七道常见面试题

超、凢脫俗 2022-05-25 14:26 280阅读 0赞

vue的优点是什么?什么是mvvm?mvvm和mvc区别?

1:什么是mvvm?

MVVM是Model-View-ViewModel的缩写。mvvm是一种设计思想。Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI 组件,它负责将数据模型转化成UI 展现出来,ViewModel 是一个同步View 和 Model的对象。

在MVVM架构下,View 和 Model 之间并没有直接的联系,而是通过ViewModel进行交互,Model 和 ViewModel 之间的交互是双向的, 因此View 数据的变化会同步到Model中,而Model 数据的变化也会立即反应到View 上。

ViewModel 通过双向数据绑定把 View 层和 Model 层连接了起来,而View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑,不需要手动操作DOM, 不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。

2:mvvm和mvc区别?

mvc和mvvm其实区别并不大。都是一种设计思想。主要就是mvc中Controller演变成mvvm中的viewModel。mvvm主要解决了mvc中大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。和当 Model 频繁发生变化,开发者需要主动更新到View 。

2:vue的优点是什么?

  1. 低耦合。视图(View)可以独立于Model变化和修改,一个ViewModel可以绑定到不同的”View”上,当View变化的时候Model可以不变,当Model变化的时候View也可以不变。
  2. 可重用性。你可以把一些视图逻辑放在一个ViewModel里面,让很多view重用这段视图逻辑。
  3. 独立开发。开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计,使用Expression Blend可以很容易设计界面并生成xml代码。
  4. 可测试。界面素来是比较难于测试的,而现在测试可以针对ViewModel来写。

3:请详细说下你对vue生命周期的理解?

答:总共分为8个阶段创建前/后,载入前/后,更新前/后,销毁前/后。

  • 创建前/后: 在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结构依然存在

3:组件之间的传值?

1:父组件与子组件传值

  1. //父组件通过标签上面定义传值
  2. <template>
  3. <Main :obj="data"></Main>
  4. </template>
  5. <script>
  6. //引入子组件
  7. import Main form "./main"
  8. exprot default{
  9. name:"parent",
  10. data(){
  11. return {
  12. data:"我要向子组件传递数据"
  13. }
  14. },
  15. //初始化组件
  16. components:{
  17. Main
  18. }
  19. }
  20. </script>
  21. //子组件通过props方法接受数据
  22. <template>
  23. <div>{
  24. {data}}</div>
  25. </template>
  26. <script>
  27. exprot default{
  28. name:"son",
  29. //接受父组件传值
  30. props:["data"]
  31. }
  32. </script>

2:子组件向父组件传递数据

  1. //子组件通过$emit方法传递参数
  2. <template>
  3. <div>
  4. <main @sendData="receiveEvent" :data="dataInfo" />
  5. </div>
  6. </template>
  7. <script>
  8. //引入子组件
  9. import Main form "./main"
  10. exprot default{
  11. data () {
  12. return {
  13. dataInfo:"传值信息"
  14. }
  15. },
  16. methods:{
  17. // 接收子组件的值
  18. receiveEvent(e){
  19. console.log(e)
  20. }
  21. },
  22. components:{
  23. 'main':Main
  24. }
  25. }
  26. </script>
  27. //
  28. <template>
  29. <div @click="sendEvent">{
  30. {data}}</div>
  31. </template>
  32. <script>
  33. exprot default{
  34. name:"son",
  35. //接受父组件传值
  36. props:["data"],
  37. methods:{
  38. sendEvent(){
  39. this.$emit('sendData', 1)
  40. }
  41. }
  42. }
  43. </script>

4:路由之间跳转?














声明式(标签跳转) 编程式( js跳转)
<router-link :to=”index”> router.push(‘index’)

5:组件的使用和自己创建公用组件?

第一步:在components目录新建你的组件文件(indexPage.vue),script一定要export default {}

第二步:在需要用的页面(组件)中导入:import indexPage from ‘@/components/indexPage.vue’

第三步:注入到vue的子组件的components属性上面,components:{indexPage}

第四步:在template视图view中使用,

问题有indexPage命名,使用的时候则index-page。

6:vue如何实现按需加载配合webpack设置?

  1. webpack中提供了require.ensure()来实现按需加载。以前引入路由是通过import 这样的方式引入,改为const定义的方式进行引入。
  2. 不进行页面按需加载引入方式:import home from '../../common/home.vue'
  3. 进行页面按需加载的引入方式:const home = r => require.ensure( [], () => r (require('../../common/home.vue')))

7:vuex是什么?怎么使用?哪种功能场景使用它?

vue框架中状态管理。在main.js引入store,注入。新建了一个目录store,….. export 。场景有:单页应用中,组件之间的状态。音乐播放、登录状态、加入购物车

发表评论

表情:
评论列表 (有 0 条评论,280人围观)

还没有评论,来说两句吧...

相关阅读

    相关 vue见面试题

    vue常见面试题(生命周期、路由是重点) Vue 实现数据双向绑定的原理:Object.defineProperty() vue 实现数据双向绑定主要是:采用数据劫

    相关 Vue见面试题

    1.聊聊你对vue的理解 vue是一个渐进式的JS框架。他易用,灵活,高效; 可以把一个页面分隔成多个组件;当其他页面有类似功能时,直接让封装的组件进行复用; 他是构建用

    相关 vue见面试题

    1.vue优点? 答:轻量级框架:只关注视图层,是一个构建数据的视图集合,大小只有几十kb; 简单易学:国人开发,中文文档,不存在语言障碍 ,易于理解和学习; 双向