美文网首页
VueRouter实现原理

VueRouter实现原理

作者: hao102 | 来源:发表于2021-11-28 12:18 被阅读0次

VueRouter类图

image.png

VueRouter类

属性:

options:记录构造函数中传入的对象;路由规则
routeMap:是一个对象;用来记录路由地址和组件之间的对应关系;即将传入的路由规则解析到routeMap对象中
data:是一个响应式的对象;里边有一个current用来记录当前的路由地址
install方法:是一个静态方法;用来实现Vue的插件机制
Constructor:构造函数,帮我们初始化类属性
initEvent:用来注册popState事件;监听浏览器历史的变化
createRouteMap方法:将构造函数中传入的路由规则转换为键值对的形式存储到routeMap属性中
initComponents方法:用来创建routeLink和routeView组件的
init方法:调用initEvent,createRouteMap,initComponents方法

/*
 * @Descripttion: 封装一个简单的VueRouter
 * @version: 
 * @Author: ahao
 * @Date: 2021-11-27 19:38:39
 * @LastEditors: ahao
 * @LastEditTime: 2021-11-27 21:37:30
 */

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.mixin({
            beforeCreated() {
                // 只在vue实例上执行;组件上不执行
                if (this.$options.router) {
                    _Vue.prototype.$router = this.$options.router;
                    this.$options.router.init();
                }
            }
        })
        // _Vue.prototype.$router = this.$options.router;
    }

    constructor(options) {
        this.options = options;
        this.routeMap = {};
        this.data = _Vue.observable({
            // 创建一个响应式的对象
            current: '/'
        })
    }
    createRouteMap() {
        // 遍历所有的路由规则;把路由规则解析成键值对的形式存储到routeMap中
        this.options.routes.forEach(route => {
            this.routeMap[route.path] = route.component;
        })
    }
    initComponents(Vue) {
        const self = this;
        Vue.component('route-link', {
            props: {
                to: String
            },
            render(h) {
                return h('a', {
                    attrs: {
                        href: this.to;
                    },
                    on: {
                        click: this.clicHandler
                    }
                }, [this.$slots.default])
            },
            methods: {
                clicHandler(e) {
                    history.pushState({}, '', this.to);
                    this.$router.data.current = this.to;
                    e.preventDefault();
                }
            }

            // template: '<a :href="to"><slot></slot></a>'
        })
        Vue.component('route-view', {
            render(h) {
                const component = self.routeMap[self.data.current]

                return h(component)
            }
        })
    }
    initEvent() {
        // 
        window.addEventListener('popstate', () => {
            this.data.current = window.location.pathname
        })
    }

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

相关文章

  • VueRouter实现原理

    VueRouter类图 VueRouter类 属性: options:记录构造函数中传入的对象;路由规则route...

  • 使用 VueRouter 构建SPA单面应用DEMO

    H5页面使用 VueRouter 构建SPA单面应用DEMO VueRouter 实现原理 一个页面地址由协议/主...

  • vue中权限设置

    一、场景 前后端分离spa页面权限设置 二、技术栈 vue全家桶 三、实现效果 四、实现原理 vueRouter控...

  • 实现一个vueRouter

    实现一个vue插件步骤 实现一个vueRouter 实现组件router-link 实现组件router-view...

  • Vuex模拟实现

    实现思路 实现install方法vuex是vue的一个插件,所以和模拟VueRouter类似,先实现Vue插件约定...

  • 路由

    路由map 路由视图 路由导航 实现简单路由 import VueRouter from 'vue-router'...

  • Vue+VueRouter+webpack+Less+VueRe

    Vue+VueRouter+webpack+Less+VueResource实现一个天气app运行步骤:1 进入W...

  • vue中通过history api拦截浏览器的前进后退按钮事件

    现在vueRouter的模式基本都是history模式,它的实现是基于原生事件popstate来实现的。先看看MD...

  • VueRouter 对象

    VueRouter 的实现是⼀个类,首先看看constructor 构造函数。 其中 this.app 表示根 V...

  • 实现一个简单的VueRouter

    上次网易实习面试问到了VueRouter的原理,现在手写一个简单的Router(hash模式)。 首先,需要在新建...

网友评论

      本文标题:VueRouter实现原理

      本文链接:https://www.haomeiwen.com/subject/vybztrtx.html