zoukankan      html  css  js  c++  java
  • Part 20 Create custom service in AngularJS

    Whenever the case changes from lower to upper, a single space character should be inserted. This means the string "AngularVideoTutorial" should be converted to"Angular Video Tutorial"

    create custom service in angularjs 

    Let us first see, how to achieve this without using a custom service. 

    HtmlPage1.html :  

    <!DOCTYPE html>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <title></title>
        <script src="Scripts/angular.js"></script>
        <script src="Scripts/Script.js"></script>
        <link href="Styles.css" rel="stylesheet" />
    </head>
    <body ng-app="myModule">
        <div ng-controller="myController">
            <table>
                <tr>
                    <td>Your String</td>
                    <td><input type="text" ng-model="input" /> </td>
                </tr>
                <tr>
                    <td>Result</td>
                    <td><input type="text" ng-model="output" /></td>
                </tr>
                <tr>
                    <td></td>
                    <td>
                        <input type="button" ng-click="transformString(input)"
                               value="Process String" />
                    </td>
                </tr>
            </table>
        </div>
    </body>
    </html>

    Script.js : Notice, all the logic to insert a space when the case changes is in the controller. There are 2 problems with this
    1. The controller is getting complex
    2. This logic cannot be reused in another controller. If you have to use this logic in another controller, we will have to duplicate this same code with in that controller. 

    When we use our own custom service to encapsulate this logic, both of these problems go away. The custom service can be injected into any controller where you need this logic. 

    var app = angular
            .module("myModule", [])
            .controller("myController", function ($scope) {
                $scope.transformString = function (input) {
                    if (!input)
                        return input;
     
                    var output = "";
     
                    for (var i = 0; i < input.length; i++) {
                        if (i > 0 && input[i] == input[i].toUpperCase()) {
                            output = output + " ";
                        }
     
                        output = output + input[i];
                    }
     
                    $scope.output = output;
                };
            });

    Now let's create a custom service. Here are the steps
    1. Add a JavaScript file to the Scripts folder in the project. Name it stringService.js.
    2. Copy and paste the following code. Notice we are using the factory method to create and register the service with Angular. 

    app.factory('stringService', function () {
        return {
            processString: function (input) {
                if (!input)
                    return input;
     
                var output = "";
     
                for (var i = 0; i < input.length; i++) {
                    if (i > 0 && input[i] == input[i].toUpperCase()) {
                        output = output + " ";
                    }
     
                    output = output + input[i];
                }
     
                return output;
            }
        };
    });

    3. Copy and paste the following code in Script.js. Notice that we have injected stringService into the controller function. 

    var app = angular
            .module("myModule", [])
            .controller("myController", function ($scope, stringService) {
                $scope.transformString = function (input) {
                    $scope.output = stringService.processString(input);
                };
            });

    4. On HtmlPage1.html, only one change is required and that is to reference the stringService.js script file

    <script src="Scripts/stringService.js"></script>
  • 相关阅读:
    大话设计模式之代理模式
    大话设计模式之装饰者模式
    策略模式与简单工厂模式
    一个简单的使用Quartz和Oozie调度作业给大数据计算平台执行
    oozie JAVA Client 编程提交作业
    HashMap分析及散列的冲突处理
    cmp排序hdoj 1106排序
    定义member【C++】cstddef中4个定义
    目录启动CXF启动报告LinkageError异常以及Java的endorsed机制
    算法代码[置顶] 机器学习实战之KNN算法详解
  • 原文地址:https://www.cnblogs.com/gester/p/5433323.html
Copyright © 2011-2022 走看看