欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

angular學(xué)習(xí)之ngRoute路由機(jī)制

ngRoute簡介

建網(wǎng)站原本是網(wǎng)站策劃師、網(wǎng)絡(luò)程序員、網(wǎng)頁設(shè)計(jì)師等,應(yīng)用各種網(wǎng)絡(luò)程序開發(fā)技術(shù)和網(wǎng)頁設(shè)計(jì)技術(shù)配合操作的協(xié)同工作。成都創(chuàng)新互聯(lián)公司專業(yè)提供成都網(wǎng)站建設(shè)、做網(wǎng)站,網(wǎng)頁設(shè)計(jì),網(wǎng)站制作(企業(yè)站、響應(yīng)式網(wǎng)站建設(shè)、電商門戶網(wǎng)站)等服務(wù),從網(wǎng)站深度策劃、搜索引擎友好度優(yōu)化到用戶體驗(yàn)的提升,我們力求做到極致!

路由是AngularJS很重要的一環(huán),它可以把你項(xiàng)目的頁面串聯(lián)起來,構(gòu)成一個(gè)項(xiàng)目,常用的路由有ngRoute和ui-route,我這里先講ngRoute。ngRoute是一個(gè)Module,提供路由和深層鏈接所需的服務(wù)和指令。

注意一點(diǎn),和之前的文章不一樣,使用ngRoute之前你需要引入另外一個(gè)js文件angular-route.js:

<script src="script/angular.min.js"></script>
<script src="script/angular-route.min.js"></script>

ngRoute包含內(nèi)容如下:

名稱類型作用
ngViewDirective路由的不同模板其實(shí)都是插入這個(gè)元素里
$routeProviderProvider路由配置
$routeService各個(gè)路由的url,view,controller
$routeParamsService路由參數(shù)

使用ngRoute的基本流程如下:

  1. 在需要路由的地方使用ngView來定義視圖模板。
  2. 在module中注入ngRoute模塊
  3. 在config中用$routeProvider來對(duì)路由進(jìn)行配置templateUrl,controller,resolve。
  4. 在每個(gè)controller中寫業(yè)務(wù)邏輯
  5. 在controller中可以通過注入$routeParams來獲得url上的參數(shù)

可以看下下面這個(gè)例子

color.html

<!DOCTYPE html>
<html>
<head>
  <meta charset="uft-8"/>
  <title></title>
</head>
<script src="script/angular.min.js"></script>
<script src="script/angular-route.min.js"></script>
<body ng-app="color">
<p><a href="#/" rel="external nofollow" rel="external nofollow" >Main</a></p>

<a href="#red" rel="external nofollow" rel="external nofollow" >Red</a>
<a href="#green" rel="external nofollow" rel="external nofollow" >Green</a>

<div ng-view></div>

</body>

<script>
  var app = angular.module("color", ["ngRoute"]);

  app.config(function ($routeProvider) {
    $routeProvider
        .when("/", {
          templateUrl: "main.html",
          controller: 'mainController'
        })
        .when("/red", {
          templateUrl: "red.html",
          controller: 'redController'
        })
        .when("/green", {
          templateUrl: "green.html",
          controller: 'greenController'
        })       
        .otherwise('/');
  });

  app.controller('mainController',['$scope',function mainController($scope){
    $scope.message='this is main page';
  }]);
  app.controller('redController',['$scope',function mainController($scope){
    $scope.message='this is red page';
  }]);
  app.controller('greenController',['$scope',function mainController($scope){
    $scope.message='this is green page';
  }]);
</script>
</html>

red.html (其他頁面類似,就不重復(fù)了)

<div >
{{message}}
</div>

例子很簡單,我們就只講下路由的配置:

  1. 使用$routeProvider.when來配置路由的關(guān)系,方法接受兩個(gè)參數(shù),第一個(gè)參數(shù)是url的路徑,第二個(gè)參數(shù)是配置url對(duì)應(yīng)的templateUrl和controller。
  2. $routeProvider.otherwise方法相當(dāng)于default。

路由模塊化

可能你已經(jīng)注意到了上面的都寫在一起,如果項(xiàng)目越來越大,會(huì)不會(huì)很頭疼,那么是不是可以把它模塊化,每個(gè)模塊都有直接的module,controller,config等。模塊依賴的技術(shù)我們之前的module那篇文章已經(jīng)講過,那么就來看下帶有路由的情況下,怎么模塊化。

color.html:

<!DOCTYPE html>
<html>
<head>
  <meta charset="uft-8"/>
  <title></title>
</head>
<script src="script/angular.min.js"></script>
<script src="script/angular-route.min.js"></script>
<script src="red.js"></script>
<script src="green.js"></script>
<script src="main.js"></script>
<body ng-app="color">
<p><a href="#/" rel="external nofollow" rel="external nofollow" >Main</a></p>

