什么是ui-router
成都創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的云霄網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
ui-router是AngularUI庫最有用的組件之一(AngularUI庫由AngularJS社區(qū)構(gòu)建)。它是一個第三方路由框架,允許通過狀態(tài)機制組織接口,而不是簡單的URL路由。
什么是ocLoayLoad
ocLoayLoad是AngularJS的模塊按需加載器。按需加載的對象
簡單說就是哪個頁面需要什么資源,在加載哪個頁面的時候在加載,而不是把所有的資源放在模板里。
三個主要文件
<script src="angular/1.4.8/angular/angular.min.js"></script> <script src="angular/ui-router/release/angular-ui-router.min.js"></script> <script src="angular/oclazyload/src/ocLazyLoad.min.js"></script>
推薦
1:首先下載插件 可以百度搜索,這里我推薦在線測試的 https://www.bootcdn.cn/angular-ui-router/
2:github url :https://github.com/366065186/angularjs-oclazyload
3:Angularjs https://code.angularjs.org/
html文件(部分代碼)簡單說明
1:首先頁面引入上面三個文件
2:在a標(biāo)簽中寫入 ui-sref='鏈接路徑' 標(biāo)簽
2:在頁面定義一塊區(qū)域用于顯示鏈接內(nèi)容 <ui-view></ui-view>
js代碼:
首先在module中注入
'ui.router', 'oc.lazyLoad'然后在通過config進(jìn)行路由配置。
(function () { var app = angular.module("app", ['ui.router', 'oc.lazyLoad']) // 配置路由 app.config(function ($stateProvider) { $stateProvider // 個人中心主頁 .state('admin/index', { url: '/admin/index', templateUrl: "/admin/index", // 加載頁面需要的js resolve: load(['/static/js/transfer/adminlte/index.js']) }) // 分類管理列表 .state('class/index', { url: '/class/index', templateUrl: "/class/index", resolve: load([ '/static/js/transfer/adminlte/classification/index.js' ]) }) // 輪播圖列表 .state('roll', { url: '/roll', templateUrl: "/roll", resolve: load([ '/static/js/transfer/adminlte/broadcat.js' ]) }) // 驗證碼列表 .state('code', { url: '/code', templateUrl: "/code", resolve: load([ '/static/js/transfer/adminlte/code.js' ]) }) // 電影列表 .state('movie', { url: '/movie', templateUrl: "/movie", resolve: load([ '/static/js/transfer/adminlte/movie/movie.js' ]) }) // 電影編輯 .state('movie/edit', { url: '/movie/edit', templateUrl: "/movie/edit", resolve: load([ '/static/js/transfer/adminlte/movie/movieedit.js' ]) }) }); // 在加載該模塊的時候調(diào)用$state.go('admin/index');,以激活admin/index狀態(tài)。 app.run(function ($state) { $state.go('admin/index'); }); /* * 通過$ocLazyLoad加載頁面對應(yīng)的所需的JS數(shù)據(jù) * 通過$q異步加載JS文件數(shù)據(jù)其中使用的是promise【保護(hù)模式】 */ function load(srcs, callback) { return { deps: [ '$ocLazyLoad', '$q', function ($ocLazyLoad, $q) { var deferred = $q.defer(); var promise = false; srcs = angular.isArray(srcs) ? srcs : srcs.split(/\s+/); if (!promise) { promise = deferred.promise; } angular.forEach(srcs, function (src) { promise = promise.then(function () { angular.forEach([], function (module) { if (module.name === src) { src = module.module ? module.name : module.files; } }); return $ocLazyLoad.load(src); }); }); deferred.resolve(); return callback ? promise.then(function () { return callback(); }) : promise; } ] }; } })();
AngularJS路由設(shè)置對象參數(shù)規(guī)則:
屬性 | 類型 | 描述 |
template | string | 在ng-view中插入簡單的html內(nèi)容 |
templateUrl | string | 在ng-view中插入html模版文件 |
controller | string,function / array | 在當(dāng)前模版上執(zhí)行的controller函數(shù) |
controllerAs | string | 為controller指定別名 |
redirectTo | string,function | 重定向的地址 |
resolve | object | 指定當(dāng)前controller所依賴的其他模塊 |
效果圖:
總結(jié)
以上所述是小編給大家介紹的Angular ui-roter 和AngularJS 通過 ocLazyLoad 實現(xiàn)動態(tài)(懶)加載模塊和依賴,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
新聞名稱:Angularui-roter和AngularJS通過ocLazyLoad實現(xiàn)動態(tài)(懶)加載模塊和依賴
本文路徑:http://jinyejixie.com/article18/ijjcdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)站設(shè)計公司、定制網(wǎng)站、動態(tài)網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)