首页 > 代码库 > 实现自定义路由
实现自定义路由
本文实现自定路由,主要是事件hashchange的使用,然后根据我们的业务需求封装。
首先实现一个router的类,并实例化。
function _router(config){ this.config = config ? config : {}; } _router.prototype = { event:function(str,callback){ var events = str.split(‘ ‘); for (var i in events) window.addEventListener(events[i],callback,false); },init: function() { this.event(‘load hashchange‘,this.refresh.bind(this)); return this;},refresh: function() { this.currentUrl = location.hash.slice(1) || ‘/‘; this.config[this.currentUrl]();},route: function(path,callback){ this.config[path] = callback || function(){};}}function router (config){ return new _router(config).init();}
上边唯一需要注意的是,在使用addEventListener的时候,需要注意bind函数的使用,因为我是踩了坑,这才体会到$.proxy()。
上边使用的时候可以使用两种方法进行注册,但第二种是依赖第一种的。
方法一:
var Router = router({ ‘/‘ : function(){content.style.backgroundColor = ‘white‘;}, ‘/1‘: function(){content.style.backgroundColor = ‘blue‘;}, ‘/2‘: function(){content.style.backgroundColor = ‘green‘;}})
方法二:
Router.route(‘/3‘,function(){ content.style.backgroundColor = ‘yellow‘; })
完整代码:
<html> <head> <title></title> </head> <body> <ul> <li><a href="http://www.mamicode.com/#/1">/1: blue</a></li> <li><a href="http://www.mamicode.com/#/2">/2: green</a></li> <li><a href="http://www.mamicode.com/#/3">/3: yellow</a></li> </ul> <script> var content = document.querySelector(‘body‘); function _router(config){ this.config = config ? config : {}; } _router.prototype = { event:function(str,callback){ var events = str.split(‘ ‘); for (var i in events) window.addEventListener(events[i],callback,false); }, init: function() { this.event(‘load hashchange‘,this.refresh.bind(this)); return this; }, refresh: function() { this.currentUrl = location.hash.slice(1) || ‘/‘; this.config[this.currentUrl](); }, route: function(path,callback){ this.config[path] = callback || function(){}; } } function router (config){ return new _router(config).init(); } var Router = router({ ‘/‘ : function(){content.style.backgroundColor = ‘white‘;}, ‘/1‘: function(){content.style.backgroundColor = ‘blue‘;}, ‘/2‘: function(){content.style.backgroundColor = ‘green‘;} }) Router.route(‘/3‘,function(){ content.style.backgroundColor = ‘yellow‘; }) </script> </body></html><script> </script>
实现自定义路由
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。