学习十四、手写最简单的vue-router的history模式

let _Vue = null;
export default class VueRouter {
  static install(Vue) {
    // 1、判断当前插件是否已经被安装
    if (VueRouter.install.installed) {
      return;
    }
    VueRouter.install.installed = true
    // 2、把 Vue 构造函数记录到全局变量
    _Vue = Vue
    // 3、把创建 Vue 实例时候传入的 router 注入到全部 Vue 实例上
    // _Vue.prototype.$router = this.$options.router
    // 混入
    _Vue.mixin({
      beforeCreate() {
        // 只在 new Vue() 实例中执行,不在组件中执行
        if (this.$options.router) {
          _Vue.prototype.$router = this.$options.router
        }
      }
    })
  }
  constructor(options) {
    this.options = options;
    this.routeMap = {};
    // 创建一个响应式对象 data
    this.data = _Vue.observable({
      current: '/'
    })
    this.init();
  }
  init() {
    this.createRouteMap();
    this.initComponents(_Vue);
    this.initEvent()
  }
  createRouteMap() {
    // 遍历所有路由规则,把路由规则解析成键值对的形式,存储到 routeMap 中
    this.options.routes.forEach(route =
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值