前端路由的简单实现

单页应用中,页面的跳转如果只是通过js控制时,浏览器的前进/后退会离开当前url。另外通过url收藏当前页面后重新打开时会跳到应用的初始状态。

用前端路由的方法可以解决上述问题。url的hash部分改变,不会反生页面跳转,但会触发hashchange事件,再通过js显示不同的组件。
简单实现如下:

<ul>
    <li><a href="#/detail">detail</a></li>
    <li><a href="#/error">error</a></li>
</ul>

 

function Router() {
    this.routes = {};//存储hash和方法的映射
    this.currentUrl = '';
}
//注册路径和方法的映射
Router.prototype.route = function(path, callback) {
    this.routes[path] = callback;
};
//hash改变时触发的事件
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.route('/', function() { console.log("主页"); }); Router.route('/detail', function() { console.log("跳转到详情页"); }); Router.route('/error', function() { console.log("出错了"); });

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值