本文实现自定路由,主要是事件hashchange的使用,然后根据我们的业务需求封装。

首先实现一个router的类,并实例化。

移动开发培训,Android培训,安卓培训,手机开发培训,手机维修培训,手机软件培训

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();
}

移动开发培训,Android培训,安卓培训,手机开发培训,手机维修培训,手机软件培训

 

上边唯一需要注意的是,在使用addEventListener的时候,需要注意bind函数的使用,因为我是踩了坑,这才体会到$.proxy()。

上边使用的时候可以使用两种方法进行注册,但第二种是依赖第一种的。

方法一:

var Router = router({
    '
        
		

网友评论