zoukankan      html  css  js  c++  java
  • [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
    });

  • 相关阅读:
    打印图片的属性和实现另存图片功能以及使用numpy
    opencv3.3 安装环境教程以及实现个图片读取功能
    在linux 创建网络会话和绑定两块网卡
    安装yum仓库
    C#添加错误日志信息
    关于使用宏将csv批量转换成xls的分享
    C#关于MySQL中文乱码问题
    无法启动iis express web服务器解决
    关于关闭WPS锁屏屏保及设置电脑自动关闭显示屏及休眠的分享
    为什么QQ能上却打不开网页呢?
  • 原文地址:https://www.cnblogs.com/Answer1215/p/4189424.html
Copyright © 2011-2022 走看看