当前位置: 首页 > news >正文

建设网站五个步骤美发网站带手机版

建设网站五个步骤,美发网站带手机版,微信表情开放平台,网络系统运维依赖注入#xff08;DI#xff09;的好处不再赘言#xff0c;使用过spring框架的都知道。angularjs作为前台js框架#xff0c;也提供了对DI的支持#xff0c;这是javascript/jquery不具备的特性。angularjs中与DI相关有angular.module()、angular.injector()、 $injector、…依赖注入DI的好处不再赘言使用过spring框架的都知道。angularjs作为前台js框架也提供了对DI的支持这是javascript/jquery不具备的特性。angularjs中与DI相关有angular.module()、angular.injector()、 $injector、$provide。对于一个DI容器来说必须具备3个要素服务的注册、依赖关系的声明、对象的获取。比如spring中服务的注册是通过xml配置文件的bean标签或是注解Repository、Service、Controller、Component实现的对象的获取可以ApplicationContext.getBean()实现依赖关系的声明即可以在xml文件中配置也可以使用Resource等注解在java代码中声明。在angular中module和$provide相当于是服务的注册injector用来获取对象angular会自动完成依赖的注入依赖关系的声明在angular中有3种方式。下面从这3个方面介绍下angular的DI。 1、angular.module()创建、获取、注册angular中的模块 The angular.module() is a global place for creating, registering and retrieving Angular modules.When passed two or more arguments, a new module is created. If passed only one argument, an existing module (the name passed as the first argument to module) is retrieved。 // 传递参数不止一个,代表新建模块;空数组代表该模块不依赖其他模块 var createModule angular.module(myModule, []);// 只有一个参数(模块名),代表获取模块 // 如果模块不存在,angular框架会抛异常 var getModule angular.module(myModule);// true,都是同一个模块 alert(createModule getModule); 该函数既可以创建新的模块也可以获取已有模块是创建还是获取通过参数的个数来区分。 angular.module(name, [requires], [configFn]); name字符串类型代表模块的名称 requires字符串的数组代表该模块依赖的其他模块列表如果不依赖其他模块用空数组即可 configFn用来对该模块进行一些配置。 现在我们知道如何创建、获取模块了那么模块究竟是什么呢官方的Developer Guide上只有一句话You can think of a module as a container for the different parts of your app – controllers, services, filters, directives, etc.现在我还不太理解大致就是说模块是一些功能的集合如控制器、服务、过滤器、指令等子元素组成的整体。现在解释不了先遗留。 2、$provide和模块的关系 The $provide service has a number of methods for registering components with the $injector. Many of these functions are also exposed on angular.Module. 之前提到过module和provide是用来注册服务到injector中的。查看官方的API可以看到$provide提供了provide()、constant()、value()、factory()、service()来创建各种不同性质的服务angular.Module中也提供了这5个服务注册方法。其实2者功能是完全一样的就是用来向DI容器注册服务到injector中。 官方API下的auto有$provide 和 $injectorImplicit module which gets automatically added to each $injector.按照字面意思是说每一个injector都有这2个隐含的服务。但1.2.25版本中感觉没有办法获取injector中的$provide。不知道这是为什么?一般来说也不需要显示使用这个服务直接使用module中提供的API即可。 var injector angular.injector(); alert(injector.has($provide));//false alert(injector.has($injector));//true 3、angular.injector() 使用angular.injector();也能获取到注入器但是没有和模块绑定。这种做法是没有意义的相当于是你创建了一个空的DI容器里面都没有服务别人怎么用呢。正确的做法是在创建注入器的时候指定需要加载的模块。 // 创建myModule模块、注册服务 var myModule angular.module(myModule, []); myModule.service(myService, function() {this.my 0; });// 创建herModule模块、注册服务 var herModule angular.module(herModule, []); herModule.service(herService, function() {this.her 1; });// 加载了2个模块中的服务 var injector angular.injector([myModule,herModule]); alert(injector.get(myService).my); alert(injector.get(herService).her); 如果加载了多个模块那么通过返回的injector可以获取到多个模块下的服务。这个例子中如果只加载了myMoudle那么得到的injector就不能访问herMoudle下的服务。这里特别需要注意下angular.injector()可以调用多次每次都返回新建的injector对象。 var injector1 angular.injector([myModule,herModule]); var injector2 angular.injector([myModule,herModule]);alert(injector1 injector2);//false 4、angular中三种声明依赖的方式 angular提供了3种获取依赖的方式inference、annotation、inline方式。 // 创建myModule模块、注册服务 var myModule angular.module(myModule, []); myModule.service(myService, function() {this.my 0; });// 获取injector var injector angular.injector([myModule]);// 第一种inference injector.invoke(function(myService){alert(myService.my);});// 第二种annotation function explicit(serviceA) {alert(serviceA.my);}; explicit.$inject [myService]; injector.invoke(explicit);// 第三种inline injector.invoke([myService, function(serviceA){alert(serviceA.my);}]);其中 annotation和inline方式对于函数参数名称没有要求是推荐的做法inference方式强制要求参数名称和服务名称一致如果JS代码经过压缩或者混淆那么功能会出问题不建议使用这种方式。
http://www.dnsts.com.cn/news/117831.html

相关文章:

  • 用DW做的网站怎么弄成链接WordPress的站内地图
  • 新手用什么框架做网站比较好哈尔滨网站建设有限公司
  • 手机网站用什么软件什么直播软件可以看那个东西
  • 网页ui设计分析焦作网站seo
  • 网站开发培训多少钱兰州有什么互联网公司
  • 电商网站分析福州定制网站开发制作
  • 有没有免费网站建设房地产网站建设内容
  • 网站开发人员的要求怎么做推销产品的网站
  • 枣庄手机网站开发公司微商城开发公司有哪些比较好
  • 做网站需要注意多少页app软件下载安装到手机
  • ps做汽车网站下载素描网站怎么做
  • 织梦网站后台地址佛山营销型网站设计
  • 自己用笔记本做网站好看的知名企业网站
  • 揭阳网站建站网站科技网站推荐
  • 做视频网站要注意什么上海注册公司引流v信xiala5
  • 蓝色旅游网站模板萧山区建设工程质量监督站网站
  • 服装网站建设效果福建鞋子做淘宝图片网站
  • 销售网站有哪些天津市城乡建设网
  • 软件开发兼职网站phpcms网站模版下载
  • 注册网站授权书怎么写兼职网站平台有哪些
  • 天津网站制作公司电话wordpress积分代码
  • 长沙建设网站的公司游戏代理怎么找平台
  • 吐鲁番好网站建设设计免费自己做网站吗
  • 监控网站模板下载陕西头条新闻最新消息
  • 做网站还 淘宝集团网站建设新闻
  • 分析某个网站建设如何看网站建立时间
  • 建设公司网站应有哪些功能生活分类信息网站大全
  • 佛山仿站定制模板建站网站手机端自适应
  • 有些网站勤换域名wordpress增加下载量显示
  • 网站 wordpress企业logo设计免费生成器