日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

JS實現(xiàn)前端路由功能示例【原生路由】

瀏覽:159日期:2024-05-06 13:14:30

本文實例講述了JS實現(xiàn)前端路由功能。分享給大家供大家參考,具體如下:

路由就是根據(jù)不同的 url 地址展示不同的內(nèi)容或頁面,早期路由的概念是在后端出現(xiàn)的,通過服務(wù)器端渲染后返回頁面,隨著頁面越來越復(fù)雜,服務(wù)器端壓力越來越大。后來ajax異步刷新的出現(xiàn)使得前端也可以對url進行管理,此時,前端路由就出現(xiàn)了。

單頁面就是有前端路由來實現(xiàn)的,也就是說網(wǎng)站只有一個頁面,點擊導(dǎo)航會顯示不同的內(nèi)容,對應(yīng)的url也在發(fā)生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內(nèi)容。

JS實現(xiàn)前端路由功能示例【原生路由】

路由實現(xiàn)的原理:window綁定了監(jiān)聽函數(shù),當url的hash值發(fā)生變化的時候會觸發(fā)hashchange回調(diào),在回調(diào)中進行不同的操作,馬上刷新頁面,從而顯示不同的頁面。

下面是一個前端路由的簡單實現(xiàn):通過路由實現(xiàn)url的切換、頁面內(nèi)容的改變。

index.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta http-equiv='X-UA-Compatible' content='ie=edge'> <title>前端路由測試</title> <script src='https://www.jq22.com/jquery/jquery-3.3.1.js'></script> <style> *{margin:0;padding: 0; } .content{width: 500px;height: 300px;margin-top: 30px;margin:20px auto 0; } #click_btn{width: 500px;height: 50px;margin:100px auto 0; } #click_btn a{display: block;background: #333;color: #fff;text-decoration: none;line-height: 50px;text-align: center;float: left;margin-right: 15px;padding: 0px 15px; } #click_btn a:hover{background: #666; } </style> </head><body><div id='click_btn'> <a href='http://m.b3g6.com/bcjs/14619.html#/one' rel='external nofollow' >第一個頁面</a> <a href='http://m.b3g6.com/bcjs/14619.html#/two' rel='external nofollow' >第二個頁面</a> <a href='http://m.b3g6.com/bcjs/14619.html#/three' rel='external nofollow' >第三個頁面</a></div><div class='content'></div> <script src='http://m.b3g6.com/bcjs/router.js'></script><script src='http://m.b3g6.com/bcjs/test.js'></script> </body></html>

router.js

//構(gòu)造函數(shù)function Router() { this.routes = {}; this.currentUrl = ’’;}Router.prototype.route = function(path, callback) { this.routes[path] = callback || function(){};//給不同的hash設(shè)置不同的回調(diào)函數(shù)};Router.prototype.refresh = function() { console.log(location.hash.slice(1));//獲取到相應(yīng)的hash值 this.currentUrl = location.hash.slice(1) || ’/’;//如果存在hash值則獲取到,否則設(shè)置hash值為/ // console.log(this.currentUrl); if(this.currentUrl&&this.currentUrl!=’/’){ this.routes[this.currentUrl]();//根據(jù)當前的hash值來調(diào)用相對應(yīng)的回調(diào)函數(shù) } };Router.prototype.init = function() { window.addEventListener(’load’, this.refresh.bind(this), false); window.addEventListener(’hashchange’, this.refresh.bind(this), false);}//給window對象掛載屬性window.Router = new Router();window.Router.init();

test.js

Router.route(’/one’, function () { $('.content').html('<p>路由就是根據(jù)不同的 url 地址展示不同的內(nèi)容或頁面,早期路由的概念是在后端出現(xiàn)的,通過服務(wù)器端渲染后返回頁面,隨著頁面越來越復(fù)雜,服務(wù)器端壓力越來越大。后來ajax異步刷新的出現(xiàn)使得前端也可以對url進行管理,此時,前端路由就出現(xiàn)了。</p>');});Router.route(’/two’, function () { $('.content').html('<h3>單頁面就是有前端路由來實現(xiàn)的,也就是說網(wǎng)站只有一個頁面,點擊導(dǎo)航會顯示不同的內(nèi)容,對應(yīng)的url也在發(fā)生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內(nèi)容。</h3>');});Router.route(’/three’, function () { $('.content').html('<img src=’https://upload-images.jianshu.io/upload_images/12890819-f8665293cc8d0dcf.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp’ width=’500’/>');});

注意:router.js要在test.js之前進行調(diào)用,不然會先加載test.js從而找不到,出現(xiàn)router.js未被定義。

上面router對象實現(xiàn)主要提供了三個方法

1.init監(jiān)聽瀏覽器url的hash值更新事件。

2.route存儲路由更新時的回調(diào)到回調(diào)數(shù)組routes中,回掉函數(shù)將負責對頁面進行更新。

3.refresh執(zhí)行當前url的回調(diào)函數(shù),更新頁面。

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調(diào)試運行工具:http://tools.jb51.net/code/WebCodeRun測試上述代碼運行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

標簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产成人免费| 久久久精品日韩| 午夜国产精品视频| 国产欧美一区二区三区精品酒店| 日韩有吗在线观看| 亚洲ab电影| 国产美女一区| 久久中文字幕av一区二区不卡| 日韩国产一区| 国产无遮挡裸体免费久久| 国产专区一区| 中文在线中文资源| 精品国产亚洲日本| 久久不见久久见中文字幕免费 | 亚洲尤物av| 99国产精品| 欧美成人久久| 日韩高清不卡| 欧美成a人免费观看久久| 亚洲国内欧美| 色婷婷精品视频| 日韩美女一区二区三区在线观看| 国产精品99视频| 久久精品九色| 美女av一区| 日韩欧美二区| 久久精品免费一区二区三区| a日韩av网址| 婷婷综合在线| 国产精品普通话对白| 一本色道精品久久一区二区三区| 一区二区精彩视频| 亚洲人成毛片在线播放女女| 水野朝阳av一区二区三区| 玖玖精品视频| 视频国产精品| 国产欧美亚洲一区| 精品一二三区| 成人国产综合| 久久久久99| 日韩在线卡一卡二| 亚洲日产国产精品| 开心激情综合| 精品一区视频| 亚洲三级欧美| 丝瓜av网站精品一区二区| 婷婷综合福利| 国产探花一区| 久久国产小视频| 国产午夜久久| 亚洲毛片在线| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 只有精品亚洲| 国产欧美大片| 成人精品国产亚洲| 91精品国产乱码久久久久久久| 最新国产拍偷乱拍精品| 亚洲午夜久久| 婷婷综合电影| 色婷婷综合网| 在线精品视频在线观看高清| 亚洲精品精选| 日韩一区二区三区免费播放| 欧美福利在线| 中文一区一区三区免费在线观| 国产一区2区| 久久在线电影| 日韩一区二区三区精品| 精品亚洲美女网站| 亚洲毛片在线| 精品高清久久| 亚洲一区二区免费在线观看| 国产精品地址| 激情黄产视频在线免费观看| 日韩影院免费视频| 国产激情欧美| 精品一区在线| 久久一区亚洲| 黄色亚洲大片免费在线观看| 香蕉久久久久久| 特黄毛片在线观看| 亚洲男人在线| 午夜欧美精品| 欧美aⅴ一区二区三区视频| 尹人成人综合网| 国产精品红桃| 欧美精品一卡| 97精品国产| 亚洲欧美日韩国产一区二区| 亚洲女同av| 日韩不卡免费视频| 日韩理论片av| 亚州精品视频| 欧美xxxx中国| 欧美午夜三级| 一区久久精品| 亚洲高清久久| 国产精品一区高清| 亚洲一级网站| 伊人久久国产| 欧美日本不卡| 日本亚洲欧洲无免费码在线| 久久精品导航| 精品三级av| 亚洲精品麻豆| 欧美/亚洲一区| 视频小说一区二区| 里番精品3d一二三区| 国产日韩中文在线中文字幕 | 国产亚洲字幕| 综合激情网站| 欧美亚洲精品在线| 麻豆高清免费国产一区| 久久国产尿小便嘘嘘| 中文日韩欧美| 红桃视频国产精品| 亚洲91精品| 久久99精品久久久久久园产越南| 亚洲综合三区| 亚洲自啪免费| 在线视频观看日韩| 国产精品宾馆| 国产伦精品一区二区三区在线播放 | 欧美日韩亚洲国产精品| 国产精品嫩草99av在线| 国产精品7m凸凹视频分类| 国产精品成人a在线观看| 日本成人在线视频网站| 日韩一区二区三区在线看| 国产精品视区| 成人av动漫在线观看| 一本色道精品久久一区二区三区| 老牛影视精品| 欧美日韩色图| 91精品亚洲| av在线资源| 91偷拍一区二区三区精品| 欧美激情福利| 国产亚洲精品美女久久 | 国产精品伊人| 国产精品红桃| 欧美日韩在线精品一区二区三区激情综合 | 激情欧美日韩一区| 蜜桃tv一区二区三区| 色在线视频观看| 国产精品高颜值在线观看| 成人在线免费观看网站| 美日韩一区二区三区| 久久精品凹凸全集| 欧美91在线|欧美| 国产亚洲一区二区三区啪| 在线精品国产亚洲| 日韩av中文字幕一区二区三区| 人人爽香蕉精品| 深夜福利亚洲| 亚洲香蕉视频| 中文字幕一区二区精品区| 88久久精品| 国产日产精品_国产精品毛片| 国产日韩欧美在线播放不卡| 久久99久久久精品欧美| 国产精品亚洲一区二区在线观看| 日本不卡一区二区| 久久影院资源站| 欧美xxxx中国| 在线视频免费在线观看一区二区| 麻豆久久精品| 亚洲日韩中文字幕一区| 亚洲人成高清| 国产精品久久久亚洲一区| 国产一区二区三区黄网站| 久久这里只有精品一区二区| 久久黄色影院| 一本色道精品久久一区二区三区| 婷婷综合成人| 国产毛片精品| 国产黄色精品| 91精品久久久久久久久久不卡| 波多野结衣一区| 青青草国产精品亚洲专区无| 国产精品美女午夜爽爽| 水蜜桃久久夜色精品一区| 国产美女一区| 国产欧美自拍| 精品国产亚洲一区二区三区在线| 久久精品123| 快she精品国产999| 欧美黑人巨大videos精品| 亚洲综合电影| 91成人精品| 久久爱www.| 日韩免费久久| 欧美日韩一二| 国产日韩中文在线中文字幕| 日韩综合一区| 五月激激激综合网色播| 久久不见久久见免费视频7| 久久久久网站| 巨乳诱惑日韩免费av| 国产毛片精品|