首页 > 其他分享 >#yyds干货盘点#VueRouter模拟实现

#yyds干货盘点#VueRouter模拟实现

时间:2023-11-20 12:32:32浏览次数:30  
标签:yyds Vue component 干货 VueRouter router options 路由

hash模式

  • URL中#号后面的内容作为路径地址
  • 监听hashchange事件
  • 根据当前路与地址找到对应的组件重新渲染
    history模式
  • 通过history.pushState()方法改变地址栏
  • 监听popstate事件
  • 根据当前路由地址找到对应组件重新渲染

基本使用

// 1. 注册路由插件
Vue.use(VueRouter)
// 2. 创建 router 对象
const router = new VueRouter({
  routes:[
    {nmae:'home',path:'/',component:homeComponent}
  ]
})
const vm = new Vue({
  // 3. 注册 router 对象
  router,
  render: h => h(App)
}).$mount('#app')

#yyds干货盘点#VueRouter模拟实现_Vue


第一步实现install方法

第二步实现构造函数,构造函数中需要初始化options,data,routeMap三个属性,data为响应式对象

第三步,实现createRouteMap方法,把构造函数中传入options中的routes构造成键值对存储到routeMap中,键为路由地址,值为对于组件。

第四步,实现initComponents方法

第五步,运行时版本vue不支持template模板,手动实现一个render函数

第六步,实现initEvent()方法

/* eslint-disable indent */
let _Vue
export default class VueRouter {
  // 先实现install方法
  //   1,判断当前插件是否已经安装
  static install (Vue) {
    if (VueRouter.install.installed) {
      return
    }
    VueRouter.install.installed = true
    // 2,把Vue构造函数记录到全局变量
    _Vue = Vue
    // 3,把创建Vue实例传入的router对象注入到Vue实例上
    // 混入
    _Vue.mixin({
      beforeCreate () {
        if (this.$options.router) {
          // 只需执行一次,并且是vue实例才执行,组件选项中没有router属性
          _Vue.prototype.$router = this.$options.router
          // this.$options.router.init() // 调用初始化两个方法
        }
      }
    })
  }

  // 第二步实现构造函数
  constructor (options) {
    this.options = options
    this.routeMap = {} // 解析options存储的routes,键是路由地址,值是组件
    this.data = _Vue.observable({
      current: '/'
    })
    this.init()
  }

  // 第三步实现createROuteMap
  createRouteMap () {
    // 遍历所有路由规则,把路由规则解析成键值对的形式 存储到routeMap中
    this.options.routes.forEach(route => {
      this.routeMap[route.path] = route.component
    })
  }

  init () {
    this.createRouteMap()
    this.initComponents(_Vue)
    this.initEvent()
  }

  initComponents (Vue) {
    // 实现一个router-link组件
    Vue.component('router-link', {
      props: {
        to: String
      },
      // template: '<a :href="to"><slot></slot></a>' 运行时版本vue不支持template模板
      render (h) {
        return h('a', {
          attrs: {
            href: this.to
          },
          on: {
            click: this.clickHandler // 阻止点击的默认行为
          }
        }, [this.$slots.default])
      },
      methods: {
        clickHandler (e) {
          history.pushState({}, '', this.to)
          // 改变当前路由地址
          this.$router.data.current = this.to
          e.preventDefault()
        }
      }
    })

    const self = this
    Vue.component('router-view', {
      render (h) {
       const component = self.routeMap[self.data.current]
        return h(component) // 转化component为虚拟dom
      }
    })
  }

  initEvent () {
    // 注册popstate事件
    window.addEventListener('popstate', () => {
      // this代表组件实例
      this.data.current = window.location.pathname
    })
  }
}

标签:yyds,Vue,component,干货,VueRouter,router,options,路由
From: https://blog.51cto.com/u_11365839/8487085

