Vue Router 深度解析指南--基础原理与进阶实践

1. Vue Router 核心原理

1.1 什么是前端路由?

前端路由是在单页应用(SPA)中,通过 JS 来操作 URL,从而在不重新请求页面的情况下更新视图内容。Vue Router 建立了 URL 和视图组件之间的映射关系。

1.2 实现原理

  1. Hash 模式:
// 核心实现原理
class HashRouter {
   
  constructor() {
   
    // 监听 hash 变化
    window.addEventListener('hashchange', () => {
   
      this.handleHashChange()
    })
  }

  handleHashChange() {
   
    const hash = window.location.hash.slice(1)
    // 根据 hash 找到对应组件进行渲染
    this.matchComponent(hash)
  }
}
  1. History 模式:
// 核心实现原理
class HistoryRouter {
   
  constructor() {
   
    // 监听 popstate 事件
    window.addEventListener('popstate', () => {
   
      this.handleUrlChange()
    })
    
    // 重写 pushState/replaceState 方法
    this.bindHistoryEvents()
  }

  bindHistoryEvents() {
   
    const originalPushState = history.pushState
    history.pushState = (...args) => {
   
      originalPushState.apply(history, args)
      this.handleUrlChange()
    }
  }
}

2. Vue2 与 Vue3 路由对比

2.1 创建方式

Vue2:

import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值