Wenn Sie eine Abhängigkeit (z. B. von einem Dienst) einfügen möchten, um ein Funktionsformular in Routen (.config) aufzurufen, wie unten gezeigt templateProvider.getTemplate ('about')
.state('index.about', {
url: "/about",
templateUrl: templateProvider.getTemplate('about'),
controller: 'AboutCtrl',
controllerAs: 'about',
data: {pageTitle: 'About Us Page'}
})
Sie müssen einen Provider erstellen. Weder Service noch Fabrik.
Hier ist ein echtes Beispiel eines Anbieters, der den Vorlagenpfad aus dem Namen generiert:
(function () {
'use strict';
angular
.module('mega-app')
.provider('template', provider);
function provider(CONSTANT) {
this.$get = function () {
return {}
};
this.getTemplate = function (name) {
return CONSTANT.TEMPLATES_URL + name + '/' + name + '.html';
}
this.getComponent = function (name) {
return CONSTANT.COMPONENTS_URL + name + '.html';
}
};
})();
Die Verwendung eines solchen Anbieters in den Routen (.config) ist wie folgt:
(function () {
'use strict'
angular
.module('mega-app')
.config(routes)
function routes($stateProvider, $urlRouterProvider, templateProvider) {
$stateProvider
//----------------------------------------------------------------
// First State
//----------------------------------------------------------------
.state('index', {
abstract: true,
url: "/index",
templateUrl: templateProvider.getComponent('content'),
controller: 'IndexCtrl',
controllerAs: 'index',
})
//----------------------------------------------------------------
// State
//----------------------------------------------------------------
.state('index.home', {
url: "/home",
templateUrl: templateProvider.getTemplate('home'),
controller: 'HomeCtrl',
controllerAs: 'home',
data: {pageTitle: 'Home Page'}
})
//----------------------------------------------------------------
// State
//----------------------------------------------------------------
.state('index.about', {
url: "/about",
templateUrl: templateProvider.getTemplate('about'),
controller: 'AboutCtrl',
controllerAs: 'about',
data: {pageTitle: 'About Us Page'}
})
//----------------------------------------------------------------
// Default State
//----------------------------------------------------------------
$urlRouterProvider.otherwise('/index/home')
}
})()
VIP Hinweis:
Um den Provider zu injizieren, müssen Sie ihn mit xxxProvider postfixieren (dieser Name des Providers sollte nicht postfixiert werden, sondern nur beim Injizieren in die .config).
$http
nur für die Konfiguration injizieren, dh als$httpProvider
: docs.angularjs.org/api/ng/provider/$httpProvider