<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識

        來源:懂視網 責編:小采 時間:2020-11-27 21:50:02
        文檔

        全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識

        全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識:Backbone 中的 Router 充當路由的作用,控制 URL 的走向,當在 URL 中使用 # 標簽時生效。 定義 Router 至少需要一個 Router 和一個函數來映射特定的 URL,而且我們需要記住,在 Backbone 中,# 標簽后的任意字符都會被 Router 接收并解釋。 下面
        推薦度:
        導讀全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識:Backbone 中的 Router 充當路由的作用,控制 URL 的走向,當在 URL 中使用 # 標簽時生效。 定義 Router 至少需要一個 Router 和一個函數來映射特定的 URL,而且我們需要記住,在 Backbone 中,# 標簽后的任意字符都會被 Router 接收并解釋。 下面

        Backbone 中的 Router 充當路由的作用,控制 URL 的走向,當在 URL 中使用 # 標簽時生效。
        定義 Router 至少需要一個 Router 和一個函數來映射特定的 URL,而且我們需要記住,在 Backbone 中,# 標簽后的任意字符都會被 Router 接收并解釋。
        下面我們來定義一個 Router:

        
        

        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方法,例如:

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

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

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

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

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識

        全面解析JavaScript的Backbone.js框架中的Router路由_基礎知識:Backbone 中的 Router 充當路由的作用,控制 URL 的走向,當在 URL 中使用 # 標簽時生效。 定義 Router 至少需要一個 Router 和一個函數來映射特定的 URL,而且我們需要記住,在 Backbone 中,# 標簽后的任意字符都會被 Router 接收并解釋。 下面
        推薦度:
        標簽: js 路由 基礎知識
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: jizz中国免费| 久久免费精品视频| 一级毛片在线免费视频| 少妇太爽了在线观看免费视频| 国内精品免费麻豆网站91麻豆| 亚洲成a人片在线观看久| 中文字幕亚洲精品| 日韩a毛片免费观看| 亚洲人成电影网站免费| 亚洲av永久无码精品秋霞电影影院| 亚洲精华液一二三产区| 99久久99久久精品免费观看| 亚洲成A人片在线观看中文| 爱情岛论坛免费视频| a毛片基地免费全部视频| 亚洲已满18点击进入在线观看| 国产精品免费一区二区三区四区| 免费一级一片一毛片| 中文字幕 亚洲 有码 在线| 在线a毛片免费视频观看| 亚洲国产精品yw在线观看| 免费人成黄页在线观看日本| 亚洲三级电影网址| 大地资源网高清在线观看免费| 免费一看一级毛片全播放| 中文字幕在线视频免费观看| 国产大片免费观看中文字幕| 亚洲一区二区三区深夜天堂| 99精品免费观看| 国产午夜亚洲精品国产| 无码人妻久久一区二区三区免费丨 | 亚洲精品一级无码鲁丝片| 亚洲人成网站在线播放2019| 麻豆视频免费观看| 亚洲福利视频网站| 18禁男女爽爽爽午夜网站免费 | 久久久久亚洲精品成人网小说| 一级毛片a免费播放王色电影 | 成人性生交视频免费观看| 亚洲91精品麻豆国产系列在线| 国产精品免费视频一区|