中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

AngularJS路由中resolve怎么用

發布時間:2021-07-09 11:12:12 來源:億速云 閱讀:148 作者:小新 欄目:web開發

小編給大家分享一下AngularJS路由中resolve怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

ng-route模塊中的when()和ui-route的state()都提供了resolve屬性。

為什么需要使用resolve?

當路由切換的時候,被路由的頁面中的元素(標簽)就會立馬顯示出來,同時,數據會被準備好并呈現出來。但是注意,數據和元素并不是同步的,在沒有任何設置的情況下,AngularJS默認先呈現出元素,而后再呈現出數據。這樣就會導致頁面會被渲染兩遍,導致“頁面UI抖動”的問題,對用戶不太友好。resolve的出現解決了這個問題。

resolve是干嘛用的

resolve屬性里的值會在路由成功前被預先設定好,然后注入到控制器中。通俗地將,就是等數據都“就位”后,才進行路由(其實我覺得也不能叫路由,因為路由是一些列的操作,其中就包括了設置resolve屬性等等)。這樣的好處就是頁面僅會被渲染一遍。

<!--首頁.html-->
<div ng-app="myApp">
<div><a ui-sref = "index">前往list.html</a></div>
<div ui-view></div><!--這里是路由視圖存放的地方-->
</div>
<!--list.html>
<div>
  <h2>HI,這里是list.html</h2>
  <a ui-sref="index.list">點擊加載list.html視圖</a>
  <div ui-view></div>
  <h2>{{user}}</h2>
  <h3>{{name}}</h3>
  <h4>{{age}}</h4>
  <h4>{{email}}</h4>
</div>
//JS
var app = angular.module('myApp',['ui.router']);
app.config(["$stateProvider",function($stateProvider){
  $stateProvider
    .state("index",{
      url:'/',
      templateUrl:'list.html',
      controller:'myController',
      resolve:{
        user:function(){
          return {
            name:"perter",
            email:"826415551@qq.com",
            age:"18"
          }
        }
      }
    })
}]);
app.controller('myController',function($scope,user){
  $scope.name=user.name;
  $scope.age=user.age;
  $scope.email=user.email;
  $scope.user=user;
});

我在state方法里面設置了resolve屬性,里面的值是一個名為user的對象,它存有幾個值(格式好像JSON)。并把這個user變量注入到控制器中。這樣就完成了預加載了。

這種把resolve屬性的值(這里是user)注入到控制器的方式有一個非常強大的地方就是,可以運用他來重用控制器,而我們需要做的僅僅只是改變user對象里面的值(tips:如果是嵌套路由的話,不重新設置resolve值則會“繼承”父路由的resolve值,如果不是嵌套路由且不重新設置,則不會正確顯示)。

<!--list.html-->
<div>
  <h2>HI,這里是list.html</h2>
  <a ui-sref="index.list">點擊加載list.html視圖</a>
  <a ui-sref="index.list2">點擊加載list2.html視圖</a>
  <div ui-view></div>
  <h2>{{user}}</h2>
  <h3>{{name}}</h3>
  <h4>{{age}}</h4>
  <h4>{{email}}</h4>
</div>
//js
var app = angular.module('myApp',['ui.router']);
app.config(["$stateProvider",function($stateProvider){
  $stateProvider
    .state("index",{
      url:'/',
      templateUrl:'list.html',
      controller:'myController',
      resolve:{
        user:function(){
          return {
            name:"perter",
            email:"826415551@qq.com",
            age:"18"
          }
        }
      }
    })

    .state("index.list",{
      url:'/list',
      template:'<h2>{{name}}</h2>',
      controller:'myController',
    })
    .state("index.list2",{
      url:'/list2',
      template:'<h2>{{name}}</h2>',
      controller:'myController',
      resolve:{
        user:function () {
          return{
          name:"Rose"
          }
        }
      }
    })

}]);
app.controller('myController',function($scope,user){
  $scope.name=user.name;
  $scope.age=user.age;
  $scope.email=user.email;
  $scope.user=user;
});

這里省略了首頁的html,可以翻到最上面看。重點對比最后的兩個state(),可以發現第一個沒有重新設置resolve屬性,而第二個重新設置了resolve()屬性。他們雖然共用了同一個控制器myController ,但是他們的值卻不相同。
這樣,控制器的可維護性就會得到提高。

除此之外還可以借助$ocLazyLoad動態加載js、css,用法如下:

resolve: { 
        deps: ['$ocLazyLoad', function($ocLazyLoad) { 
          return $ocLazyLoad.load({ 
            name: 'App', 
            insertBefore: '#ng_load_plugins_before',  
            files: [ 
              'xx/js/controllers/xx.js' 
            ] 
          }); 
        }], 
        showImgFiles: ['$ocLazyLoad', function($ocLazyLoad) { 
          return $ocLazyLoad.load([{ 
            name: 'App', 
            insertBefore: '#ng_load_plugins_before',  
            files: [ 
              'xx/xx/xx.css', 
              'xx/xx/xx.js' 
            ] 
          }]).then(function(){ 
            //做些事情 
          }); 
        }] 
      }

以上是“AngularJS路由中resolve怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沙湾县| 砀山县| 铁力市| 尼勒克县| 红桥区| 兴和县| 曲松县| 修文县| 都昌县| 浠水县| 浏阳市| 阿坝| 英山县| 聂荣县| 临邑县| 盐山县| 宜春市| 仁化县| 隆昌县| 阜城县| 钟山县| 镇远县| 萨嘎县| 客服| 宁河县| 萝北县| 赣榆县| 闸北区| 卓资县| 塔城市| 平凉市| 大埔县| 阿城市| 吴堡县| 沂南县| 十堰市| 旅游| 化州市| 页游| 云浮市| 德钦县|