ホームページ  >  記事  >  ウェブフロントエンド  >  AngularJS のモジュール化と依存関係の注入について詳しく説明します

AngularJS のモジュール化と依存関係の注入について詳しく説明します

青灯夜游
青灯夜游転載
2021-09-02 10:17:591485ブラウズ

AngularJS のモジュール化と依存関係の注入について詳しく説明します

AngularJS 依存関係注入メカニズムが組み込まれています。アプリケーションを、AngularJS がそれぞれに注入できるさまざまなタイプの複数のコンポーネントに分割できます。アプリケーションをモジュール化すると、コンポーネントの再利用、構成、およびアプリケーションのテストが容易になります。 [関連チュートリアルの推奨事項: "angular チュートリアル"]

AngularJS には、次のコア タイプのオブジェクトとコンポーネントが含まれています:

  • Value
  • Factory
  • Services
  • Providers
  • persistent

これらのコア タイプは、AngularJS 依存関係注入メカニズムを使用して相互に注入できます。この記事の残りの部分では、これらのコンポーネントを定義して相互に挿入する方法について説明します。

AngularJS の値は単純なオブジェクトです。数値、文字列、または JavaScript オブジェクトを指定できます。値は通常、ファクトリ、サービス、またはコントローラーに挿入するための構成として使用されます。

値は AngularJS モジュールに属している必要があります。 AngularJS モジュールに追加される値の 3 つの例を次に示します。

var myModule = angular.module("myModule", []);

myModule.value( “numberValue”,999);

myModule.value( “stringValue的”, “ABC”);

myModule.value("objectValue", { val1 : 123, val2 : "abc"} );

値は、モジュールの value() 関数を使用して定義されます。最初のパラメータは値の名前で、2 番目のパラメータは値そのものです。ファクトリ、サービス、コントローラは、これらの値を名前で参照できるようになりました。

値を注入する

AngularJS コントローラー関数に値を注入するには、次の値を渡します。値と同じ名前のパラメータ Complete (最初の引数を value() 関数に渡すことは、単に定義時の値です)。以下に例を示します。

var myModule = angular.module("myModule", []);

myModule.value( “ numberValue ”,999);

myModule.controller( “myController的”功能($范围,numberValue){

    的console.log(numberValue);

});

関数の 2 番目のパラメータの名前が値と同じであることをコントローラに通知します。

#Factory

Factory は価値を生み出す機能です。サービス、コントローラーなどがファクトリから注入される値を必要とする場合、ファクトリはオンデマンドで値を作成します。この値は、作成されると、注入する必要があるすべてのサービス、コントローラーなどに再利用されます。したがって、ファクトリは、ファクトリ関数を使用して返すオブジェクトを作成できるという点で値とは異なります。オブジェクトの作成時に使用する値をファクトリに注入することもできます。値を使用してこれを行うことはできません。

これは、モジュール上でファクトリを定義し、ファクトリで作成された値が注入されるコントローラの例です:

var myModule = angular.module("myModule", []);
myModule.factory("myFactory", function() {
return "a value";
});

myModule.controller("MyController", function($scope, myFactory) {
console.log(myFactory);
});

ご覧のとおり、これは値オブジェクトの定義と注入に非常に似ています。 。注入されるのはファクトリ関数ではなく、ファクトリ関数によって生成された値であることに注意してください。

ファクトリへの値の注入

ファクトリに値を注入できます。コントローラーに値を注入するのと同じように機能します。以下に例を示します。

var myModule = angular.module("myModule", []);
myModule.value("numberValue", 999);
myModule.factory("myFactory", function(numberValue) {
return "a value: " + numberValue;
});

この例では、注入された値を使用して、ファクトリ関数によって作成されたオブジェクトが作成されます。

サービス

AngularJS のサービスは、一連の関数を含むシングルトン JavaScript オブジェクトです。これらの関数には、サービスがそのジョブを実行するために必要なロジックが含まれています。

AngularJS サービスは、モジュールの

service() 関数を使用して作成されます。以下に例を示します。

function MyService() {this.doIt = function() {console.log("done");}}
var myModule = angular.module("myModule", []);
myModule.service("myService", MyService);

ご覧のとおり、サービスの定義はファクトリと値によって異なります。まず、サービスは単一の名前付き関数として定義されます。これは、AngularJS のサービスが

new キーワードを使用して作成されるためです。したがって、AngularJS はこれを内部的に行います:

var theService = new MyService();

サービスを内部関数を含む関数として定義することに加えて、値や関数を使用するのと同じように、サービスを AngularJS に追加して使用することもできます。次のようにサービスをコントローラーに挿入できます。

function MyService() {
    this.doIt = function() {
        console.log("done");
    }
}


var myModule = angular.module("myModule", []);

myModule.service("myService", MyService);


myModule.controller("MyController", function($scope, myService) {

    myService.doIt();

});

サービスへの値の注入

コントローラーに値を注入したり、コントローラーなどにサービスを注入したりできるのと同じように、サービスに値を注入できます。以下に例を示します。

var myModule = angular.module("myModule", []);

myModule.value  ("myValue"  , "12345");

function MyService(myValue) {
    this.doIt = function() {
        console.log("done: " + myValue;
    }
}

myModule.service("myService", MyService);

MyService 関数のパラメーターの名前が、モジュールに登録されている値と同じであることに注目してください。したがって、この値は作成時にサービスに注入されます。

provider

AngularJS 中的提供者是您可以创建的最灵活的工厂形式。您可以像使用服务或工厂一样使用模块注册提供者,但您要使用该 provider()函数。这是一个 AngularJS 提供程序示例:

var myModule = angular.module("myModule", []);

myModule.provider("mySecondService", function() {
    var provider = {};

    provider.$get = function() {
        var service = {};

        service.doService = function() {
            console.log("mySecondService: Service Done!");
        }

        return service;
    }

    return provider;
});

如您所见,该provider()函数采用 2 个参数。第一个参数是提供者创建的服务/对象的名称。在这种情况下,名称是mySecondService。第二个参数是创建提供程序的函数。注意:提供者本身是一个工厂,因此此时没有从提供者创建实际的服务或对象。仅定义了创建提供程序的函数。

当您查看创建提供程序的函数时,您可以看到提供程序是一个 JavaScript 对象。

JavaScript 提供程序对象包含一个$get()函数。这是提供者的工厂函数。换句话说,该$get()函数会创建提供者创建的任何内容(服务、值等)。在上面的例子中,提供者创建了一个服务对象,其中包含一个名为 的服务函数(标准 JavaScript 函数)doService()

为了将提供者的产品注入控制器,请指定对提供者的依赖,就像使用服务一样。注入控制器的是提供者创建的产品,而不是提供者本身。这是一个 AngularJS 提供程序注入示例:

myModule.controller("MyController", function($scope, mySecondService ) {

    $scope.whenButtonClicked = function() {
        mySecondService.doIt();
    }

});

如您所见,提供者的名称用作控制器函数中的参数。提供者的$get()函数创建的对象将被注入到这个参数中。

配置提供商

可以在模块的配置阶段通过调用其函数来进一步配置提供者。下面是一个例子:

var myModule = angular.module("myModule", []);

myModule.provider("mySecondService", function() {
    var provider = {};
    var config   = { configParam : "default" };

    provider.doConfig = function(configParam) {
        config.configParam = configParam;
    }

    provider.$get = function() {
        var service = {};

        service.doService = function() {
            console.log("mySecondService: " + config.configParam);
        }

        return service;
    }

    return provider;
});

myModule.config( function( mySecondServiceProvider ) {
    mySecondServiceProvider.doConfig("new config param");
});

myModule.controller("MyController", function($scope, mySecondService) {

    $scope.whenButtonClicked = function() {
        mySecondService.doIt();
    }

});

注意 provider 对象现在如何有一个名为 的额外函数doConfig()。此函数可用于在提供程序上设置配置参数。

还要注意对myModule.config()函数的调用。该config函数接受一个函数作为参数。该函数可以配置模块。传递给的函数 config()采用名为 的单个参数mySecondServiceProvider。这与提供者注册的名称相同Provider,后缀为 plus 。后缀告诉 AngularJS 注入提供者本身,而不是提供者创建的对象。在传递给config()函数的mySecondServiceProvider.doConfig()函数内部调用该函数,该函数在提供程序上设置 config 参数。

示例中稍后定义的控制器仅依赖于提供者创建的对象(而不是提供者本身)。它通过获取一个名为mySecondServicename 的参数来实现,该参数是服务提供者注册的名称。如您所见,从$scope.whenButtonClicked()函数内部使用的服务 。

常数

在上一节有关提供程序的部分中,您看到了如何通过module.config() 函数配置提供程序。不幸的是,您不能将值注入到module.config()函数中。相反,您可以注入常量。

AngularJS 中的常量是使用module.constants()函数定义的。这是一个 AngularJS 常量示例:

myModule.constant("configValue", "constant config value");

这个常量现在可以module.config()像这样注入到函数中:

myservices.config( function( mySecondServiceProvider, configValue ) {
    mySecondServiceProvider.doConfig(configValue);
});

如您所见,该参数configValue与常量的名称相匹配,该名称也是 configValue. 因此常量的值将被注入到这个参数中。然后将常量值作为参数传递给提供程序doConfig()上的函数 mySecondServiceProvider

模块之间的依赖关系

如您所见,值、工厂和服务被添加到 AngularJS 模块中。一个模块可以使用另一个模块的值、工厂和服务。为此,模块需要声明对包含它要使用的值、工厂和服务的模块的依赖关系。下面是一个例子:

var myUtilModule = angular.module("myUtilModule", []);

myUtilModule.value("myValue", "12345");


var myOtherModule = angular.module("myOtherModule", [ 'myUtilModule' ]);

myOtherModule.controller("MyController", function($scope, myValue ) {

});

注意第二个模块 ( myOtherModule)如何在myUtilModule传递给angular.module()函数的第二个参数(数组内部)中列出第一个模块 ( )的名称。这告诉 AngularJS 中定义的所有值、工厂和服务也myUtilModule应该在myOtherModule模块中可用。换句话说,myOtherModule 取决于 myUtilModule

其次,注意MyController控制器函数现在如何声明一个名为 的参数myValue。该值将从在myUtilModule模块上注册的值提供。

微小的安全依赖注入AngularJS

当您缩小 JavaScript 时,JavaScript minifier 会用较短的名称替换局部变量和参数的名称。然而,AngularJS 使用控制器函数、工厂、服务和提供者的参数名称来决定将什么注入到他们的工厂函数中。如果名称更改,AngularJS 将无法注入正确的对象。

为了使您的 AngularJS 代码压缩安全,您需要提供要作为字符串注入的对象的名称。您将这些字符串与需要注入值的函数一起包装在一个数组中。这是一个 AngularJS 压缩安全依赖注入示例:

var myapp = angular.module("myapp", ['myservices']);

myapp.controller("AController", ['$scope', function(p1) {
    p1.myvar = "the value";
}]);

本示例将$scope对象注入到p1控制器函数的参数中。

注意控制器函数是如何注册的。不是angular.controller直接将控制器函数传递给函数,而是传递一个数组。该数组包含要注入控制器函数的值的名称,以及控制器函数本身。控制器函数始终是该数组中的最后一个值。如果需要注入多个值,则值名称列在数组的开头,并按它们要注入函数的顺序列出。这是一个缩小安全的多值示例:

var myapp = angular.module("myapp", ['myservices']);

myapp.controller("AController", ['$scope', '$http', function(p1, p2) {
    p1.myvar = "the value";
    p2.get("/myservice.json");
}]);

此示例将$scope对象注入p1参数,并将$http服务注入p2控制器函数的参数。

现在,控制器函数的参数名称不再重要。AngularJS 将使用数组开头的字符串来确定要注入到控制器函数中的内容。

相同的机制可用于工厂、服务和提供者,以提供缩小安全的依赖注入。这是一个小型化安全工厂、服务和提供程序示例:

var myutil = angular.module("myutil", []);


myutil.value("safeValue", "a safe value");


myutil.factory("safeFactory", ['safeValue', function(p1) {
    return { value : p1 };
}]);


function MySafeService(p1){
    this.doIt = function() {
        return "MySafeService.doIt() called: " + p1.value;
    }
}
myutil.service("safeService", ['safeFactory', MySafeService]);


myutil.provider("safeService2", function() {
    var provider = {};

    provider.$get = ['safeService', function(p1) {
        var service = {};

        service.doService = function() {
            console.log("safeService from provider: " + p1.doIt());
        }

        return service;
    }];

    return provider;
});

myapp.controller("AController", ['$scope', 'safeService2', function(p1, p2) {
    p1.myvar = "the value";
    p2.doService();
}]);

尤其要注意的provider的声明。注意,此时的依赖不会对provider工厂函数指定,但对$get()从provider工厂函数内部返回的供应商的功能。实际上,使用具有依赖项名称和函数实现的数组而不仅仅是$get() 函数。

更多编程相关知识,请访问:编程视频!!

以上がAngularJS のモジュール化と依存関係の注入について詳しく説明しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。