AngularJS1.X学习笔记1-整体看看
听说 明天是愚人节,这与我有什么关系呢!我可 不想被愚弄,但是但是,我这么笨怎么才能不被愚弄呢?左思右想,我决定从现在开始闭关,闭关干啥哩?学习!学习AngularJS。以前学习过Angular的,不过很久没用都忘的差不多了,所以决定好好复习一下。这两天我将多发几篇随笔,记录一下我的学习过程。参考用书《AngularJS高级程序设计-Adam Freeman》,我会参考书中的例子做一遍,谈谈自己的理解。现在按照作者的思路先总体把握一下,后面再一个一个看。
一、Module对象
调用angular.module()可以创建一个module对象实例或者返回一个module对象。
创建:augular.module("nameApp",[]),第二个参数声明你要依赖的模块对象数组,不依赖传空数组
返回已经创建的:angular.module("nameApp");不指定第二个参数则返回已经创建的名字为nameApp的模块,如果此前没有创建这个模块则出错
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>module Test</title>
- </head>
- <body>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var nameApp = angular.module("nameApp",[]);
- console.log(nameApp);
- </script>
- </body>
- </html>
假如去掉第二个参数
得到的module对象的实例有如下方法和属性(当然还有其他的,上面那个图有)
模块是Angular应用的起点,它可以和HTML文档的一部分关联,可以帮助组织代码和组件。
二、controller
1、简单的例子
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>controller Test1</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4>Today is {{day || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- $scope.day = dayNames[new Date().getDay()];
- })
- </script>
- </body>
- </html>
这里我们调模块的controller方法,定义了一个控制器,在工厂函数中声明了$scope依赖,他是一个视图作用域,定义在这个$scope上的方法和属性可以在视图中方法,将控制器绑定到视图的方法是使用ng-app指令。
关于依赖注入:简单说就是拿来主义,要用什么直接拿,会有人给你的。这真是不错啊,比如你要一百万,然后就有人打一百万给你,想想就爽!!
2、一个控制器用于一个多个视图
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>controller Test2</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4>Today is {{day || "(不晓得)"}}</h4>
- </div>
- <div ng-controller='dayCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- $scope.day = dayNames[new Date().getDay()];
- $scope.date = new Date().getDate();
- })
- </script>
- </body>
- </html>
3、多个控制器多个视图
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>controller Test3</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4>Today is {{day || "(不晓得)"}}</h4>
- </div>
- <div ng-controller='dateCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- $scope.day = dayNames[new Date().getDay()];
- });
- myApp.controller('dateCtrl',function($scope){
- $scope.date = new Date().getDate();
- })
- </script>
- </body>
- </html>
效果和上面的例子是相同的。(这个编辑器有待改进啊,代码加粗要点半天才可以!)
三、directive
指令是干嘛的,感觉指令就是将视图,和其他组件搞到一起了,方便复用。
一个简单的例子
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>directive Test1</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4highlight='星期五'>Today is {{day || "(不晓得)"}}</h4><!-- important -->
- </div>
- <div ng-controller='dayCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- $scope.day = dayNames[new Date().getDay()];
- $scope.date = new Date().getDate();
- });
- myApp.directive("highlight",function(){<!-- important -->
- return function(scope,element,attrs){
- if(scope.day == attrs["highlight"]){
- element.css("color","red");
- }
- }
- })
- </script>
- </body>
- </html>
比较喜欢星期五,星期五意味着放假,所以做了一个指令,星期五的时候就显示红色。
分析一下directive的用法,它接受两个参数,第一个是指令名字,第二个是一个工厂函数,要求工厂函数返回一个工人函数;工人函数中接受三个参数,第一个scope表示应用指令的视图的作用域,第二个表示指令所在元素的jq包装对象(ng里面个有个迷离版的jq叫jqLIte),第三个参数表示指令所在元素的特性集合。
四、filter
1、自己定义一个filter并使用之
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>filter Test1</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4>Today is {{day || "(不晓得)" | toDay}}</h4> <!-- important -->
- </div>
- <div ng-controller='dayCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- $scope.day = new Date().getDay();
- $scope.date = new Date().getDate();
- })
- .filter("toDay",function(){ <!-- important -->
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- return function(value){
- return dayNames[value];
- }
- })
- </script>
- </body>
- </html>
原来我们是在控制器里面格式化数据的,现在我们用filter在视图中格式化数据,这样更加灵活一点。
filter用法分析:第一个参数为过滤器名字,第二个参数为一个工厂函数,工厂函数里返回一个工人函数,工人函数接受一个参数,为应用过滤器的那个值。对比一下directive,有木有很像。
然而然而,我们的highlight呢?想想。。。我们解决一下,不对我好像用错例子了(上面的例子本来就没有highlight,尴尬),但是我想你已经知道我要说什么了,不改了。
2、在指令中使用filter
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>filter Test2</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4 highlight='星期五'>Today is {{day || "(不晓得)" | toDay}}</h4>
- </div>
- <div ng-controller='dayCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope){
- $scope.day = new Date().getDay();
- $scope.date = new Date().getDate();
- })
- .filter("toDay",function(){
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- return function(value){
- return dayNames[value];
- }
- });
- myApp.directive("highlight",function($filter){ <!-- important --->
- var toDay = $filter("toDay") <!-- important --->
- return function(scope,element,attrs){
- if(toDay(scope.day) == attrs["highlight"]){ <!-- important --->
- element.css("color","red");
- }
- }
- })
- </script>
- </body>
- </html>
I think you know!我们将我们的filter用到了directive。当然并不是要这么干才能解决这个问题,我只想告诉你可以这样干。
五、服务(provider,service,factory)
后面理会发现这三个都是fprovider,就像三角形和四边行都是多边形一样。这里先那个service感受一下。
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>service Test1</title>
- </head>
- <body>
- <div ng-controller='dayCtrl'>
- <div>
- <h3>AngularJS App</h3>
- </div>
- <h4>Today is {{day || "(不晓得)"}}</h4>
- </div>
- <div ng-controller='dayCtrl'>
- <h4>今天是几号: {{date || "(不晓得)"}}</h4>
- </div>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.controller('dayCtrl',function($scope,day){ <!--- important -->
- var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
- $scope.day = dayNames[day.day]; <!--- important -->
- $scope.date = day.date; <!--- important -->
- }).service("day",function(){ <!--- important -->
- this.day = new Date().getDay();
- this.date = new Date().getDate();
- })
- </script>
- </body>
- </html>
原来我们要自己在控制器中创建Date对象,从里面取出我们要的值,现在直接用day这个服务给我们提供的服务就可以了。
service用法分析:第一个参数是服务名字,第二个参数 是一个工厂函数,工厂函数定义你的服务内容。
六、定义值
1、先上一个value()方法
- <!DOCTYPE html>
- <html lang="en" ng-app="myApp">
- <head>
- <meta charset="UTF-8">
- <title>value test1</title>
- </head>
- <body>
- <h1 ng-controller="dayCtrl">
- 今天是{{date}}号
- </h1>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.value("nowDate",new Date()) <!-- important-->
- .controller('dayCtrl',function($scope,nowDate){ <!-- important-->
- $scope.date = nowDate.getDate();
- })
- </script>
- </body>
- </html>
value()方法可以将任意值封装起来,用作依赖注入,这就说所有东西都可以作为依赖注入的对象(不知道这句话严谨否)。
2、再上一个constant
- <!DOCTYPE html>
- <html lang="en" ng-app="myApp">
- <head>
- <meta charset="UTF-8">
- <title>value test1</title>
- </head>
- <body>
- <h1 ng-controller="dayCtrl">
- 今天是{{date}}号
- </h1>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",[]);
- myApp.constant("nowDate",new Date()) <!-- important-->
- .controller('dayCtrl',function($scope,nowDate){ <!-- important-->
- $scope.date = nowDate.getDate();
- })
- </script>
- </body>
- </html>
信了你的邪,这不是一样的吗?是的。自由男人(那本书的作者)是这样说的,constant是定义一个常量,可以在config方法声明的依赖中使用,value定义的是变量,不能在config声明的依赖中使用。
七、使用模块组织代码
是这个样子,我们可以把不同的组件放在不同的模块,然后声明依赖,比如说将控制器放在一个模块,将过滤器放在另一个模块,这样呢就可以很方便的维护了。
代码时刻来临。。。。搞图吧,好看结构
八、使用模块生命周期工作
config()方法的函数会在当前模块被加载后调用,而run()方法会在所有模块加载后执行。啥意思,我也没看懂,实验一下先。
- <!DOCTYPE html>
- <html lang="en" ng-app='myApp'>
- <head>
- <meta charset="UTF-8">
- <title>life test</title>
- </head>
- <body>
- <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
- <script type="text/javascript">
- var myApp = angular.module("myApp",["module1","module2"]);
- myApp.config(function(){
- console.log("myApp config excute:");
- })
- .run(function(){
- console.log("myApp fun excute");
- });
- angular.module('module1',[])
- .config(function(){
- console.log("module1 config excute");
- })
- .run(function(){
- console.log("module1 fun excute");
- });
- angular.module('module2',[])
- .config(function(){
- console.log("module2 config excute");
- })
- .run(function(){
- console.log("module2 fun excute");
- });
- </script>
- </body>
- </html>
看看这个执行的顺序,因为myApp是依赖module1,module2的所以,module1和module2会先加载,按照config和run的特性我们知道module1加载后,他的config方法执行,然后加载module2后,执行module2的config方法,然后加载完myApp,myApp的config方法执行,至此所有模块加载完毕,开始执行run方法,他是按照加载完成的顺序执行的。用这样的生命周期方法有啥用呢?我猜测,config是可以对模块进行一些初始化的配置,从他的名字就能猜出来,configure是配置的意思,run方法估计是这个模块要等待所有依赖加载完后做一些事情。
给到一篇参考文章:http://blog.csdn.net/peter_zhou123/article/details/53222287直接拿过来算了,文章很短
最近,在项目中遇到需要在 config 阶段中注入一些service的情况,然而 factory,service 还有 value 是不能在 config 中注入的,先看一个清单:
服务/阶段 | provider | factory | service | value | constant |
---|---|---|---|---|---|
config阶段 | Yes | No | No | No | Yes |
run 阶段 | Yes | Yes | Yes | Yes | Yes |
注意,provider 在config阶段,注入的时候需要加上 provider 后缀,可以调用非 $get 返回的方法在 run 阶段注入的时候,无需加 provider 后缀,只能调用 $get 返回的方法
至此,对Angular的整体上有了一个认识,接下来的几个小时里,我将一个一个组件认真学习,同时完成学习笔记。如果你觉得我的笔记写的不错的话,请关注我,毕竟这会增加一点我学习的动力。再如果你要转在这篇文章的话,请把文章的链接放上去。好了,我去上个厕所先。
AngularJS1.X学习笔记1-整体看看的更多相关文章
- Bootstrap学习笔记之整体架构
之前有粗略地看过一下Bootstrap的内容,不过那只是走马观花式地看下是怎么用的,以及里面有什么控件,所以就没想着记笔记.现在由于要给部门做分享,所以不得不深入地去学习下,不然仅是简单地说下怎么用, ...
- AngularJS1.X学习笔记2-数据绑定
上一篇从整体上认识了Angular,从现在开始更加深入的学习Angular的特性.本次学习的是数据绑定.应该所有的MVC框架都会用到数据绑定,比如我所知道的ThinkPHP.struts等,只有实现了 ...
- AngularJS1.X学习笔记6-控制器和作用域
经过一番艰苦卓绝的鏖战,我终于来到了控制器和作用域部分.控制器作为MVC的C,其重要性不可谓不重要:作用域决定了你可以拿到哪些东西,亦是分外重要.现在就来学习一下两个东西.去看看$apply,$wat ...
- AngularJS1.X学习笔记5-加强版的表单
大家愚人节快乐!表单是沟通服务器端和客户端的桥梁,为数据从客户端传到服务端打开了一扇大门.AngularJS增加了一些新特性,使我们能够更加方便的操作表单.OK!开始学习!学习使我快乐. 一.双向数据 ...
- AngularJS1.X学习笔记4-内置事件指令及其他
AngularJS为我们定义了一系列事件指令,方便我们对用户的操作作出响应.甚至他还有一个可选模块提供了触摸事件和手势事件的支持,为移动端开发提供了可能.现在开始学习一下AngularJS的事件指令. ...
- AngularJS1.X学习笔记3-内置模板指令
前面学习了数据绑定指令,现在开始学习内置模板指令.看起来有点多,目测比较好理解.OK!开始! 一.ng-repeat 1.基本用法 <!DOCTYPE html> <html lan ...
- AngularJS1.X学习笔记13-动画和触摸
本文主要涉及了ngAnimation和ngTouch模块,自由男人讲的比较少,估计要用的时候还要更加系统的学习一下. 一.安装 没错,就是酱紫. 二.玩玩动画 <!DOCTYPE html> ...
- AngularJS1.X学习笔记12-Ajax
说到Ajax,你一定是思绪万千,想到XMLHttpRequest,$.ajax(),跨域,异步之类的.本文将探讨一下AngularJS的Ajax. 一.一个简单的例子 <!DOCTYPE htm ...
- AngularJS1.X学习笔记8-自定义指令(上)
AngulaJS的指令是一种非常强大的特性,一个ng-repeat就能让我们非常方便的展示一个数据列表,指令相当于是一个组件,为我们将一些东西封装起来了,提供了复用的可能性.个人认为自定义指令还是比较 ...
随机推荐
- ctags使用说明详解
ctags使用说明详解 一.ctags是干什么的 ctags的功能:扫描指定的源文件,找出其中所包含的语法元素,并将找到的相关内容记录下来. 我用的是Exuberant Ctags 二.ctags可以 ...
- devexpress表格gridcontrol实现列统计,总计,平均,求和等。
1.在许多项目中,经常要实现对某些列的统计.devexpress控件gridcontrol实现这些功能只需要设置某些属性,就可以达到要求了.以下例举了一个统计班级总数,人数总计,分数总计的案例.效果图 ...
- 不启动VS2013,直接打开帮助文档的方法
在使用VS2013做开发的时候,当我们需要查询一个知识点时,直接按"F1"键就可以打开配套的帮助文档.如果在没有打开VS2013的情况想查看它的帮助文档,我们应该怎么办呢?我们能否 ...
- GDOI2015 解题报告
首先嘛现在发现题目这么水我还啥都没想出来正是呵呵了.接下来就口胡下GDOI的题解吧 PS:代码什么的要请联系我 题目:快戳我 Day1: T1:这个嘛,可以先找到起点所能到达的每个点然后判断该点能否到 ...
- IOS高级开发~开机启动&无限后台运行&监听进程
一般来说, IOS很少给App后台运行的权限. 仅有的方式就是 VoIP. IOS少有的为VoIP应用提供了后台socket连接,定期唤醒并且随开机启动的权限.而这些就是IOS上实现VoIP App的 ...
- 关于Mysql的索引
索引是指把你设置为索引的字段A的内容储存在一个独立区间S里,里面只有这个字段的内容.在找查这个与这个字段A的内容时会直接从这个独立区间里查找,而不是去到数据表里查找.找到的这些符合条件的字段后再读取字 ...
- HTTP严格安全传输(HTTP Strict Transport Security, HSTS)chromuim实现源码分析(二)
HTTP严格安全传输(HTTP Strict Transport Security, HSTS)chromuim实现源码分析(一) 下面来查看其他对保存HSTS信息的enabled_sts_hosts ...
- SerfJ REST
SerfJ提供了一个MVC架构,但它不包含任何模型,其主要特点是使用控制器collerlor,通过这些collerlor管理REST请求.可帮助你开发优雅的MVC架构的应用,使用惯例重于配置的思路,无 ...
- C#基础——结构体
集合:数组:同一类型,固定长度集合:不同类型,不固定长度 要使用集合,必须先引用命名空间:using System.Collections; 定义:ArrayList arr = new ArrayL ...
- maven 项目发布时,无法引用 修改的domain 问题
其实是在bo 的smart-score 里面引用了这个interface 所以还要把 smart -Score 重新发布一下.让这个smart 引用 新的 Player-service 中的i ...