使用模块定义AngularJS组件
一、模块创建/查找 module
当创建一个模块时,必须指定name和requires参数,即使你的模块并不存在依赖
var myApp=angular.module("exampleApp",[]);
如果没有requires参数,则为查找该模块
var myApp=angular.module("exampleApp");
二、定义控制器 controller
myApp.controller("dayCtrl",function($scope){
// do something
})
控制器是用module.controller方法来定义的,该方法接收两个参数:控制器名称和一个工厂函数。
在创建控制器时提供的参数$scope组件是用于向视图提供数据的,而且只有通过$scope配置的数据才能用于表达式和数据绑定中。
三、定义指令 directive
调用module.directive方法,提供要创建的指令的名称以及一个用于创建指令的工厂函数即可。
myApp.directive("directiveName",function(){
// 工厂函数
return function(scope,element,attrs){
// 工人函数
}
})
不能够依赖于工厂函数或工人函数在某个特定时刻被调用。当你想注册一个构件时,你得调用module方法(此处是directive方法)。当建立构件时angularjs将调用工厂函数,然后当需要使用该构件时就会调用工人函数,这三个事件不一定按顺序立即调用(也就是说,在你的工厂函数被调用前其他module方法有可能被调用,在你的工人函数被调用前其他工厂函数也有可能被调用)。
工人函数的三个参数分别为:scope视图的作用域,用于检查在视图中可用的数据,element指令所应用到的元素,是一个jqLite对象,attrs该元素的属性,提供了指令所应用到的元素的属性的完整集合。
四、定义过滤器 filter
filter方法用于定义一个过滤器,其参数是新过滤器的名称以及一个在调用时将会创建过滤器的工厂函数。过滤器本身就是函数,接受数据值并进行格式化,这样就可以显示该值了。
myApp.filter("filterName",function(){
// 工厂函数
return function(data){
// 工人函数
}
})
1)使用过滤器
过滤器应用在视图里所包含的模板表达式中。数据绑定或者表达式后紧跟一个竖线(“|”字符)以及过滤器的名称
{{day|filterName}}
2) 引入过滤服务$filter
向指令的工厂函数里添加一个$filter参数,用于告诉angular当我的函数被调用时要接收的过滤器服务对象。$filter服务允许我访问所有已定义的过滤器,包括自定义的过滤器,通过名称获取过滤器。
var f=$filter("filterName");
五、定义服务 service factory provider
服务是提供在整个应用程序中所使用的任何功能的单例对象。单例的意思是说只有一个对象实例会被angular创建出来,并被程序需要服务的各个不同部分所共享。
1)service
myApp.service("serviceName",function(){
this.name="Mary";
this.age="18";
})
service方法具有两个参数:服务名和调用后用来创建服务对象的工厂函数。当angular调用工厂函数时,会分配一个可通过this关键字访问的新对象。
2)value
module.value用于创建返回固定值和对象的服务。
myApp.value("valueName",value);
AngularJS假设工厂函数的任意参数都声明了需要解析的依赖。如下
var now=new Date();
myApp.service("days",function(now){
this.today=now.getDay();
})
这段代码将报错,因为调用工厂函数时,Angular不会为now参数使用哪个局部变量,当引用now变量时它已经不再作用域中了。
因此你可以这样使用:
var now=new Date();
myApp.value("nowValue",now);
myApp.service("days",function(nowValue){
this.today=nowValue.getDay();
}) 或者 利用闭包 var now=new Date();
myApp.service("days",function(){
this.today=now.getDay();
})
3) constant
这个方法与value类似,但是创建的服务可以作为config方法所声明的依赖使用(值服务却做不到这一点)
六、config & run
module.config和module.run方法注册了那些在angularJS应用的生命周期的关键时刻所调用的函数。传给config方法的函数在当前模块被加载后调用,config方法通常通过注入来自其他服务的值(比如链接的详细信息或者用户凭证)的方式用于配置模块。传给run方法的函数在所有模块被加载后以及解析完他们的依赖后才会被调用。
myApp.config(function(){ })
.run(function(){ })
使用模块定义AngularJS组件的更多相关文章
- Angular06 组件、模块、父子组件之间的数据传递
1 创建组件 进入到angular项目的根目录,执行如下命令 ng g component test-component 注意:执行完上述命令后在angular项目的src/app文件夹下就会多出一个 ...
- 每天记录一点:NetCore获得配置文件 appsettings.json vue-router页面传值及接收值 详解webpack + vue + node 打造单页面(入门篇) 30分钟手把手教你学webpack实战 vue.js+webpack模块管理及组件开发
每天记录一点:NetCore获得配置文件 appsettings.json 用NetCore做项目如果用EF ORM在网上有很多的配置连接字符串,读取以及使用方法 由于很多朋友用的其他ORM如S ...
- 通俗的讲,就是高层模块定义接口,低层模块负责实现。 Bob Martins对DIP的定义: 高层模块不应依赖于低层模块,两者应该依赖于抽象。 抽象不不应该依赖于实现,实现应该依赖于抽象。
通俗的讲,就是高层模块定义接口,低层模块负责实现. Bob Martins对DIP的定义: 高层模块不应依赖于低层模块,两者应该依赖于抽象. 抽象不不应该依赖于实现,实现应该依赖于抽象. 总结出使用D ...
- 基于SqlSugar的开发框架循序渐进介绍(12)-- 拆分页面模块内容为组件,实现分而治之的处理
在早期的随笔就介绍过,把常规页面的内容拆分为几个不同的组件,如普通的页面,包括列表查询.详细资料查看.新增资料.编辑资料.导入资料等页面场景,这些内容相对比较独立,而有一定的代码量,本篇随笔介绍基于V ...
- CMD规范(通用模块定义规范)(翻译)
最近在使用sea.js.大家知道sea.js遵循CMD规范.该规范的英文说明很简洁,我试着翻译了一下,旨在交流. Common Module Definition 通用模块定义规范 This spec ...
- Sea.js学习3——Sea.js的CMD 模块定义规范
在 Sea.js 中,所有 JavaScript 模块都遵循 CMD(Common Module Definition) 模块定义规范.该规范明确了模块的基本书写格式和基本交互规则. 在 CMD 规范 ...
- 详解模块定义(.def)文件
一个完整的Windows应用程序(C++程序)通常由五种类型的文件组成:源程序文件,头文件,资源描述文件,项目文件,模块定义文件.本文主要讲解模块定义文件. 模块定义 (.def)文件为链接器提供有关 ...
- 2016-03-15:关于VS中模块定义文件
1 def模块定义文件 在使用开源库libx265时,因x265项目的头文件x265中有如下的宏定义 #ifdef X265_API_IMPORTS #define X265_API __declsp ...
- CMD 模块定义规范
在 Sea.js 中,所有 JavaScript 模块都遵循 CMD(Common Module Definition) 模块定义规范.该规范明确了模块的基本书写格式和基本交互规则. 在 CMD 规范 ...
随机推荐
- Leetcode641.Design Circular Deque设计循环双端队列
设计实现双端队列. 你的实现需要支持以下操作: MyCircularDeque(k):构造函数,双端队列的大小为k. insertFront():将一个元素添加到双端队列头部. 如果操作成功返回 tr ...
- 使用Data Lake Analytics + OSS分析CSV格式的TPC-H数据集
0. Data Lake Analytics(DLA)简介 关于Data Lake的概念,更多阅读可以参考:https://en.wikipedia.org/wiki/Data_lake 以及AWS和 ...
- javascript DOM知识脑图
- CSS基础教程:群组化选择器
常常我们的CSS 样式中会有好几个地方需要使用到相同的设定时,一个一个分开写会是一件满累人的工作,重覆性太高且显得冗长,更不好管理....在CSS 语法的基本设定中,就可以把这几个相同设定的选择器合并 ...
- IDEA maven项目查自动查看依赖关系,解决包冲突问题
在maven项目中找到pom.xml,打开. <dependencies> <dependency> <groupId>org.apache.storm</g ...
- Loadrunner常用分析点
Loadrunner常用的分析点 一.在Vuser(虚拟用户状态)中 1.Running Vusers:提供了生产负载的虚拟用户运行状态的相关信息,可以帮助我们了解负载生成的结果.(即用户在几分钟左右 ...
- SDUT-3398_数据结构实验之排序一:一趟快排
数据结构实验之排序一:一趟快排 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定N个长整型范围内的整数,要求输出以给 ...
- vscode中编译输出c++是乱码
vscode中编译输出c++是乱码的解决 环境说明:windows下面运行vscode win + R 右键属性 查看当前编码状态 知道当前环境的编码格式后,可以改变vscode上c++的格式 点击v ...
- prepareStatement设置参数,mysql数据出现中文‘?’的情景与解决方式
在prepareStatement中传入中文的参数,mysql数据库中出现“?”号 try { Class.forName("com.mysql.jdbc.Driver"); co ...
- docker search
命令:docker search [root@iZ943kh74qgZ ~]# docker search --help Usage: docker search [OPTIONS] TERM Sea ...