这篇文章主要讲解了“Javascript中如何实现前端路由”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Javascript中如何实现前端路由”吧!页面中有一个导航菜单ul,和一个p#result用来显示结果,当点击导航菜单时,#result中会显示不同的结果内容。
- 首页
- 产品
- 服务
说一下前端路由实现的简要原理,以 hash 形式(也可以使用 History API 来处理)为例,当 url 的 hash 发生变化时,触发 hashchange 注册的回调,回调中去进行不同的操作,进行不同的内容的展示。function Router(){ this.routes = {}; this.curUrl = ''; this.route = function(path, callback){ this.routes[path] = callback || function(){}; }; this.refresh = function(){ this.curUrl = location.hash.slice(1) || '/'; th 香港云主机is.routes[this.curUrl](); }; this.init = function(){ window.addEventListener('load', this.refresh.bind(this), false); window.addEventListener('hashchange', this.refresh.bind(this), false); } }
上面代码中路由系统Router对象实现,主要提供三个方法:init监听浏览器 url hash 更新事件。route存储路由更新时的回调到回调数组routes中,回调函数将负责对页面的更新。refresh执行当前url对应的回调函数,更新页面。Router调用方式如下:点击触发 url 的 hash 改变,并对应地更新内容,运行后你会发现每次点击菜单时,#result中会变换背景色和内容。var R = new Router(); R.init(); var res = document.getElementById('result'); R.route('/', function() { res.style.background = 'blue'; res.innerHTML = '这是首页'; }); R.route('/product', function() { res.style.background = 'orange'; res.innerHTML = '这是产品页'; }); R.route('/server', function() { res.style.background = 'black'; res.innerHTML = '这是服务页'; });
感谢各位的阅读,以上就是“Javascript中如何实现前端路由”的内容了,经过本文的学习后,相信大家对Javascript中如何实现前端路由这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是开发云,小编将为大家推送更多相关知识点的文章,欢迎关注!
这篇文章主要讲解了“电脑鼠标不能动了如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“电脑鼠标不能动了如何解决”吧!方法一、强制关机这种问题一般是卡机了,可以通过长按电源键强制关机即可,一般即可正常启动,如…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。