vue-router使用与源码浅析

0e95128abca995d820d4fe0ac0e533b3.png

本文主要讨论最新版的vue-router(支持Vue3),主要从其出现原因、使用方式、自己实现一个玩具vue-router以及vue-router源码分析这几个角度去讨论,希望你喜欢。

前端路由演变

在JQuery时代,多数Web项目的路由都是由后端实现的,用户访问网页时的常见流程为:

  • 1.用户访问路由

  • 2.后端获得路由并匹配相应的模板

  • 3.后端动态渲染模板并返回

  • 4.浏览器加载返回模板中的JS、CSS

前端人员的开发多数都受限于后端框架提供的模板语言,用户每次页面跳转,都由后端动态渲染出相应的模板并返回。

这种项目开发方式有很多缺点:

  • 前后端无法分离

  • 页面调整需要刷新整个页面

  • 等待时间较长、交互体验下降

当Ajax出来后,前后端可以分离了,前端工程师尝试利用JS来构建路由系统,用户访问某路由时,利用Ajax去动态获取数据,再利用JS去动态生产换网页页面,这样页面不需要全局刷新,用户浏览网页的体验也更好了一些。

这种,通过JS去控制路由,让用户一直停留在index.html上,通过JS动态根据不同路由加载不同页面元素的应用便是单页应用程序(SPA,single page application)的早期形态。

vue-router的核心原理也类似,通过JS去匹配URL,然后加载不同的页面内容。

一般,前端JS匹配路由URL有两种方式:

  • hash模式,通过在URL中加入#来做内容区分

  • history模式,这种方式的URL看起与正常的一样

在2014年之前,大家主要通过hash模式来匹配URL,其URL形式为:

http://xxx.com/#/home

当页面跳转时,URL中#后的内容变化会触发hashchange事件(这种模式称为hash模式的原因),通过对hashchange事件的监听,便可以实现对网页内容的动态渲染:

window.addEventListener('hashchange', fn)

通过window.addEventListener方法,我们实现了,当hashchange事件改变时,对fn方法的调用,在fn方法中,可以对URL中不同的hash值进行不同的逻辑操作,比如加载不同页面内容。

在2014后,HTML5标准发布,浏览器多了pushState与replaceState这两个API,通过这两个API,我们可以改变URL且浏览器不会向后端服务发起请求,同时还触发popstate事件,利用这两个新增的API和popstate事件,便可以设计出history模式。

已经通过window.addEventListener方法监听popstate事件,然后调用相应的方法则可。

简单使用vue-router

构建一个vue3项目,然后安装vue-router@next。

yarn create vite DashboardFrameWork --template vue
yarn add vue-router@next

在src/components中创建Home.vue和About.vue这两个文件:

<!-- Home.vue -->
<template>
  <div>
    主页
  </div>
</template>


<!-- About.vue -->
<template>
  <div>
    关于页
  </div>
</template>

创建src/router目录,用于存放路由相关的逻辑,在src/router目录下,创建index.js,代码如下:

// src/router/index.js

import { createR
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

懒编程-二两

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值