标签:
Sometimes you have javascript object defined:
//value object var droidValue = { name: ‘‘, speak: function () { return "Hi I am " + this.name; } }; var droid = droidValue; droid.name = ‘bb-8‘; console.log(droid.speak());
If want to use this object in AngularJS, can use ‘value‘:
//angularjs (function () { "use strict"; //value object var droidValue = { name: ‘‘, speak: function () { return "Hi I am " + this.name; } }; angular.module(‘app‘, []) .value(‘droid‘, droidValue) .controller(‘DroidController‘, DroidController) function DroidController(droid) { var droidCtrl = this; droid.name = ‘bb-8‘; droidCtrl.message = droid.speak(); } })();
//angularjs (function () { "use strict"; //module pattern (configurable per app) function droidProvider() { var greeting = ‘‘; return { configure: function (settings) { greeting = settings.greeting; }, $get: function () { return { name: ‘‘, speak: function () { return greeting + this.name; } }; } }; } angular.module(‘app‘, []) .config(function (droidProvider) { droidProvider.configure({greeting: "Greetings I am "}); }) .provider(‘droid‘, droidProvider) .controller(‘DroidController‘, DroidController); function DroidController(droid) { var droidCtrl = this; droid.name = "ig-88"; droidCtrl.message = droid.speak(); } })();
Important to understand:
return { configure: function (settings) { greeting = settings.greeting; }, $get: function () { return { name: ‘‘, speak: function () { return greeting + this.name; } }; } };
return { name: ‘‘, speak: function () { return greeting + this.name; } };
[AngularJS] Services, Factories, and Providers -- value & Providers
标签:
原文地址:http://www.cnblogs.com/Answer1215/p/5045307.html