原生JS实现一个简单的前端路由(路由实现的原理)
来源:互联网 发布:微信 url token java 编辑:程序博客网 时间:2024/04/27 13:03
一个极简前端路由实现
说一下前端路由实现的简要原理,以 hash 形式(也可以使用 History API 来处理)为例,当 url 的 hash 发生变化时,触发 hashchange 注册的回调,回调中去进行不同的操作,进行不同的内容的展示。直接看代码或许更直观。
function Router() { this.routes = {}; this.currentUrl = '';}Router.prototype.route = function(path, callback) { this.routes[path] = callback || function(){};};Router.prototype.refresh = function() { this.currentUrl = location.hash.slice(1) || '/'; this.routes[this.currentUrl]();};Router.prototype.init = function() { window.addEventListener('load', this.refresh.bind(this), false); window.addEventListener('hashchange', this.refresh.bind(this), false);}window.Router = new Router();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 anythingfunction changeBgColor(color) { content.style.backgroundColor = color;}Router.route('/', function() { changeBgColor('white');});Router.route('/blue', function() { changeBgColor('blue');});Router.route('/green', function() { changeBgColor('green');});
5 0
- 原生JS实现一个简单的前端路由(路由实现的原理)
- 前端路由的实现原理
- Javascript 实现一个原生的路由系统
- 前端路由的两种实现原理
- 前端路由的两种实现原理
- 用director.js实现的前端路由
- 前端路由实现原理
- JS原生一步步实现前端路由和单页面应用
- 阿里巴巴校招2017前端笔试题目 -- 原生js/html5 实现一个路由
- 基于原生PHP的路由分配实现
- Director JS 实现前端路由
- Javascript实现前端简单路由
- 基于AngularJS前端路由,实现一个最简单的图片翻页查看器
- 前端路由的不同方法实现
- NS2上实现一个简单的路由协议
- 实现一个手动配置路由表的无线路由协议
- PHP正则路由的实现原理
- create-react-app路由的实现原理
- python函数中的参数
- 如何开发凤凰网资讯即时新闻采集爬虫
- COGS 621.[NOIP2011] 选择客栈 解题报告
- Xcode下使用Vim
- Activity的生命周期
- 原生JS实现一个简单的前端路由(路由实现的原理)
- C#异步编程
- ios 布局预览
- log4j框架logger的继承关系以及使用场景
- HDFS nnTop统计功能
- JAVA基础(30) Java代码finally语句到底是在return之前还是之后执行?
- hdu1816 Get Luffy Out *--二分 & 2-sat
- inode详解
- RPG Maker MV插件系统详解与如何编写插件