相关文章

  • 【虹科干货】如何解决安全问题?——重新定义与供应链伙伴的合作
    2023年竟已接近尾声,2024年又该如何呢?安全和第三方风险管理的正忙于总结过去,展望未来。调查显示,仅有16%的组织表示,在过去的一年里他们有效地管理了第三方风险,我们需要重新审视现有流程效率的机会。平均而言,一个组织会与88个第三方共享敏感或关键信息。对于员工超过10,000人的组织,这......
  • # yyds干货盘点 # chrome老更新的话 driver怎么才能保持更新呢?
    大家好,我是皮皮。一、前言前几天在Python最强王者交流群【鶏啊鶏。】问了一个selenium驱动器的问题,一起来看看吧。问题描述:有没有selenium用的比较多的大佬 想问问一些selenium的定时任务 关于chrome老更新的话 driver怎么才能保持更新呢二、实现过程后来【瑜亮老师】给了一......
  • 【虹科干货】Oracle与Redis Enterprise协同,作为企业缓存解决方案
    单独使用Oracle作为企业缓存数据库时,会出现哪些问题呢?使用RedisEnterprise与Oracle共同用作企业级缓存或副本数据库,会出现哪些喜人的提升呢?Orcle配合使用RedisEnterprise,为什么能够打造更快、更高效、更具成本效益的现代企业数据库呢?  文章速览: Oracle为什么需要Redis......
  • 【虹科干货】Oracle与Redis Enterprise协同,作为企业缓存解决方案
    单独使用Oracle作为企业缓存数据库时,会出现哪些问题呢?使用RedisEnterprise与Oracle共同用作企业级缓存或副本数据库,会出现哪些喜人的提升呢?Orcle配合使用RedisEnterprise,为什么能够打造更快、更高效、更具成本效益的现代企业数据库呢?文章速览:Oracle为什么需要RedisEnterpriseRed......
  • # yyds干货盘点 # 盘点一个Python自动化办公需求之word文档图片自动插入
    大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Python自动化办公的问题,一起来看看吧。下面还给出了他的代码。三、总结大家好,我是皮皮。这篇文章主要盘点了一个Python自动化办公之word文档图片自动插入问题,文中针对该问题,给出了具体的解析和代码实现,帮助......
  • # yyds干货盘点 # echarts图表,在notebook里为什么显示不出呢?
    大家好,我是皮皮。一、前言前几天在Python最强王者交流群【吴超建】问了一个echarts图像可视化的问题,一起来看看吧。echarts图表,在notebook里为什么显示不出呢?二、实现过程这里【巭孬......
  • 实用干货丨Eolink Apikit 配置和告警规则的各种用法
    API在运行过程中可能会遇到各种异常情况,如响应时间过长、调用频率过高、请求参数错误等,这些异常会对系统的稳定性和性能产生严重影响。因此,对API进行异常监控和告警是非常必要的。本文将介绍EolinkApikit中使用的告警规则,帮助开发者和运维人员更好地监控和管理API。全局告警......
  • 【转】JDK8 升级 JDK11 最全实践干货来了 | 京东云技术团队
    原文地址:JDK8升级JDK11最全实践干货来了|京东云技术团队作者:京东云开发者1.前言截至目前(2023年),Java8发布至今已有9年,2018年9月25日,Oracle发布了Java11,这是Java8之后的首个LTS版本。那么从JDK8到JDK11,到底带来了哪些特性呢?值得我们升级吗?而且升级过程会......
  • 【转】JDK11 升级 JDK17 最全实践干货来了 | 京东云技术团队
    原文地址:JDK11升级JDK17最全实践干货来了|京东云技术团队原文作者:京东云开发者1.前言上篇文章给大家带来了JDK8升级JDK11的最全实践,相信大家阅读后已经对JDK11有了比较深入的了解。2021年9月14日,Oracle发布了可以长期支持的JDK17版本,那么从JDK11到JDK17,......
  • # yyds干货盘点 # 由['a', 'b', 'c']变为['c', 'a', 'b&
    大家好,我是皮皮。一、前言前几天在Python最强王者交流群【吴超建】问了一个Python基础问题,一起来看看吧。由['a','b','c']变为['c','a','b','c']请教下有没有优雅一点的写法?二、实现过程这里【巭孬......