<a href="#red" rel="external nofollow" rel="external nofollow" >Red</a>
<a href="#green" rel="external nofollow" rel="external nofollow" >Green</a>

<div ng-view></div>

</body>

<script>
  var app = angular.module("color", ["ngRoute","Module.red","Module.main","Module.green"]);

  app.config(function ($routeProvider) {
    $routeProvider.otherwise('/');
  });
</script>
</html>

可以看到我們的color.html文件是不是很簡潔,config的路由配置里只有一行$routeProvider.otherwise方法,但是module卻注入了除ngRoute外的三個(gè)module:”Module.red”,”Module.main”,”Module.green”,這其實(shí)是把path對(duì)應(yīng)的路由提取成模塊,使用了專門的js來處理它們,看起來和他們對(duì)應(yīng)的模板相對(duì)應(yīng),我們來看下red.html對(duì)應(yīng)的模塊js:

red.js

angular.module('Module.red', ['ngRoute'])

  .config([
    '$routeProvider',
    function ($routeProvider) {
      $routeProvider.when('/red', {
        templateUrl: 'red.html',
        controller: 'redController'
      });
    }
  ])


  .controller('redController', [
    '$scope',
    function ($scope) {
      $scope.color='red';
      $scope.message = 'This is red page';
    }
  ]);

路由的參數(shù)

那么路由怎么將參數(shù)傳入到模板頁呢?我們把上面的例子改造一下,通過例子來講解:

main.js

angular.module('Module.main', ['ngRoute'])

  .config([
    '$routeProvider',
    function ($routeProvider) {
      $routeProvider
        .when('/', {
          templateUrl: 'main.html',
          controller: 'mainController'
        });
    }
  ])

  .controller('mainController', [
    '$scope',
    function ($scope) {
      $scope.message = 'This is main page';
      $scope.colors=['blue','yellow','pink'];
    }
  ]);

這里初始化了一個(gè)colors的數(shù)組,作為要傳遞的數(shù)據(jù)。

main.html

{{message}}
<br>
<ul>
  <li ng-repeat="color in colors">
    <a href="#/color/{{color}}" rel="external nofollow" >{{color}}</a>
  </li>
</ul>

通過ng-repeat循環(huán)創(chuàng)建a鏈接,數(shù)組的元素通過鏈接傳入。

colorId.js

angular.module('Module.colorId', ['ngRoute'])

  .config([
    '$routeProvider',
    function ($routeProvider) {
      $routeProvider
        .when('/color/:colorId', {
          templateUrl: 'colorId.html',
          controller: 'colorIdController'
        });
    }
  ])

  .controller('colorIdController', [
    '$scope','$routeParams',
    function ($scope,$routeParams) {
      $scope.color = $routeParams.colorId;
      $scope.message = 'This is ' +$routeParams.colorId +' page';
    }
  ]);

這里定義了一個(gè)colorId的模塊,通過:colorId來匹配傳入的參數(shù),這里匹配到的是數(shù)組中的元素。例如/color/blue,那么匹配到的就是blue。

colorId.html

<div >
  {{message}}
</div>

最后在colorId上呈現(xiàn)出來。

如果是多個(gè)參數(shù)可以直接一一接到后面比如/color/:colorId/:year/:month/:day,和后面的參數(shù)也一一匹配,如/color/pink/2017/3/13。

支持*號(hào):/color/:color/largecode/:largecode*/edit匹配/color/brown/largecode/code/with/slashes/edit的話,color將會(huì)匹配到brown,largecode將匹配到code/with/slashes。

支持?號(hào):/color/:color/largecode/:largecode?/edit可以匹配匹配/color/brown/largecode/code/edit,largecode將會(huì)匹配到code。
/color/:color/largecode/:largecode?/edit可以匹配匹配/color/brown/largecode/edit,largecode將會(huì)匹配到空值。

路由中的resolve

一個(gè)最常見的情景,頁面跳轉(zhuǎn)時(shí)要加載一些數(shù)據(jù)。有兩種方式可以做到:

  1. 頁面跳轉(zhuǎn)后加載,通過controller去控制數(shù)據(jù)的加載,如果時(shí)間較長則顯示一個(gè)loading的界面,數(shù)據(jù)請(qǐng)求成功后再替換成數(shù)據(jù)界面
  2. 頁面跳轉(zhuǎn)前加載,通過路由的resolve去配置。

個(gè)人更喜歡跳轉(zhuǎn)后加載的方式,因?yàn)楦鼮橛押?,所以?duì)resolve不太感冒,但我們還是講下resolve。

