博客
关于我
VUE-编程式路由导航
阅读量:777 次
发布时间:2019-03-24

本文共 1202 字,大约阅读时间需要 4 分钟。

编程式路由导航

编程式路由导航是通过JS代码实现路由跳转的技术,适用于单页应用的路由管理。以下是实现细节和操作方法。

路由实现

路由实现主要通过以下两种方式实现:

1. Hash方式

hash方式通过改变URL的哈希值来实现路由跳转。主要特点是:

  • 浏览器记录历史会被更新,用户可以通过浏览器返回键回溯
  • Brower会监控哈希值的变化,可以根据哈希值获取当前路由

2. State/History API

State API提供了push和replace方法,用于对管理当前和历史状态。它们的区别在于:

  • push:将新路由压入栈,不影响当前任务stack
  • replace:新路由直接替换当前记录,不回退

两者都使用栈结构来管理历史记录,这使得路由系统更具层次性。

路由器$router的实现

路由器是一个栈结构,支持push、replace和back操作。典型的代码操作如下:

示例代码:
pushShow(id) {  this.$router.push(`/home/messages/MessageDetail/${id}`);},replaceShow(id) {  this.$router.replace(`/home/messages/MessageDetail/${id}`);},

路由器采用栈的作用方式,push操作会将新路由压入栈顶,replace则完全替换当前记录。这种栈结构使得路由系统具备良好的历史记录功能,比如back按钮可以实现前一路由的返回。

路由跳转方式

路由器提供了多种方式进行跳转,具体包括:

trailed

1. this.$router.push(path)

push方法主要用于点击路由链接,相当于普通链接点击后跳转。此方法保持当前路由历史记录,可以通过back返回当前页面。

2. this.$router.replace(path)

replace方法用于替换当前的路由记录,不会保留历史信息。如果用户使用replace跳转后,再点击back,就无法回到原来的页面。

3. this.$router.back()

back方法用于回到上一个路由记录,这个方法适合栈结构的路由系统,能有效管理页面的层次NullOrEmpty

4. this.$router.go(-1)

go方法和back功能一致,用于请求前一个路由记录。这两者在实现上可能存在细微差别,但作用相同。

技术要点

在使用路由器时需要注意以下几点:

1. 组件中自带$route和$router属性,$route用于获取当前路由信息,$router用于调用路由控制方法

2. $router提供的方法可与组件生命周期结合使用,确保路由变化时组件及时刷新

3. 栈结构的路由管理需要注意数据的深层次合并,避免数据覆盖和冲突

4. 路由参数传递要规范化,统一接收和处理方式有助于路由参数的安全和稳定

转载地址:http://yprkk.baihongyu.com/

你可能感兴趣的文章
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>