欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

AngularJS入門教程之路由機(jī)制ngRoute實(shí)例分析

 更新時(shí)間:2016年12月13日 09:53:53   作者:鄭浩-  
這篇文章主要介紹了AngularJS入門教程之路由機(jī)制ngRoute,結(jié)合實(shí)例形式分析了AngularJS路由機(jī)制的原理、ngRoute的組成、配置、參數(shù)與相關(guān)使用技巧,需要的朋友可以參考下

本文實(shí)例講述了AngularJS路由機(jī)制ngRoute。分享給大家供大家參考,具體如下:

引言

在我們介紹路由之前我們首先談一下SPA,所以SPA就是我們現(xiàn)在經(jīng)常說的單頁應(yīng)用single page APP,為了實(shí)現(xiàn)無刷新的視圖切換我們之前的做法就是利用AJAX從后取出數(shù)據(jù)然后渲染在前臺(tái)頁面HTML中,但是AJAX有一個(gè)致命的缺點(diǎn)就是不能實(shí)現(xiàn)瀏覽器的后退按鈕失效,為了解決這個(gè)問題我們通常使用hash,監(jiān)聽hashchange事件來進(jìn)行視圖切換,另一個(gè)方法是用HTML5的history API,通過pushState()記錄操作歷史,監(jiān)聽popstate事件來進(jìn)行視圖切換,也有人把這叫pjax技術(shù)?;玖鞒倘缦拢?/p>

如此一來,便形成了通過地址欄進(jìn)行導(dǎo)航的深度鏈接(deeplinking ),也就是我們所需要的路由機(jī)制。通過路由機(jī)制,一個(gè)單頁應(yīng)用的各個(gè)視圖就可以很好的組織起來了。

ng-route包含的內(nèi)容

ng的路由機(jī)制是靠ngRoute提供的,通過hash和history兩種方式實(shí)現(xiàn)了路由,可以檢測(cè)瀏覽器是否支持history來靈活調(diào)用相應(yīng)的方式。ng的路由(ngRoute)是一個(gè)單獨(dú)的模塊,包含以下內(nèi)容:

•服務(wù)$routeProvider用來定義一個(gè)路由表,即地址欄與視圖模板的映射

•服務(wù)$routeParams保存了地址欄中的參數(shù),例如{id : 1, name : 'tom'}

•服務(wù)$location用來實(shí)現(xiàn)用于獲取當(dāng)前url以及改變當(dāng)前的url,并且存入歷史記錄

•服務(wù)$route完成路由匹配,并且提供路由相關(guān)的屬性訪問及事件,如訪問當(dāng)前路由對(duì)應(yīng)的controller

•指令ngView用來在主視圖中指定加載子視圖的區(qū)域

路由機(jī)制的實(shí)現(xiàn)

第一步、引入兩個(gè)依賴文件

<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
<script src="http://cdn.bootcss.com/angular.js/1.2.9/angular-route.min.js"></script>

因?yàn)槁酚蓹C(jī)制上一個(gè)單獨(dú)的模塊,所以我們需要單獨(dú)的引入路由文件,僅僅引入AngularJS.min.js是不包含路由的,引入文件以后我們還需要在模塊聲明中注入對(duì)ng-route的依賴:

var app = angular.module("myApp", ['ngRoute']);

完成了這些,我們就可以在模板或是controller中使用上面的服務(wù)和指令了。下面我們需要定義一個(gè)路由表。

第二步:完成路由表的配置

app.config(['$routeProvider', function ($routeProvider) {
    $routeProvider
      .when('/div1', {
        template: '<p>這是div1{{text}}</p>',
        controller: 'div1Controller'
      })
      .when('/div2', {
        template: '<p>這是div2{{text}}</p>',
          controller: 'div2Controller'
      })
      .when('/div3', {
        template: '<p>這是div3{{text}}</p>',
        controller: 'div3Controller'
      })
      .when('/content/:id', {
        template: '<p>這是content{{id}}</p>',
        controller: 'div4Controller'
      })
      .otherwise({
        redirectTo: '/div1'
      });
}]);

$routeProvider提供了定義路由表的服務(wù),它有兩個(gè)核心方法,when(path,route)和otherwise(params),先看一下核心中的核心when(path,route)方法。

when(path,route)方法接收兩個(gè)參數(shù),path是一個(gè)string類型,表示該條路由規(guī)則所匹配的路徑,它將與地址欄的內(nèi)容($location.path)值進(jìn)行匹配。如果需要匹配參數(shù),可以在path中使用冒號(hào)加名稱的方式,如:path為/show/:name,如果地址欄是/show/tom,那么參數(shù)name和所對(duì)應(yīng)的值tom便會(huì)被保存在$routeParams中,像這樣:

{name : tom}。我們也可以用*進(jìn)行模糊匹配,如:/show*/:name將匹配/showInfo/tom。

