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

您的位置:首頁技術文章
文章詳情頁

JS實現前端路由功能示例【原生路由】

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

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

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

單頁面就是有前端路由來實現的,也就是說網站只有一個頁面,點擊導航會顯示不同的內容,對應的url也在發生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內容。

JS實現前端路由功能示例【原生路由】

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

下面是一個前端路由的簡單實現:通過路由實現url的切換、頁面內容的改變。

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://www.b3g6.com/bcjs/14619.html#/one' rel='external nofollow' >第一個頁面</a> <a href='http://www.b3g6.com/bcjs/14619.html#/two' rel='external nofollow' >第二個頁面</a> <a href='http://www.b3g6.com/bcjs/14619.html#/three' rel='external nofollow' >第三個頁面</a></div><div class='content'></div> <script src='http://www.b3g6.com/bcjs/router.js'></script><script src='http://www.b3g6.com/bcjs/test.js'></script> </body></html>

router.js

//構造函數function Router() { this.routes = {}; this.currentUrl = ’’;}Router.prototype.route = function(path, callback) { this.routes[path] = callback || function(){};//給不同的hash設置不同的回調函數};Router.prototype.refresh = function() { console.log(location.hash.slice(1));//獲取到相應的hash值 this.currentUrl = location.hash.slice(1) || ’/’;//如果存在hash值則獲取到,否則設置hash值為/ // console.log(this.currentUrl); if(this.currentUrl&&this.currentUrl!=’/’){ this.routes[this.currentUrl]();//根據當前的hash值來調用相對應的回調函數 } };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>路由就是根據不同的 url 地址展示不同的內容或頁面,早期路由的概念是在后端出現的,通過服務器端渲染后返回頁面,隨著頁面越來越復雜,服務器端壓力越來越大。后來ajax異步刷新的出現使得前端也可以對url進行管理,此時,前端路由就出現了。</p>');});Router.route(’/two’, function () { $('.content').html('<h3>單頁面就是有前端路由來實現的,也就是說網站只有一個頁面,點擊導航會顯示不同的內容,對應的url也在發生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內容。</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之前進行調用,不然會先加載test.js從而找不到,出現router.js未被定義。

上面router對象實現主要提供了三個方法

1.init監聽瀏覽器url的hash值更新事件。

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

3.refresh執行當前url的回調函數,更新頁面。

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

