[AngularJS] Provider

This lesson describes what is really happening when you use the angular
factory and how you can make your factories even more dynamic in creation.
This gets further into the internals of AngularJS by showing you how a factory is built dynamically for you and how they have reduced the plumbing you need to make applications.

Factory:

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="utf-8">
  <title>Egghead Videos</title>
  <link rel="stylesheet" href="vendor/foundation/foundation.min.css">
</head>
<body>

  <div ng-app="app" ng-controller="AppCtrl">
    <h1 class="panel">{{title}}</h1>
  </div>

  <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.5/angular.min.js"></script>
  <script type="text/javascript" src="app/js/main.js"></script>
</body>
</html>
var app = angular.module("app", []);

app.factory("game", function() {
    return {
        title: "StarCraft"
    }
})

app.controller("AppCtrl", function($scope, game) {
    $scope.title = game.title
});

"app.factory" is just simply short-hand for using this "provide object":

/**
 * Created by Answer1215 on 12/27/2014.
 */
var app = angular.module("app", []);

app.config(function($provide) {
    $provide.factory("game", function() {
        return{
            title: "StarCraft"
        }
    })
})

app.controller("AppCtrl", function($scope, game) {
    $scope.title = game.title
});

"Factory" is really just shorthand for the provider which sets up a more generic provider which returns things or objects that have "get" functions:

/**
 * Created by Answer1215 on 12/27/2014.
 */
var app = angular.module("app", []);

app.config(function($provide) {
    $provide.provider("game", function() {
        return{
            $get: function() {
                return{
                    title: "StarCraft"
                }
            }
        }
    })
})

app.controller("AppCtrl", function($scope, game) {
    $scope.title = game.title
});

If you want to set up something like game provider and set the type of game:

/**
 * Created by Answer1215 on 12/27/2014.
 */
var app = angular.module("app", []);

app.provider("game", function() {

    var type;
    return{
        setType: function(title) {
            type = title;
        },
        $get: function() {
            return{
                title: type + "Craft"
            }
        }
    }
})

app.config(function(gameProvider) {
    gameProvider.setType("War");
})

app.controller("AppCtrl", function($scope, game) {
    $scope.title = game.title
});

时间: 2024-12-22 12:48:58

[AngularJS] Provider的相关文章

angularJs 解析factory、service、provider

了解angular js factory可以认为是设计模式中的工厂方法,就是你提供一个方法,该方法返回一个对象的实例:对于angularJs的factory,就是先定义一个对象,给这个对象添加属性和方法,然后返回这个对象.例如:var app = angular.module("MyApp",[]);app.factory("MyFactory",function(){ var result = {}; result.greeting = "Hello f

Angularjs 自定义服务 provide 里 provider 方法 以及 factory、 service 方法以及 provider 供应商的概念

Angularjs 自定义服务 provide 里 provider 方法 以及factory. service 方法以及 provider 供应商的概念 学习要点:1. Angularjs 中的 provider 方法2. Angularjs 中的 factory 方法3. Angularjs 中的 service 方法4. provider 供应商的概念5. 研究 ionic 代码中的 services 当你初试 Angular 时,很自然地就会往 controller 和 scope 里堆

AngulaJS实战总结, 带你进入AngularJS世界(待续)

AngulaJS实战总结, 带你进入AngularJS世界(待续) 使用AngularJS  进行Hybrid App 开发已经有一年多时间了,这里做一个总结. 一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM.2.浏览器载入angular.js脚本.3.AngularJS等到DOMContentLoaded事件触发.4.AngularJS寻找ng-app指令,这个指令指示了应用的边界.5.使用ng-app中指定的模块来配置注入器($injector).6.注

使用AngularJS 进行Hybrid App 开发已经有一年多时间了,这里做一个总结

一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM.2.浏览器载入angular.js脚本.3.AngularJS等到DOMContentLoaded事件触发.4.AngularJS寻找ng-app指令,这个指令指示了应用的边界.5.使用ng-app中指定的模块来配置注入器($injector).6.注入器($injector)是用来创建“编译服务($compile service)”和“根作用域($rootScope)”的.7.编译服务($compile se

ionic service

当你初试 Angular 时,很自然地就会往 controller 和 scope 里堆满不必要的逻辑.一定要早点意识到,controller 这一层应该很薄:也就是说,应用里大部分的业务逻辑和持久化数据都应该放在 service 里.很多人问道,关于如何在 controller 里保存持久化数据.这就不是 controller 该干的事.出于内存性能的考虑,controller 只在需要的时候才会初始化,一旦不需要就会被抛弃.因此,每次当你切换或刷新页面的时候,Angular 会清空当前的 c

AngulaJS实战总结

一.AngularJS 初始化加载流程 1.浏览器载入HTML,然后把它解析成DOM. 2.浏览器载入angular.js脚本. 3.AngularJS等到DOMContentLoaded事件触发. 4.AngularJS寻找ng-app指令,这个指令指示了应用的边界. 5.使用ng-app中指定的模块来配置注入器($injector). 6.注入器($injector)是用来创建“编译服务($compile service)”和“根作用域($rootScope)”的. 7.编译服务($comp

Angularjs[13] - 定义服务 $provide 中 provider 方法

服务本身是一个任意的对象,ng提供的服务过程涉及它的依赖注入机制. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div ng-app="myApp"> <div ng-controller=

AngularJS注册和使用服务和常量(provider、factory、service、constant、value)

1.   简介 AngularJS采用MVC架构,提供了服务的注册和以依赖注入方式使用服务的机制.服务是功能(方法)和数据(常量)的抽象,比如系统中关于用户信息相关的功能(头像.昵称.签名.生日.性别等信息的获取与修改)抽象后集中在一个对象中,那么这个对象就可以视为一个服务.服务可以通过angular.Module(常以var app = angular.module('my-app',[])方式获取)和$provider(以依赖注入方式获取)对象注册,常以依赖注入的方式使用使用. 每个服务有一

AngularJS 中 Provider 的用法及区别

在一个分层良好的 Angular 应用中,Controller 这一层应该很薄.也就是说,应用里大部分的业务逻辑和持久化数据都应该放在 Service 里. 为此,理解 AngularJS 中的几个 Provider 之间的区别很有必要. Provider 创建的新服务都可以用来注入.包括: provider factory service constant value 另外,内建的服务 $controller 和 $filter 也可以被注入,同时也可以使用这些服务来获得新的过滤器和控制器.