angularjs入门

当前位置:首页>AngularJS>angularjs入门>AngularJS快速入门-javascript编程【1】

AngularJS快速入门-javascript编程【1】

时间:2015-08-07 16:47来源:网络整理 作者:KKWL 点击:
【提要】本篇《AngularJS快速入门-javascript编程【1】》特别为需要编程学习的朋友收集整理的,仅供参考。内容如下: 怎么样快速了解AngularJS? 相信很多初学者都有过或者类似的疑问,

    【提要】本篇《AngularJS快速入门-javascript编程【1】》特别为需要编程学习的朋友收集整理的,仅供参考。内容如下:

    怎么样快速了解AngularJS?

    相信很多初学者都有过或者类似的疑问,其实这个问题没有标准的答案,每个人的技术背景、工作经验等等都不经相同,所以学习AngularJS的切入点肯定也就不同,我之前初略使用过knockoutjs,当我第一眼看到AngularJS的Helloworld案例后,顿时就被声明式的语法和强大的双向绑定特性所吸引。

    其实AngularJS的官方网站首页的几个例子已经很好的展示了AngularJS的一些特性,下面我就从几个例子一步一步的讲解AngularJS吸引人的东西并且实际项目中是怎么使用ng的。

    首先还是从第一个经典的Hello world 案例说起,如下HTML(如果你在墙外,可以直接访问https://angularjs.org ,右边就有运行效果)。

    -------------------------------------

    

Hello {{yourName}}!

    会一点HTML的人都知道,这个界面有个input输入框,下面有个的标题,内容是 Hello {{yourName}}!。

    实现的效果是:当用户在input输入框输入内容时,下面的h1标题内部实时显示 ”Hello 输入的内容!"

    与普通的HTML不同之处有以下几点:

    html标签上加了一个 ng-app属性,意思是整个HTML都属于AngularJS控制;

    input输入框加了一个 ng-model="yourName",这样就表明input的value与内存中的变量yourName是双向绑定的,在输入框输入”world“,内存中的yourName变量就变成了”world“,反之亦然;

    h1标签内部有个{{yourName}},这个表示内存中的yourName属性和h1节点的内容实现了双向绑定,yourName为”world“后,h1的内容就会变成”Hello world!“,"{{}}"是ng的表达式。

    传统的做法:

    在input上添加change事件,当触发change事件后,获取input输入框的内容,再组合字符串,通过DOM操作修改h1的innerHTML,前提可能要给 input和h1加上id或者name属性。

    通过这个例子.

    大家应该能够很明显的感觉到AngularJS的优势了,不用写一行JS代码,就能实现一个很完美的功能。

    上面的例子只是展示了一个简单的双向绑定功能,AngularJS既然是一个MV*框架,上面说的yourName是Model,HTML是View,那么*(Controller或者ViewModel)去哪了?我稍微修改下上面的例子:

    -------------------------------------

    

Clear Input ValueHello {{yourName}}!

    可以看到我修改的地方:

    在div上加了一个ng-controller="testCtrl",表示这个DIV内部所有元素都属于testCtrl管辖;

    同时script加了一个函数testCtrl,这个函数有个$scope的参数,并且函数内给$scope.yourName赋了一个”world“的值,而且还有个clearInputValue函数,这个$scope大家可以理解为ViewModel,ng Model的载体(或者说上下文),所有模板中使用的ng变量都在$scope上,初始化给$scope.yourName赋值说明input输入框的Value默认就为”world“;

    界面上多了一个Button,button上有个ng-click="clearInputValue()",ng-click表示给这个Button绑定了一个click事件,点击Button执行clearInputValue函数,这个函数给$scope.yourName赋值了空字符串,清空了输入框的值。

    从这个例子中大家可以清楚的看到AngularJS是怎么样实现MV*的,具体传统的做法大家可以自行在脑海中想想,ng的实现方式是不是更加的简单,至此你有没有被ng所吸引???

    大家看了上面的例子后,或许有些人就开始疑问了,每个controller绑定一个函数,这个函数的第一个参数是$scope,所有的数据和方法都在$scope上下文里面,而且这个函数是全局函数,如果界面上有很多controller呢?不会有很多个全局函数吧?(注意:这种全局函数的方式在1

------分隔线----------------------------