參數(shù)說明如下:

controller //function或string類型。在當(dāng)前模板上執(zhí)行的controller函數(shù),生成新的scope
controllerAs //string類型,為controller指定別名
template //string或function類型,視圖所用的模板,這部分內(nèi)容將被ngView引用
templateUrl //string或function類型,當(dāng)視圖模板為單獨(dú)的html文件或是使用了<script type="text/ng-template">定義模板時(shí)使用
resolve //指定當(dāng)前controller所依賴的其他模塊
redirectTo //重定向的地址

第三步:在主視圖模板中指定加載子視圖的位置

我們的單頁面程序都是局部刷新的,那這個(gè)“局部”是哪里呢,這就輪到ngView出馬了,只需在模板中簡(jiǎn)單的使用此指令,在哪里用,哪里就是“局部”。

通過以上我們就完成了了一個(gè)路由的全部配置過程,在沒有接觸路由的時(shí)候感覺路由這一塊是比價(jià)難的,但是當(dāng)我們真正的了解到這一塊的原理的時(shí)候并不是非常的難,路由在AngularJS中是核心部分所以我們需要牢牢的掌握這一部分。

友情推薦:

看到這可能會(huì)有人說如果有個(gè)完整的Ddeo就好了,所以說小編給大家推薦一個(gè)編寫前臺(tái)代碼的工具RunJS并且可以實(shí)現(xiàn)代碼的共享,小編的這個(gè)Demo就在這上面,可在此處查看效果;http://sandbox.runjs.cn/show/gj894e3t#/content/13

此處查看源碼:
http://runjs.cn/code/gj894e3t

這樣以后我們就可以隨意的分享代碼,尤其是我們?cè)谥v課的時(shí)候非常的方便!

更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)

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

相關(guān)文章

  • AngularJS select加載數(shù)據(jù)選中默認(rèn)值的方法

    AngularJS select加載數(shù)據(jù)選中默認(rèn)值的方法

    下面小編就為大家分享一篇AngularJS select加載數(shù)據(jù)選中默認(rèn)值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • angularjs中ng-bind-html的用法總結(jié)

    angularjs中ng-bind-html的用法總結(jié)

    這篇文章主要介紹了angularjs中ng-bind-html的用法總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • Angular 路由route實(shí)例代碼

    Angular 路由route實(shí)例代碼

    下面小編就為大家?guī)硪黄狝ngular 路由route實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • 深究AngularJS中ng-drag、ng-drop的用法

    深究AngularJS中ng-drag、ng-drop的用法

    本篇文章主要介紹了深究AngularJS中ng-drag、ng-drop的用法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • AngularJs bootstrap搭載前臺(tái)框架——js控制部分

    AngularJs bootstrap搭載前臺(tái)框架——js控制部分

    本文主要介紹AngularJs bootstrap搭載前臺(tái)框架js控制部分的資料,這里有實(shí)現(xiàn)代碼,有興趣的小伙伴可以參考下
    2016-09-09
  • AngularJs 終極購物車(實(shí)例講解)

    AngularJs 終極購物車(實(shí)例講解)

    下面小編就為大家?guī)硪黄狝ngularJs 終極購物車的實(shí)例講解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • 利用Angular2 + Ionic3開發(fā)IOS應(yīng)用實(shí)例教程

    利用Angular2 + Ionic3開發(fā)IOS應(yīng)用實(shí)例教程

    這篇文章主要給大家介紹了關(guān)于利用Angular2 + Ionic3開發(fā)IOS應(yīng)用的相關(guān)資料,文中通過示例代碼和圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Angularjs 動(dòng)態(tài)改變title標(biāo)題(兼容ios)

    Angularjs 動(dòng)態(tài)改變title標(biāo)題(兼容ios)

    這篇文章主要介紹了 Angularjs 動(dòng)態(tài)改變title標(biāo)題(兼容ios)的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • Angular 2使用路由自定義彈出組件toast操作示例

    Angular 2使用路由自定義彈出組件toast操作示例

    這篇文章主要介紹了Angular 2使用路由自定義彈出組件toast操作,結(jié)合實(shí)例形式分析了Angular2使用路由操作彈出組件toast相關(guān)定義與使用技巧,需要的朋友可以參考下
    2019-05-05
  • AngularJS基礎(chǔ)學(xué)習(xí)筆記之表達(dá)式

    AngularJS基礎(chǔ)學(xué)習(xí)筆記之表達(dá)式

    AngularJS表達(dá)式用于應(yīng)用程序數(shù)據(jù)綁定到HTML。表達(dá)式都寫在雙括號(hào)就像{{表達(dá)式}}。表達(dá)式中的行為跟ng-bind指令方式相同。 AngularJS應(yīng)用表達(dá)式是純javascript表達(dá)式,并輸出它們被使用的數(shù)據(jù)在那里。
    2015-05-05

最新評(píng)論