中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

全面解析JavaScript的Backbone.js框架中的Router路由
來源:易賢網 閱讀:1222 次 日期:2016-07-02 14:25:31
溫馨提示:易賢網小編為您整理了“全面解析JavaScript的Backbone.js框架中的Router路由”,方便廣大網友查閱!

這篇文章主要介紹了Backbone.js框架中的Router路由功能,Router在Backbone中相當于一個MVC框架中的Controller控制器功能,需要的朋友可以參考下

Backbone 中的 Router 充當路由的作用,控制 URL 的走向,當在 URL 中使用 # 標簽時生效。

定義 Router 至少需要一個 Router 和一個函數來映射特定的 URL,而且我們需要記住,在 Backbone 中,# 標簽后的任意字符都會被 Router 接收并解釋。

下面我們來定義一個 Router:

<script>

 var AppRouter = Backbone.Router.extend({

  routes: {

   "*actions": "defaultRoute" // 匹配 http://example.com/#anything-here

  }

 });

 // 實例化 Router

 var app_router = new AppRouter;

 app_router.on('route:defaultRoute', function(actions) {

  alert(actions);

 })

 // 打開 Backbone 的歷史記錄

 Backbone.history.start();

</script>

現在,我們就定義好了一個 Router 了,但此時 Router 并未匹配特定的 URL,接下來我們開始詳細講解 Router 是如何工作的。

動態路由選擇

Backbone 允許你定義帶有特定參數的 Router。例如,你可能希望通過一個特定的 id 接收一個 post,比如這樣一個 URL:"http://example.com/#/posts/12",一旦這個 Router 被激活,你就可以取得一個 id 為12的 post。接下來,我們就來定義這個 Router:

<script>

 var AppRouter = Backbone.Router.extend({

  routes: {

   "posts/:id": "getPost",

   "*actions": "defaultRoute" //Backbone 會根據順序匹配路由

  }

 });

 // 實例化 Router

 var app_router = new AppRouter;

 app_router.on('route:getPost', function (id) {

  // 注意,參數通過這里進行傳遞

  alert( "Get post number " + id ); 

 });

 app_router.on('route:defaultRoute', function (actions) {

  alert( actions ); 

 });

 // 打開 Backbone 的歷史記錄

 Backbone.history.start();

</script>

匹配規則

Backbone 使用兩種形式的變量來設置 Router 的匹配規則。第一種是 :,它可以匹配 URL 中斜杠之間的任意參數,另一種是 *,它用來匹配斜杠后面的所有部分。注意,由于第二種形式的模糊性大于第一種,所以它的匹配優先級最低。

任一形式匹配的結果會以參數的形式傳遞到相關的函數中,第一種規則可能返回一個或多個參數,第二種規則將整個匹配結果作為一個參數返回。

接下來,我們用實例來說明:

routes:{

 "posts/:id": "getPost",

 // <a >Example</a>

 "download/*path": "downloadFile",

 // <a >Download</a>

 ":route/:action": "loadView",

 // <a >Load Route/Action View</a>

},

app_router.on('route:getPost', function( id ){ 

 alert(id); // 匹配后,傳遞過來的參數為 12

});

app_router.on('route:downloadFile', function( path ){ 

 alert(path); // 匹配后,整個匹配結果作為一個參數返回,路徑為 user/images/hey.gif 

});

app_router.on('route:loadView', function( route, action ){ 

 alert(route + "_" + action); // 匹配后,傳遞過來兩個參數,此時會彈出 dashboard_graph 

});

你可能經常聽說“路由器”這個詞,但它常常是指一種網絡設備,這種設備是網絡連接、數據傳輸的導航和樞紐。而Backbone中的“路由器”功能與它類似,從上面的例子中你就能看出,它可以將不同的URL錨點導航到對應的Action方法。

(許多服務端Web框架中也提供了這樣的機制,但Backbone.Router更側重前端單頁應用的導航。)

Backbone的路由導航是由Backbone.Router和Backbone.History兩個類共同完成的:

Router類用于定義和解析路由規則,并將URL映射到Action。

History類用于監聽URL的變化,和觸發Action方法。

我們一般不會直接實例化一個History,因為我們在第一次創建Router實例時,會自動創建一個History的單例對象,你可以通過Backbone.history來訪問這個對象。

要使用路由功能,首先我們需要定義一個Router類來聲明需要監聽的URL規則和Action,在剛才的例子中,我們在定義時通過routes屬性來定義需要監聽的URL列表,其中Key表示URL規則,Value表示當URL處于該規則時所執行的Action方法。

Hash規則

URL規則表示當前URL中的Hash(錨點)片段,我們除了能在規則中指定一般的字符串外,還需要注意兩種特別的動態規則:

規則中以/(斜線)為分隔的一段字符串,在Router類內部會被轉換為表達式([^\/]+),表示以/(斜線)開頭的多個字符,如果在這一段規則中設置了:(冒號),則表示URL中這一段字符串將被作為參數傳遞給Action。

