博客
关于我
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/

你可能感兴趣的文章
Nginx做反向代理时访问端口被自动去除
查看>>
Nginx入门教程-简介、安装、反向代理、负载均衡、动静分离使用实例
查看>>
nginx反向代理
查看>>
Nginx反向代理
查看>>
nginx反向代理、文件批量改名及统计ip访问量等精髓总结
查看>>
Nginx反向代理与正向代理配置
查看>>
Nginx反向代理及负载均衡实现过程部署
查看>>
Nginx反向代理和负载均衡部署指南
查看>>
Nginx反向代理是什么意思?如何配置Nginx反向代理?
查看>>
nginx反向代理解决跨域问题,使本地调试更方便
查看>>
nginx反向代理转发、正则、重写、负摘均衡配置案例
查看>>
Nginx反向代理配置
查看>>
Nginx启动SSL功能,并进行功能优化,你看这个就足够了
查看>>
nginx启动脚本
查看>>
Nginx和Tomcat的区别
查看>>
Nginx在Windows上和Linux上(Docker启动)分别配置基本身份认证示例
查看>>
Nginx在Windows下载安装启动与配置前后端请求代理
查看>>
Nginx在开发中常用的基础命令
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>