原生JS实现一个简单的前端路由(原理)

Posted 安慕希

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了原生JS实现一个简单的前端路由(原理)相关的知识,希望对你有一定的参考价值。

说一下前端路由实现的简要原理,以 hash 形式(也可以使用 History API 来处理)为例,

当 url 的 hash 发生变化时,触发 hashchange 注册的回调,回调中去进行不同的操作,进行不同的内容的展示。

直接看代码或许更直观。

 1 function Router() {
 2     this.routes = {};
 3     this.currentUrl = \'\';
 4 }
 5 Router.prototype.route = function(path, callback) {
 6     this.routes[path] = callback || function(){};
 7 };
 8 Router.prototype.refresh = function() {
 9     this.currentUrl = location.hash.slice(1) || \'/\';
10     this.routes[this.currentUrl]();
11 };
12 Router.prototype.init = function() {
13     window.addEventListener(\'load\', this.refresh.bind(this), false);
14     window.addEventListener(\'hashchange\', this.refresh.bind(this), false);
15 }
16 window.Router = new Router();
17 window.Router.init();

上面路由系统 Router 对象实现,主要提供三个方法

  • init 监听浏览器 url hash 更新事件
  • route 存储路由更新时的回调到回调数组routes中,回调函数将负责对页面的更新
  • refresh 执行当前url对应的回调函数,更新页面

Router 调用方式以及呈现效果如下:点击触发 url 的 hash 改变,并对应地更新内容(这里为 body 背景色)

<ul> 
    <li><a href="#/">turn white</a></li> 
    <li><a href="#/blue">turn blue</a></li> 
    <li><a href="#/green">turn green</a></li> 
</ul> 
var content = document.querySelector(\'body\');
// change Page anything
function changeBgColor(color) {
    content.style.backgroundColor = color;
}
Router.route(\'/\', function() {
    changeBgColor(\'white\');
});
Router.route(\'/blue\', function() {
    changeBgColor(\'blue\');
});
Router.route(\'/green\', function() {
    changeBgColor(\'green\');
});

 

 

以上是关于原生JS实现一个简单的前端路由(原理)的主要内容,如果未能解决你的问题,请参考以下文章

原生js简单轮播图 代码

利用JS实现前端路由

微前端实现原理研究总结

微前端实现原理研究总结

SPA路由实现的基本原理

窥探原理:实现一个简单的前端代码打包器 Roid