vue路由(vue-router)面试题

本文详细介绍了Vue Router的相关面试题目,涵盖了MVVM模式、vue-router组件、active-class属性、动态路由、导航钩子、$route和$router的区别、响应路由参数变化、传参方式、两种模式(hash和history)及其比较,还涉及路由懒加载、重定向、404页面配置和路由的#号去除方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.mvvm 框架是什么?

MVVM

MVVM是把MVCControllerMVPPresenter改成了ViewModel

View的变化会自动更新到ViewModelViewModel的变化也会自动同步到View上显示。这种自动同步是因为ViewModel中的属性实现了Observer,当属性变更时都能触发对应的操作。
img

img

MVC

MVC是应用最广泛的软件架构之一,一般MVC分为:

Model( 模型 )Controller( 控制器 )View( 视图 )

这主要是基于分层的目的,让彼此的职责分开。View一般通过Controller来和Model进行联系。ControllerModelView的协调者,ViewModel不直接联系。基本联系都是单向的。
img

1、View 传送指令到 Controller
2、Controller 完成业务逻辑后,要求 Model 改变状态
3、Model 将新的数据发送到 View,用户得到反馈

MVP

MVP 模式将 Controller 改名为Presenter,同时改变了通信方向。
img

1、各部分之间的通信,都是双向的。
2、View 与 Model 不发生联系,都通过 Presenter 传递。
3、View 非常薄,不部署任何业务逻辑,称为"被动视图"(Passive View),即没有任何主动性,而 Presenter非常厚,所有逻辑都部署在那里。

MVVM模式的优点以及与MVC模式的区别

MVVM模式的优点:

1、低耦合:视图(View)可以独立于 Model 变化和修改,一个 ViewModel 可以绑定到不同的"View"上,当View变化的时候Model可以不变,当Model变化的时候View也可以不变。

2、可重用性:你可以把一些视图逻辑放在一个ViewModel里面,让很多 view 重用这段视图逻辑。

3、独立开发:开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计。

4、可测试:界面素来是比较难于测试的,而现在测试可以针对ViewModel来写。

MVVM 和 MVC 的区别:

mvcmvvm其实区别并不大。都是一种设计思想。

主要区别

mvc 中 Controller演变成 mvvm 中的 viewModel,

mvvm 通过数据来显示视图层而不是节点操作。

mvvm主要解决了:

mvc中大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。

2.vue-router 是什么?它有哪些组件

vue-router 是 vue 的路由插件,

组件:router-link router-view

3.active-class 是哪个组件的属性?

active-class 是 vue-router 模块的 router-link 组件的属性

active-class使用方法

1、直接在路由js文件中配置linkActiveClass

export default new Router({
   
   

  linkExactActiveClass: 'active',

})

2、在router-link中写入exact

<router-link to="/" class="menu-home" active-class="active" exact>首页</router-link>

4.怎么定义 vue-router 的动态路由? 怎么获取传过来的值

在 router 目录下的 index.js 文件中,对 path 属性加上 /:id。

获取传过来的值

使用 router 对象的 params.id 获取

示例

第一个页面

~~~
<div>
    <a href="javascript:void(0)" @click="getDetail(1)">
        去第二个页面
    </a>
</div>


<script>
export default {
   
   
  name: 'app',
  methods:{
   
   
    getDetail(id) {
   
   
      this.$router.push({
   
   
        name: 'login',
        params: {
   
   
          id: id
        }
      })
    }
  }
}
<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值