例如我們設置了規則topic/:id,當錨點為#topic/1023時,1023將被作為參數id傳遞給Action,規則中的參數名(:id)一般會和Action方法的形參名稱相同,雖然Router并沒有這樣的限制,但使用相同的參數名更容易讓人理解。

規則中的*(星號)會在Router內部被轉換為表達式(.*?),表示零個或多個任意字符,與:(冒號)規則相比,*(星號)沒有/(斜線)分隔的限制,就像我們在上面的例子中定義的*error規則一樣。

Router中的*(星號)規則在被轉換為正則表達式后使用非貪婪模式,因此你可以使用例如這樣的組合規則:*type/:id,它能匹配#hot/1023,同時會將hot和1023作為參數傳遞給Action方法。

上面介紹了規則的定義方式,這些規則都會對應一個Action方法名稱,該方法必須處于Router對象中。

在定義好Router類之后,我們需要實例化一個Router對象,并調用Backbone.history對象的start()方法,該方法會啟動對URL的監聽。在History對象內部,默認會通過onhashchange事件監聽URL中Hash(錨點)的變化,對于不支持onhashchange事件的瀏覽器(例如IE6),History會通過setInterval心跳的方式監聽。

pushState規則

Backbone.History還支持pushState方式的URL,pushState是HTML5提供的一種新特性,它能操作當前瀏覽器的URL(而不是僅僅改變錨點),同時不會導致頁面刷新,從而使單頁應用使用起來更像一套完整的流程。

要使用pushState特性,你需要先了解HTML5為該特性提供的一些方法和事件(這些方法都被定義在window.history對象中):

1.pushState():該方法可以將指定的URL添加一個新的history實體到瀏覽器歷史里

2.replaceState():該方法可以將當前的history實體替換為指定的URL

調用pushState()和replaceState()方法,僅僅是替換當前頁面的URL,而并不會真正轉到這個URL地址(當使用后退或前進按鈕時,也不會跳轉到該URL),我們可以通過onpopstate事件來監聽這兩個方法引起的URL變化。

路由相關方法

1.route()方法

在設定好路由規則之后,如果需要動態調整,可以調用Router.route()方法來動態添加路由規則及Action方法,例如:

router.route('topic/:pageno/:pagesize', 'page', function(pageno, pagesize){ 

 // todo 

}); 

我們調用route()方法時,給定的規則不僅僅可以是字符串,也可以是一個正則表達式:

router.route(/^topic/(.*?)/(.*?)$/, 'page', function(pageno, pagesize){ 

 // todo 

}); 

2.navigate()方法

在前面的例子中,URL規則都是由我們手動輸入觸發的,在實際應用中,有時可能需要手動進行跳轉、導航,這時可以調用

Router.navigate()方法進行控制,例如:

router.navigate('topic/1000', { 

 trigger: true

}); 

這段代碼將URL更改為http://localhost/index.html#topic/1000,并觸發了renderDetail方法。需要注意的是,我們在第二個參數傳入了trigger配置,該配置用于表示更改URL的同時是否觸發相應的Action方法。

3.stop()方法

還記得我們是通過Backbone.history.start()方法來啟動路由監聽的,你也可以隨時調用Backbone.history.stop()方法來停止監聽,例如:

router.route('topic/:pageno/:pagesize', 'page', function(pageno, pagesize) { 

 Backbone.history.stop(); 

}); 