更多關于JavaScript相關內容可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結》

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

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本欧洲一区二区| 久久精品高清| 蜜臀久久99精品久久一区二区| 日韩精品一区二区三区免费观影| 国产亚洲一区| 精品在线网站观看| 日韩区一区二| 少妇精品久久久一区二区| 日韩av不卡在线观看| 麻豆传媒一区二区三区| 久久只有精品| 成人在线网站| 免费在线观看精品| 欧美精品观看| 日韩综合在线| 另类激情亚洲| 国产精品chinese| 日本综合字幕| 亚洲美女久久| 久久影院资源站| 在线日韩av| 91久久在线| 国产美女精品视频免费播放软件| 欧美激情 亚洲a∨综合| 午夜欧美巨大性欧美巨大| 一本色道精品久久一区二区三区| 丝袜美腿亚洲色图| 久久精品系列| 欧美综合二区| 涩涩av在线| 日本欧美韩国一区三区| 久久久久国产一区二区| 国产精品一区二区av交换| 亚洲视频播放| 首页国产精品| 国产精品日韩精品中文字幕| 国产成人精品一区二区三区视频| av不卡免费看| 欧美成人基地| 国产精品qvod| 亚洲精品日韩久久| 婷婷亚洲综合| 97精品一区二区| 国产精品欧美三级在线观看| 国产精品普通话对白| 国产传媒在线观看| 国产精品入口久久| 亚洲精品大片| 国产视频亚洲| 99国产精品私拍| 1000部精品久久久久久久久| 亚洲+小说+欧美+激情+另类| 亚洲高清毛片| 久久激情一区| 激情国产在线| 国内在线观看一区二区三区| 国产劲爆久久| 久久伊人久久| 久久久精品国产**网站| 欧美亚洲三区| 青青在线精品| 国产精品2区| 久久精品国产99国产精品| 你懂的亚洲视频| 成人在线超碰| 群体交乱之放荡娇妻一区二区| 日本一不卡视频| 久久精品99国产精品日本| 国产亚洲字幕| 国产999精品在线观看| se01亚洲视频 | 99riav1国产精品视频| 在线日韩视频| 成人在线视频免费看| 成人在线免费观看网站| 国产精品xx| 亚洲性色视频| 亚洲精品成人一区| 精品美女在线视频| 中文字幕在线看片| 国产一级久久| 欧美激情精品| 婷婷中文字幕一区| 色狠狠一区二区三区| 久久不见久久见免费视频7| 国产+成+人+亚洲欧洲在线| 久久精品不卡| 视频在线在亚洲| 综合激情视频| 久久亚州av| 伊人精品视频| 欧美成人精品午夜一区二区| 亚洲欧洲高清| 久久精品97| 国内精品99| 精品国产亚洲一区二区三区在线| 伊人久久国产| 日韩高清二区| 欧美日韩精品免费观看视欧美高清免费大片 | 午夜在线观看免费一区| 国产伦精品一区二区三区在线播放| 亚洲精品88| 国产精品tv| 亚洲影院天堂中文av色| 电影亚洲精品噜噜在线观看| 日本aⅴ精品一区二区三区 | 国产精品videosex极品| 亚洲色图国产| 99国产精品久久久久久久| 毛片在线网站| 精品网站999| 欧美亚洲一区二区三区| 国语对白精品一区二区| 青青草精品视频| 一本色道精品久久一区二区三区| 91免费精品| 久久精品一区| 麻豆高清免费国产一区| 国产乱码精品| 国产激情久久| 国产精品久久久亚洲一区| 国产美女久久| 欧美精品91| 精品一区二区三区亚洲| 欧美日韩1区| 国产精品99精品一区二区三区∴| 欧美日韩中出| 亚洲精选久久| 婷婷久久免费视频| 日本视频在线一区| 国产精品白丝久久av网站| 美日韩一区二区三区| 国产一区二区色噜噜| 日韩毛片视频| 国产手机视频一区二区| 六月丁香综合| 国产欧美一区二区三区精品观看 | 国产日韩欧美三区| 日本在线成人| 国产精品日本一区二区不卡视频| 91嫩草精品| 欧美国产中文高清| 日韩福利一区| 午夜欧美精品| 日韩精品欧美大片| 国产精品3区| 999久久久免费精品国产| 免费久久99精品国产| 国产剧情在线观看一区| 特黄毛片在线观看| 一区二区亚洲精品| 国产精品色婷婷在线观看| 久久久久久网| 亚洲小说欧美另类婷婷| 亚洲精品系列| 裤袜国产欧美精品一区| 亚洲精品系列| 999国产精品视频| 国产精品一区二区av交换| re久久精品视频| 麻豆一区在线| 欧美美女一区| 国产精品qvod| 日韩综合一区二区| 亚洲成人va| 久久成人av| 日本亚洲最大的色成网站www| 欧美gv在线| 综合激情在线| 亚洲国内欧美| 色一区二区三区四区| 97精品久久| 亚洲精品四区| 香蕉久久国产| 亚洲一级特黄| 欧美天堂视频| 国产一区二区三区四区五区| 日本成人中文字幕| 日韩中文字幕91| 欧美日韩激情| 欧美va天堂| 国产综合色区在线观看| 国产一区二区久久久久| 免播放器亚洲一区| 一区三区视频| 夜夜精品视频| 久久av在线| 在线视频亚洲欧美中文| 日韩中文欧美在线| 蜜臀久久99精品久久久久宅男| 亚洲va中文在线播放免费| 色天使综合视频| 激情偷拍久久| 久久国产99| 亚洲久久视频| 欧美一区不卡| 精品日产乱码久久久久久仙踪林| 国产剧情一区| 欧美亚洲福利| 国产极品嫩模在线观看91精品|