-
-
Notifications
You must be signed in to change notification settings - Fork 4.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Best Practices for templateUrl
and ngInclude
URLs
#839
Comments
I agree with you about templateUrl and constants but you cannot use angular.module.constant because you cannot declare the component factory method when writing a component. You are limited to the definition object. You have to do that : angular
.module('sales.widgets')
.component('acmeSalesCustomerInfo', {
templateUrl: 'app/sales/widgets/acme-sales-customer-info.html',
bindings: {
data: '<',
onWhateverClick: '&'
},
controller: salesCustomerInfo
});
function salesCustomerInfo(/* component controller injections are here */) {
/* implementation details */
} You cannot do that : angular
.module('sales.widgets')
.component('acmeSalesCustomerInfo', acmeSalesCustomerInfoComponent);
acmeSalesCustomerInfoComponent.$inject = ['TEMPLATES_URL'];
function acmeSalesCustomerInfoComponent(TEMPLATES) {
return {
templateUrl: TEMPLATES + '/acme-sales-customer-info.html',
bindings: {
data: '<',
onWhateverClick: '&'
},
controller: salesCustomerInfo
};
}
function salesCustomerInfo(/* component controller injections are here */) {
/* implementation details */
} Anyway you could use external file with global var as constants and used IIFE to inject them, example : (function (angular, TEMPLATES_URL) {
'use strict';
angular
.module('sales.widgets')
.component('acmeSalesCustomerInfo', {
templateUrl: TEMPLATES_URL.SALES.WIDGETS + '/acme-sales-customer-info.html',
bindings: {
data: '<',
onWhateverClick: '&'
},
controller: salesCustomerInfo
});
function salesCustomerInfo() {
/* implementation details */
}
})(angular, TEMPLATES_URL); Something like that. |
In that case, I feel it would be much more prudent to have HTML template files compiled into calls to $templateCache.put() in a run block, seeing how components cannot have a factory. I've experimented with this approach since I posted and I find it to be easy and fitting for the style being put forth. In general, you point |
...I didn't mean to close this issue with that comment. Sorry. |
I'm surprised at, with how much this guide pushes modularity in AngularJS, that there is nothing in it that suggests how an app should generate the URLs for
ngInclude
calls and directive/componenttemplateUrl
s. Because manually specifying such paths as you do in various examples detracts from modularity and expects the specified file to be in a very specific place relative to the base URL.For example, relative to my app's index.html, my Angular source code is in
mysite/js/myNg/
, and my compiled AngularJS scripts will sit inmysite/scripts.js
(Angular frontend sitting on top of a SilverStripe PHP backend,mysite
contains all non-framework code as a practice of SilverStripe).If I were to ditch SilverStripe and move my UI to a different platform, or simply place this UI module on a different server by itself, I would have to go through all of my files and manually change each URL to point to the correct paths if the new framework discouraged the same module directory structure as Silverstripe, or if I decide to plop the scripts in a different place altogether.
There are a couple different routes I can think of right here and now to address this, if this is something that the guide should cover.
.html
files in a module, giving them to$templateCache
.The text was updated successfully, but these errors were encountered: