这里是修真院前端小课堂,每篇分享文从
【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】
八个方面深度解析前端知识/技能,本篇分享的是:
【angular js中的依赖注入是什么?有什么作用?与不用依赖注入的其他框架相比,有何优点? 】
大家好,我是IT修真院北京分院25期的学员,一枚正直纯洁善良的web前端程序员
今天给大家分享一下,修真院官网js任务7,深度思考中的知识点——angular js中的依赖注入是什么?有什么作用?与不用依赖注入的其他框架相比,有何优点?
以前原始社会,我们需要斧子,然后由于还没有社会分工,只能自己打磨一把来使用,对应在程序上是我们需要一个功能的时候只能自己创建,然后使用new等关键字来调用方法。
然后工业社会阶段,我们需要使用斧子的时候,只需要找到工厂,购买斧子就可以使用,共产主义社会,需要斧子的时候甚至不需要购买,直接坐等社会提供。
依赖注入的意思就是我们需要的东西不是我们自己创建的,而是第三方提供的,我们只需要引用就可以使用了。
不需要的时候就不引用它。
依赖注入产生的背景:
传统应用程序通常是在类内部执行代码中主动创建这个类所依赖的其它对象,
从而导致类与类之间发生紧密耦合,使得类难于测试和隔离,最终导致系统的扩展和维护异常困难。
解决方案:
依赖注入用来解决组件之间依赖关系、配置及生命周期管理,
通过转移对象控制权,可以解决类之间的耦合问题,
对象与对象之间是松散耦合关系,更重要的是使得应用程序体系结构变得非常灵活,
很好的体现了面向对象的设计法则之一---依赖设计原则
依赖注入的原理:
程序运行过程中,如需另一个对象协作(调用它的方法、访问他的属性)时,无须在代码中创建被调用者,而是依赖于外部容器的注入,
调用者仅通过声明某个组件就可以获得组件的控制权,而对该组件的依赖关系管理、查找、加载由外部完成。
依赖注入有什么用
作用一:可以使我们能够轻松对组件进行测试
作用二:降低代码的逻辑复杂度
angular提供了几种很好的依赖注入机制,以下5个核心组件用来作为依赖注入
value、factory、service、provider、constant
Value 是一个简单的 javascript 对象,用于向控制器传递值(配置阶段)
var mainApp = angular.module("mainApp", []);
mainApp.value("defaultInput", 5);
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
$scope.number = defaultInput;
$scope.result = CalcService.square($scope.number);
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
工厂是用于返回函数的值。它根据需求创造值,每当一个服务或控制器需要。它通常使用一个工厂函数来计算并返回对应值
// 定义一个模块
var mainApp = angular.module("mainApp", []);
// 创建 factory "MathService" 用于两数的乘积
mainApp.factory('MathService', function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b
}
return factory;
});
// 在 service 中注入 factory "MathService"
mainApp.service('CalcService', function(MathService){
this.square = function(a) {
return MathService.multiply(a,a);
}
});
AngularJS中通过 provider创建一个service、factory等(配置阶段)。Provider 中提供了一个 factory 方法 get(),它用于返回 value/service/factory。
var mainApp = angular.module("mainApp", []);mainApp.config(function($provide) {
$provide.provider('MathService', function() {
this.$get = function() {
var factory = {};
factory.multiply = function(a, b) {
return a * b;
}
return factory;
};
});
});
服务是一个单一的JavaScript包含了一组函数对象来执行某些任务。服务使用service()函数,然后注入到控制器的定义。
var mainApp = angular.module("mainApp", []);
mainApp.service('CalcService', function(MathService){
this.square = function(a) {
return MathService.multiply(a,a);
}
});
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
$scope.number = defaultInput;
$scope.result = CalcService.square($scope.number);
$scope.square = function() {
$scope.result = CalcService.square($scope.number);
}
});
constant(常量)用来在配置阶段传递数值,注意这个常量在配置阶段是不可用的。mainApp.constant("configParam", "constant value");
当我们想要创建一个服务,并且这个服务只需要返回数据时,就可以使用constant(name,value)和value(name,value),不过,它们有两个显著的区别:
1.value不可以在config里注入,但是constant可以
2.value可以修改,但是constant不可以修改,一般直接用constant配置一些需要经常使用的数据。
通常情况下,可以通过value()来注册服务对象或函数,用constant()来配置数据。
依赖注入有哪几种方式
依赖注入有三种方式
1.通过数组标注在方法的参数中声明依赖
2.使用控制器构造方法的$inject属性注入依赖
3.通过方法参数隐式推断依赖
1、数组标注
在代码中通过在第二个数组类型的参数中声明
了$scope,$http等依赖,数组最后一个元素为控制器的构造方法,注意在构造方法的参数列表与前面
的数组元素是一一对应的。
var app = augular.module("app",[]);
app.controller('MyController', ['$scope', '$http',
function($scope, $http) {
}]);
2、$inject属性注入依赖
AngularJS提供了显式的方法来明确定义一个函数在被调用时需要用到的依赖关系。
通过这种方法声明依赖,即使在源代码被压缩、参数名称发生改变的情况下依然能够正常工作。
我们给我们的函数设置的参数名称分别是$scope和$http,然后我们在后面使用
MyController.$inject=['$scope','$http'];
显式的将我们需要的依赖注入到MyController函数中;
var app = augular.module("app",[]);
var MyController = function($scope, '$http') {
}
MyController.$inject = ['$scope', '$http'];
app.controller('MyController', MyController);
3.隐式声明依赖
让构造方法的参数与依赖名字一样即可,注入器可以从方法的参数中推断所依赖的服务
var app = augular.module("app",[]);
app.controller('MyController', function($scope, $http) {
});
这些依赖组件的本质是啥?
factory,service以及value全部都是用来定义一个provider的简写,
它们提供了一种方式来定义一个provider而无需输入所有的复杂的代码。
参考:详解依赖注入
AngularJS中的依赖注入与不用依赖注入的其他框架相比,有何优点?
1. 模板功能强大丰富,并且是声明式的,自带了丰富的Angular指令;
2. 是一个比较完善的前端MVC框架,包含模板,数据双向绑定,路由,模块化,服务,过滤器,依赖注入等所有功能;
3. 依赖注入简化了组件之间处理依赖的过程(即解决依赖)。没有依赖注入,就不得不以某种方式自己查找$scope,很可能得使用全局变量。这虽然能够工作,但是不如AngularJS的依赖注入技术这么简单。
4. 在开发中使用依赖注入的主要好处是AngularJS负责管理组件并在需要的时候提供给相应函数。依赖注入还能够为测试带来好处,因为它允许你使用假的或者模拟的对象来代替真实的组件,从而让开发者专注于程序的特定部分。
PPT
视频:密码: 14dj