運行這段代碼,并訪問URL:http://localhost/index.html#topic/5/20,你會發現這個Action被執行之后,監聽已經不再生效了。

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久久久国产免费免费| 亚洲大片精品永久免费| 欧美日韩国产天堂| 亚洲国产欧美另类丝袜| 欧美高清视频在线播放| 亚洲精品乱码久久久久久黑人| 欧美韩日一区| 一区二区三区四区五区视频| 国产精品尤物| 欧美**字幕| 亚洲精品在线一区二区| 国产精品v欧美精品v日本精品动漫 | 欧美日韩一区二区三区视频| 亚洲一区二区黄色| 国产在线成人| 欧美福利视频在线| 欧美亚洲在线视频| 亚洲黄色成人久久久| 国产精品久久激情| 久久综合九色综合网站| 亚洲淫性视频| 91久久久久久久久久久久久| 国产欧美韩日| 欧美极品一区二区三区| 欧美一级免费视频| 日韩视频一区二区在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品成人在线| 久久国产精品第一页| 99视频一区| 亚洲国产91精品在线观看| 国产精品欧美一区喷水| 欧美激情精品久久久久久蜜臀| 欧美一区2区视频在线观看| 日韩一级片网址| 在线观看亚洲a| 国产欧美一区二区三区视频| 欧美日韩三区四区| 欧美福利专区| 欧美成人久久| 久久久久国内| 欧美在线视频免费| 午夜精品视频在线| 亚洲午夜精品一区二区| 亚洲精选一区| 亚洲精品美女| 亚洲激情网站免费观看| 影音欧美亚洲| 亚洲成人中文| 亚洲国产视频直播| 亚洲国产日韩在线| 在线精品国产成人综合| 在线播放中文字幕一区| 黄色成人片子| 精品电影在线观看| 在线观看成人av电影| 尤物视频一区二区| 伊人久久大香线| 在线观看视频一区| 亚洲欧洲精品一区二区| 亚洲国产清纯| 日韩一区二区高清| 日韩亚洲精品在线| 99精品国产高清一区二区| 亚洲日产国产精品| 亚洲美女免费精品视频在线观看| 亚洲高清精品中出| 亚洲激情国产| 夜夜夜久久久| 亚洲免费人成在线视频观看| 亚洲一本大道在线| 亚洲欧美一区二区三区在线| 欧美一区二区三区免费观看| 久久久久久网| 欧美精品1区| 国产精品豆花视频| 国产亚洲欧美另类一区二区三区| 国产一区二区中文字幕免费看| 在线观看91精品国产入口| 亚洲欧洲另类国产综合| 亚洲一区二区三区免费在线观看 | 国产三级欧美三级| 狠狠爱综合网| 亚洲精品视频在线看| 亚洲五月六月| 久久精品麻豆| 欧美日韩亚洲一区| 国产午夜精品理论片a级探花| 亚洲电影中文字幕| 一区二区三区四区五区视频| 久久福利电影| 欧美日韩少妇| 黄色国产精品| 一区二区三区四区五区精品| 久久xxxx精品视频| 欧美国产亚洲视频| 国产婷婷97碰碰久久人人蜜臀| 亚洲国产精品123| 亚洲欧美日韩一区二区在线| 美日韩在线观看| 国产精品视频| 亚洲精品中文字幕有码专区| 久久成人国产| 欧美系列亚洲系列| 亚洲高清资源综合久久精品| 亚洲在线中文字幕| 欧美激情中文不卡| 在线播放中文一区| 亚洲欧美另类国产| 欧美国产日韩二区| 国产一区香蕉久久| 亚洲美女电影在线| 香蕉久久一区二区不卡无毒影院| 欧美第一黄色网| 国产一区二区三区久久悠悠色av| 日韩亚洲成人av在线| 乱码第一页成人| 国产欧美一区二区三区沐欲| 中文欧美字幕免费| 欧美日本一区二区高清播放视频| 激情综合网址| 久久精品二区三区| 国产伦精品一区二区三区| 亚洲视频久久| 欧美日韩精品免费观看视频完整| 一区在线视频| 欧美在线高清| 国产一区二区中文| 性欧美xxxx大乳国产app| 欧美午夜一区二区三区免费大片 | 亚洲美女精品久久| 久久久久久亚洲精品中文字幕| 国产欧美日韩一区二区三区在线 | 美女主播一区| 狠狠色香婷婷久久亚洲精品| 久久黄色网页| 国产伊人精品| 亚洲欧美另类中文字幕| 国产精品福利在线观看| 亚洲欧美不卡| 国产视频欧美| 久久久爽爽爽美女图片| 狠狠色丁香久久婷婷综合丁香| 欧美一区影院| 国产午夜精品一区二区三区欧美| 午夜亚洲福利| 国内成+人亚洲| 另类天堂av| 亚洲三级影片| 欧美精品激情blacked18| 中文成人激情娱乐网| 国产精品久线观看视频| 亚洲欧美在线磁力| 黄色成人在线| 欧美激情精品久久久久久久变态| 亚洲免费观看视频| 国产精品久久久久久久久久免费| 欧美一区二区三区免费在线看| 激情六月综合| 欧美日韩亚洲一区二| 亚洲视频播放| 国产一区二区主播在线| 欧美黑人多人双交| 午夜性色一区二区三区免费视频| 狠狠色丁香婷婷综合影院| 欧美激情视频一区二区三区不卡| 洋洋av久久久久久久一区| 国产精品久久久亚洲一区| 久久精品成人一区二区三区蜜臀| 亚洲电影免费观看高清完整版在线| 欧美精品系列| 性18欧美另类| 日韩视频久久| 国产香蕉97碰碰久久人人| 久久嫩草精品久久久精品| 亚洲欧洲视频| 国产日韩亚洲| 欧美日韩成人| 久久精品国产久精国产爱| 亚洲乱码视频| 国语精品一区| 国产精品久久久久国产a级| 毛片精品免费在线观看| 亚洲欧美日韩精品在线| 亚洲国产精品久久久久婷婷884| 国产精品国产三级国产a| 久久免费视频观看| 亚洲影视综合| 日韩亚洲在线| 尤物精品在线| 国产欧美日韩一区二区三区在线| 麻豆9191精品国产| 欧美一级网站| 中国女人久久久| 亚洲精品一区二区三区四区高清| 韩曰欧美视频免费观看| 国产日产欧美精品| 欧美性猛交xxxx免费看久久久| 巨乳诱惑日韩免费av| 久久久久青草大香线综合精品|