<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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        在AngularJS中使用ui-route實現多層嵌套路由(詳細教程)

        來源:懂視網 責編:小采 時間:2020-11-27 19:37:44
        文檔

        在AngularJS中使用ui-route實現多層嵌套路由(詳細教程)

        在AngularJS中使用ui-route實現多層嵌套路由(詳細教程):這篇文章主要介紹了AngularJS使用ui-route實現多層嵌套路由的示例,現在分享給大家,也給大家做個參考。本文介紹了AngularJS使用ui-route實現多層嵌套路由的示例,分享給大家,具體如下:一、預期實現效果:https://liyuan-meng.github.i
        推薦度:
        導讀在AngularJS中使用ui-route實現多層嵌套路由(詳細教程):這篇文章主要介紹了AngularJS使用ui-route實現多層嵌套路由的示例,現在分享給大家,也給大家做個參考。本文介紹了AngularJS使用ui-route實現多層嵌套路由的示例,分享給大家,具體如下:一、預期實現效果:https://liyuan-meng.github.i
        這篇文章主要介紹了AngularJS使用ui-route實現多層嵌套路由的示例,現在分享給大家,也給大家做個參考。

        本文介紹了AngularJS使用ui-route實現多層嵌套路由的示例,分享給大家,具體如下:

        一、預期實現效果:

        https://liyuan-meng.github.io/uiRouter-app/index.html

        (項目地址:https://github.com/liyuan-meng/uiRouter-app)

        二、分析題目要求,給出依賴關系,構建項目

        1. service:

        (1)根據條件查詢people數據checkPeople.service,不給出條件則查詢所有。

        (2)得到路由信息getStateParams.service。

        2. components:

        (1)hello模塊:點擊button按鈕更改內容。

        (2)peolpleList模塊:顯示people列表,點擊people顯示people詳情。依賴于checkPeople.service模塊。

        (3)peopleDetail模塊:顯示people詳情,依賴于checkPeople.service模塊和getStateParams.service模塊。

        3. 構建項目:

        如圖所示:component目錄用來保存所有服務模塊和業務模塊,lib目錄保存外部引用(我是用的是angular.js1.5.8和ui-route0.2.18),app.config.js文件用來配置路由,index.html則作為入口文件。

        三、實現這個例子

        1. 首頁index.html

        <!DOCTYPE html>
        <html lang="en">
        <head>
         <meta charset="UTF-8">
         <title>Title</title>
         <script src="./lib/angular.js"></script>
         <script src="./lib/angular-ui-route.js"></script>
         <script src="./app.config.js"></script>
         <script src="./components/core/people/checkPeople.service.js"></script>
         <script src="./components/core/people/getStateParams.service.js"></script>
         <script src="./components/hello/hello.component.js"></script>
         <script src="./components/people-list/people-list.component.js"></script>
         <script src="./components/people-detail/people-detail.component.js"></script>
        </head>
        <body ng-app="helloSolarSystem">
        <p>
         <a ui-sref="helloState">Hello</a>
         <a ui-sref="aboutState">About</a>
         <a ui-sref="peopleState">People</a>
        </p>
        
        <ui-view></ui-view>
        
        </body>
        </html>

        (1)導入lib中的文件以及所有用到的service和component服務的文件。

        (2)ng-app="helloSolarSystem"指明了從helloSolarSystem模塊開始解析。

        (3)定義視圖<ui-view></ui-view>

        2. 配置路由app.config.js

        'use strict';
        
        angular.module("helloSolarSystem", ['peopleList', 'peopleDetail', 'hello','ui.router']).
        
         config(['$stateProvider', function ($stateProvider) {
        
         $stateProvider.state('helloState', {
         url: '/helloState',
         template:'<hello></hello>'
        
         }).state('aboutState', {
         url: '/about',
         template: '<h4>Its the UI-Router Hello Solar System app!</h4>'
        
         }).state('peopleState', {
         url: '/peopleList',
         template:'<people-list></people-list>'
        
         }).state('peopleState.details', {
         url:'/detail/:id',
         template: '<people-detail></people-detail>'
         })
         }
        ]);

        (1)模塊名字:helloSolarSystem;

        (2)注入'peopleList', 'peopleDetail', 'hello','ui.router'模塊。

        (3)配置stateProvider服務的視圖控制,例如第一個名為helloState的視圖控制器:當ui-sref == "helloState"的時候,路由更新為url的值#/helloState,并且<ui-view></ui-view>中顯示的內容為<hello></hello>組件解析出的內容。

        (4)嵌套路由的實現:名為peopleState的視圖控制器是父路由。名為peopleState.details的視圖控制器是子路由。這是一種相對路由方式,父路由將匹配.../index.html#/peopleState/,子路由將匹配.../index.html#/peopleState/detail/x(x是/detail/:id中的id的值)。如果改成絕對路由的形式,只需要寫成url:'^/detail/:id',這時子路由將匹配.../index.html#/detail/x(x是/detail/:id中的id的值)。

        4. 實現checkPeople.service(根據條件查找people)

        checkPeople.sercice.js

        'use strict';
        
        //根據條件(參數)查找信息。
        angular.module('people.checkPeople', ['ui.router']).
         factory('CheckPeople', ['$http', function ($http) {
         return {
         getData: getData
         };
         function getData(filed) {
         var people;
         var promise = $http({
         method: 'GET',
         url: './data/people.json'
         }).then(function (response) {
         if (filed) {
         people = response.data.filter(function (value) {
         if (Number(value.id) === Number(filed)) {
         return value;
         }
         })
         } else {
         people = response.data;
         }
         return people;
         });
         return promise;
         }
         }]);

        (1)在getData這個函數中,我們想要返回一個保存people信息的數組,但是由于使用$http().then()服務的時候,這是一個異步請求,我們并不知道請求什么時候結束,所以世界返回people數組是有問題的。我們注意到,$http().then()是一個Promise對象,所以我們可以想到直接將這個對象返回,這樣在就可以使用"函數的結果.then(function(data))"來得到異步請求拿來的數據data。

        3. 實現getStateParams.service(獲取路由信息)

        getStatePatams.service.js

        "use strict";
        
        angular.module("getStateParams", ['ui.router']).
         factory("GetStateParams", ["$location", function ($location) {
         return {
         getParams: getParams
         };
         function getParams() {
         var partUrlArr = $location.url().split("/");
         return partUrlArr[partUrlArr.length-1];
         }
        }]);

        (1)這里的getParams函數返回的是路由信息的最后一個數據,也就是people的id,這個service有些特殊,不夠通用,可能還需要優化一下會更加合理。不過并不影響我們的需求。

        4. 實現hello模塊

        hello.template.html

        <p>
         <p ng-hide="hideFirstContent">hello solar sytem!</p>
         <p ng-hide="!hideFirstContent">whats up solar sytem!</p>
         <button ng-click="ctlButton()">click</button>
        </p>

        hello.component.js

        'use strict';
        
        angular.module("hello", [])
         .component('hello', {
         templateUrl: './components/hello/hello.template.html',
         controller: ["$scope", 
         function HelloController($scope) {
         $scope.hideFirstContent = false;
         $scope.ctlButton = function () {
         this.hideFirstContent = !this.hideFirstContent;
         };
         }
         ]
         });

        5. 實現peolpeList模塊:

        peopleList.template.html

        <p>
         <ul>
         <a ng-repeat="item in people" ui-sref="peopleState.details({id:item.id})">
         <li>{{item.name}}</li>
         </a>
         </ul>
         <ui-view></ui-view>
        </p>

        (1)這里的<ui-view></ui-view>用來顯示peopleList的子組件pepleDetail

        peopleList.component.js

        'use strict';
        
        angular.module("peopleList", ['people.checkPeople'])
         .component('peopleList', {
         templateUrl: './components/people-list/people-list.template.html',
         controller: ['CheckPeople','$scope',
         function PeopleListController(CheckPeople, $scope) {
         $scope.people = [];
         CheckPeople.getData().then(function(data){
         $scope.people = data;
         });
         }
         ]
         });

        6. 實現peopleDetail模塊

        peopleDetail.template.html

        <ul ng-repeat="item in peopleDetails track by $index">
         <li>名字: {{item.name}}</li>
         <li>介紹: {{item.intro}}</li>
        </ul>

        peopleDetail.component.js

        'use strict';
        
        angular.module("peopleDetail", ['people.checkPeople', 'getStateParams'])
         .component('peopleDetail', {
         templateUrl: './components/people-detail/people-detail.template.html',
         controller: ['CheckPeople', 'GetStateParams', '$scope',
         function peopleDetailController(CheckPeople, GetStateParams, $scope) {
         $scope.peopleDetails = [];
         CheckPeople.getData(GetStateParams.getParams()).then(function(data){
         $scope.peopleDetails = data;
         });
         }
         ]
         });

        上面是我整理給大家的,希望今后會對大家有幫助。

        相關文章:

        利用JS腳本加載后如何實現能執行相應回調函數

        利用vue+webpack如何解決打包文件 404 頁面空白問題

        通過webpack項目如何實現調試以及打包配置文件(詳細教程)

        通過vue-cli+webpack項目如何實現修改項目名稱

        在vue組件中如何實現全局注冊和局部注冊

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

        文檔

        在AngularJS中使用ui-route實現多層嵌套路由(詳細教程)

        在AngularJS中使用ui-route實現多層嵌套路由(詳細教程):這篇文章主要介紹了AngularJS使用ui-route實現多層嵌套路由的示例,現在分享給大家,也給大家做個參考。本文介紹了AngularJS使用ui-route實現多層嵌套路由的示例,分享給大家,具體如下:一、預期實現效果:https://liyuan-meng.github.i
        推薦度:
        標簽: js 路由 嵌套
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 东北美女野外bbwbbw免费 | 久久免费视频99| a级大片免费观看| 久久99国产综合精品免费| 97在线线免费观看视频在线观看| 成人在线视频免费| 亚洲综合色在线观看亚洲| 亚洲精品成人网站在线观看| 久久国产精品亚洲综合| 亚洲熟妇无码一区二区三区导航 | 亚洲精品国产高清嫩草影院| 亚洲AV区无码字幕中文色| 国产拍拍拍无码视频免费| 午夜dj免费在线观看| 亚洲一区精品无码| 亚洲国产一区二区三区在线观看| 国产精品免费αv视频| 在线看免费观看AV深夜影院 | 97国产免费全部免费观看| 美女视频黄免费亚洲| 可以免费观看的毛片| 久久精品国产亚洲AV高清热| 野花视频在线官网免费1| 四虎成年永久免费网站| 亚洲尤码不卡AV麻豆| 午夜免费福利视频| 亚洲精品国产美女久久久| 在线免费观看你懂的| 亚洲欧美日韩中文高清www777| 特级无码毛片免费视频尤物| 亚洲六月丁香六月婷婷色伊人| 亚欧国产一级在线免费| 亚洲第一精品福利| 成人毛片18女人毛片免费96| 精品一区二区三区免费视频| 亚洲 无码 在线 专区| 亚洲性无码AV中文字幕| 国产精品亚洲高清一区二区| 5g影院5g天天爽永久免费影院| 亚洲国产精品成人精品无码区在线| 五月天婷婷精品免费视频|