要说现在前端最火热的东西,node.js以及谷歌推出的Angular绝对是不二之选,本人也是最近才开始学习这个东西,写下这篇文章,就当做是自己的一个学习见证吧!
Angular。一听名字就很高大上啊。那么它是做什么的呢,简单的说就在MVC模式上升级——>MVVM
模式。AngularJS通过新的属性和表达式扩展了HTML。他可以构建单页面应用程序,即SPA(SPAs:Single Page Applications)。
下载
官方网址:https://angularjs.org/(国内的墙,你懂的,一般都很高!)
CDN地址:http://cdn.bootcss.com/angular.js/1.3.0-beta.13/angular.js
简单使用
首先它是一个 JavaScript框架,所以使用之前需要使用script标签引入。
ng-app
这个指令决定了angularjs的作用域范围,你可以如下使用
html
<html ng-app> … </html>
如果只想让angularjs渲染整个页面,也可以使用
html
<div ng-app='myapp'> …… </div>
来渲染其中的一部分。
ng-model
ng-model,当你的数据模型被改变的时候,譬如ng-model=’test’,其中这个test的数值被改变的时候,绑定的{{test}}的数值也将跟随改变,也就是连接到ng-model中的test也跟随改变,如下
html
<!doctype html> <html> <head> <script src="angular.min.js" type="text/javascript"></script> <title>learing argularjs--widuu</title> </head> <body ng-app> <input ng-model='test' > <p> hello {{test}} </p> </body> </html>
结果如图所示:
怎么样。不错吧。通过短短的几行代码就可以实现几倍jquery实现的功能。当然这还只是angular的冰山一角,传闻当时google一个项目在用angular之前有15000+代码。使用angular以后只用了3000+左右。当然具体的情况我不敢确定哈。但是这足以说明angular的强大了!
controller
controller是angular.Module中的方法。
使用方法为controller(name,constructor);
其中name是controller的名字,constructor是控制器构造函数,我们利用代码来看看:
html
<!doctype html> <html> <head> <script src="angular.min.js" type="text/javascript"></script> <script type="text/javascript"> var app = angular.module('myapp',[]); app.controller('hockor',function($scope){ $scope.test="hello word"; }); </script> <title>learing argularjs--widuu</title> </head> <body ng-app='myapp' ng-controller='hockor' > <input ng-model='test'> <p> hello {{test}} </p> </body> </html>
执行代码以后大家可以看到和上一个效果是一样的,这就是controller的作用。即控制器。代码中的$scope和module可能很陌生。没关系,接下来我就会解释了。
$scope
顾名思义,这是指作用域。谈到JS的作用域,相信很多从事多年JS开发的人都还是有一点晕,JS的预解析是招聘中的一个重要考察点。好了废话不多说,咱们还是通过代码来看问题。(以后的代码我指贴出重要部分了哈,ng-app指令默认放在HTML标签上面)
html
<p ng-controller="hockor">{{name}}</p>
Javascript
function hockor($scope){ $scope.name = "hello hockor"; }
代码中的控制器指向了hockor这个函数,hockor这个函数中我定义了1个形参是$scope,这是angular内置的,我现在是把name这个变量挂载到$scope上的,这样name这个属性才能被找到,如果单纯的写var name = "XXX",这样是无效的,它就是一个普通的变量,而不是我们想要的数据。
接下来我们再来看个例子。
html
<div ng-controller="hockor"> <p>{{name}}</p> </div> <p> {{age}}</p>
javascript
function hockor($scope,$rootScope){ $scope.name = "hello hockor"; $rootScope.name = "Just test"; }
这一次大家可以看到除了$scope以外我们还有一个参数$rootScope。通过其名字我们也可以猜出,它就是一个顶级作用域,也就是全局作用域。本来上面代码中的{{age}}是没有挂载到hockor这个控制器下的,但是执行代码我们可以发现他还是被解析成了Just test这句话,这就是Angular中的作用域!
注意:以上我们所写的形参$scope.$rootScope是不能修改为其他值的哦!
为什么呢?
大家可以观察上面的ng-controller,我们写的是一个函数名。并且不带括号,这和我们普通的调用JS函数不一样,普通的调用JS函数是需要加括号的,并且可以传参在里面,而且形参的名字是不受限制的。而在这里就不需要写括号了,只需要写一个函数名,angular自动帮我们依赖注入了参数,所以形参$scope.$rootScope是不能修改为其他值的,必须按照angular的格式来写。
OK,第一篇到此结束!
原创文章:转载请注明!-hockor