resolve是一個(gè)map對(duì)象:

  1. map的key是可以注入到controller的可選的依賴項(xiàng),如果resolve其中依賴項(xiàng)的返回值是promise,那么在controller初始化之前,路由會(huì)一直等待直到所有的promise都已經(jīng)resolved或者其中的一個(gè)被rejected。如果所有的promise都成功resolved,這些依賴項(xiàng)將可以注入到controller中并同時(shí)觸發(fā)$routeChangeSuccess事件,如果其中的一個(gè)promise是rejected,那么將會(huì)觸發(fā)$routeChangeError事件,并中止路由切換。
  2. map的value如果是個(gè)字符串,那么它會(huì)是一個(gè)service的別名。如果是一個(gè)函數(shù),他的返回值可以被當(dāng)做依賴注入 到controller中,如果返回值是一個(gè)promise,在注入之前必須是resolved的。注意這時(shí)候ngRoute.$routeParams還不可用,如果需要使用參數(shù)則需要使用$route.current.params。

看下例子:

news.html

<html>
<head>
  <meta charset="uft-8"/>
  <title></title>
</head>
<script src="script/angular.min.js"></script>
<script src="script/angular-route.min.js"></script>
<body ng-app="ngst-news">
<div ng-controller="MainController">
  <ul>
    <li ng-repeat="news in newsAarry">
      <a href="#/newsDetail/{{news.id}}" rel="external nofollow" >{{news.title}}</a>
    </li>
  </ul>
  <div ng-view></div>
</div>
</body>

<script src="news.js" charset="UTF-8"></script>
<script src="newsDetail.js" charset="UTF-8"></script>
</html>

news.js

var news = angular.module("ngst-news", ["ngst-newsDetail"]);

news.controller("MainController", ["$scope", function ($scope) {
  $scope.newsAarry = [{"id": "1", "title": "遼寧人大副主任王陽 浙江寧波市長盧子躍被免職"},
    {"id": "2", "title": "今冬小雨繽紛,荔枝園地濕潤壯旺荔枝果樹,下刀環(huán)剝最狠"},
    {"id": "3", "title": "百度任原搜索渠道總經(jīng)理顧國棟為市場執(zhí)行總監(jiān)"}];
}]);

news頁面是一個(gè)新聞列表,在列表下面有個(gè)ng-view,點(diǎn)擊新聞列表鏈接下面的ng-view進(jìn)行路由切換。

newsDetails.html

{{message}}

newsDetails.js

var news = angular.module("ngst-newsDetail", ['ngRoute']);

news.config(["$routeProvider",
  function ($routeProvider) {
    $routeProvider.when("/newsDetail/:newsId", {
      templateUrl: 'newsDetail.html',
      controller: 'newsDetailController',
      resolve: {
        content: ['$q', '$timeout', "$route", function ($q, $timeout, $route) {
          var deferred = $q.defer();
          $timeout(function () {
            deferred.resolve('新聞詳情 id=' + $route.current.params.newsId);
          }, 1000);
          return deferred.promise;
        }]
      }
    });
  }])
  .controller("newsDetailController", ['$scope', 'content',
    function ($scope, content) {
      $scope.message = content;
    }]);

這里使用$route.current.params來獲得參數(shù)

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)站名稱:angular學(xué)習(xí)之ngRoute路由機(jī)制
標(biāo)題來源:http://aaarwkj.com/article20/gjjojo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)公司做網(wǎng)站、App設(shè)計(jì)網(wǎng)站建設(shè)、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
插美女逼免费视频导航| 亚洲女人淫片在线观看| 国产精品一区二在线观看| 欧美护士激情第一欧美精品| 扒开女性毛茸茸的视频| 国产精品亚洲精品欧美| 免费日本高清色噜噜视频| 白嫩少妇情久久密月久久| 欧美日韩高清一区二区三区| 国产精品自拍av一区二区| 日本少妇激情后入嗯啊| 欧美一区二区三区成人网| 欧美日韩台湾一区二区| 欧美黑人少妇高潮喷水| 四虎永久精品在线视频| 亚洲黄色av在线免费观看| 韩国三级网站在线观看视频| 精品国产无遮挡污污网站| 国产精品一区二区三区专区| 日韩欧美亚洲视频另类| 欧美日韩黄色的三级视频| 男女做爰高清无遮挡免费| 福利视频免费观看欧美| 国产精品欧美久久久久久| 偷窥偷拍视频一区二区| 国产精品欧美一区二区视频| 日韩美女后入式在线视频| 尤物视频在线观看羞羞| 国产精品一级性生活片| 亚洲精品在线观看午夜福利| 精品国产91久久粉嫩懂色| 日本在线一区二区三区| 亚洲熟妇av乱码在线观看| 国产精品六区久久综合亚洲av| 日本高清加勒比免费在线| 老女人性生交大片免费| 国产美女冒白浆免费网站| 亚洲伦理一区二区三区中文| 成年人午夜看片免费网站| 国产91黑丝在线视频| 激情亚洲不卡一区二区|