很久没有系统学习一个新技术了,angularjs将会比较系统的讲解这个技术的语法、应用。次类型的博客将会持续更新,博主也是一个初学者,如果有问题欢迎留言讨论。

  angularjs简介。

  angularjs在创建优质的web应用的方面有着令人难以置信的能力。你将会用到一些概念,这个概念将会贯穿整个应用。并非杜撰了这些概念,而只是从其他开发环境中大量地借用了这些比较成功的习惯用语,然后以适合HTML、浏览区一起其他常见的web标准的方式来实现了这些概念。

  多页面的应用会在服务端创建HTML,把HTML和数据装配并混合起来,然后把生成的页面发送到浏览器中。在某种程度上,大部分单页应用也叫作AJAX应用,也会做同样的事情。在这一方面。Angularjs在处理方式完全不同,模版和数据都会发送到浏览器中,然后客户端进行专配。这样一来,服务器的角色就是仅仅为这些模版提供一些静态资源,然后为这些模版提供所需的正确的数据。

  我们能来看一个例子,看看angular是如何把数据和模版进行装配的。我们会例行公事的写一个“Hello World!”,但是不会把“Hello world!”写成一个完整的字符串打印出来。

  为了实现这一功能,我把模版放在hello.html中:

  

 <!DOCTYPE html>
<html ng-app="hello">
<head>
<meta charset="UTF-8">
<title>Hello World!</title>
<script src="static/js/angular.js" type="text/javascript"></script>
<script src="static/app/controller/controller.js" type="text/javascript"></script>
</head>
<body ng-controller="HelloController">
<p>{{greeting.text}},world</p>
</body>
</html>

  

 !(function (){
var app= angular.module('hello',[]);
app.controller('HelloController', function ($scope) {
$scope.greeting = {text: "Hello"};
});
}());

  使用任意的浏览器打开hello.html,你会看到如下效果:

  

  与之前广泛的应用相比,这里有些非常有趣的东西需要注意:

  1、HTML里没有ID或者class来定义事件和监听器。

  2、当把HelloController中的greeting.text设置成其他的文本的时候,我们没有必要设置任何的监听事件和回调函数

  3、HelloController只是一个普通的javascript类,并没有继承任何angularjs类

  4、HelloController可以获取到它的$scope类,而没有必要去创建它

  5、没有必要去自己调用HelloController的构造方法,或者指定合适调用它

  

  数据绑定

   当数据改变的时候,我们会把HTML模版和数据混合起来,然后把获得的DOM数据插入到UI中,但是,当根据用户的修改状态来修改数据的时候可能要编写极其复杂度代码来保证数据的状态是正确的,并且UI和JAVASCRIPT是属性要同时正确。

  但是,我们不需要编写代码就能做到以上所有事情会怎样呢?如果我们可以仅仅声明UI中某个部分需要映射到javascript属性,然后它们自己去同步又会怎样呢?这样是编码风发就叫数据绑定

  为了实战中看到这一点,我们把第一个例子,让它变成动态的。目前的情况是greeting.text是一个静态的值,之后再也不会修改它。为了让它变成动态的,我们来增加一个输入框,会把greeting.text值变成用户输入的值:

  

 <!DOCTYPE html>
<html ng-app="hello">
<head>
<meta charset="UTF-8">
<title>Hello World!</title>
<script src="static/js/angular.js" type="text/javascript"></script>
<script src="static/app/controller/controller.js" type="text/javascript"></script>
</head>
<body ng-controller="HelloController">
<input type="text" ng-model="greeting.text"/>
<p>{{greeting.text}},world</p>
</body>
</html>
 !(function (){
var app= angular.module('hello',[]);
app.controller('HelloController', function ($scope) {
$scope.greeting = {text: "Hello"};
});
}());

我们在没有添加任何事件的时候UI就自动刷新了,这一机制对于来自服务器的数据同样有效。angular会自动把输入框和花括号中的文本更新为所获得的新值。

依赖注入

如代码所示,我们并不需要编写任何代码去获得$scope对象,而是$scope对象会自动传递给我们,我们并不需要调用任何函数去调用它,只需要办$scope对象放到HelloController中我们就可使用它了,正如以后的讲解当中,$scope并不是我们唯一能获得的对象,如:如果我们想获得浏览器中URL上的操作,可以适应$location对象,只需把$location对象放到HelloController中就可以使用了。

 !(function (){
var app= angular.module('hello',[]);
app.controller('HelloController', function ($scope,$location) {
$scope.greeting = {text: "Hello"};
//在这里进行一些$locaotion操作
});
}());
指令

angularjs最强大的功能之一就是,你可以把模版编写成HTML的形式。之所以可以做到这一点,是因为,我们引入了一款强大的DOM转换引擎,可以用他来扩展HTML语法。

有了这个东东,你就可以实现一些神奇的功能!

  

Angularjs简介的更多相关文章

  1. AngularJS学习之旅—AngularJS 简介(一)

    一.AngularJS 简介 1.AngularJS 是一个 JavaScript 框架. AngularJS 是一个 JavaScript 框架.它是一个以 JavaScript 编写的库.Angu ...

  2. 【03】AngularJS 简介

    AngularJS 简介 AngularJS 是一个 JavaScript 框架.它可通过 <script> 标签添加到 HTML 页面. AngularJS 通过 指令 扩展了 HTML ...

  3. AngularJS简介与四大特征

    1.1 AngularJS简介 AngularJS  诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀的前端JS框架,已经被用于Google的多款产品当中.A ...

  4. Angular企业级开发(1)-AngularJS简介

    AngularJS介绍 AngularJS是一个功能完善的JavaScript前端框架,同时是基于MVC(Model-View-Controller理念的框架,使用它能够高效的开发桌面web app和 ...

  5. 01、AngularJs简介

    AngularJs致力于减轻程序员在开发Ajax应用过程的痛苦.做前端的童鞋都知道,当在开发Ajax应用时,我们在与后台交互的同时,还在不断的手动操作Dom,诸如自己组装后台数据,渲染Html标签生成 ...

  6. AngularJS 简介

    AngularJS 是一个 JavaScript 框架. 它可通过 <script> 标签添加到 HTML 页面. <script src="http://apps.bdi ...

  7. AngularJS 简介、指令、表达式

    AngularJS 是一个 JavaScript 框架.它可通过 <script> 标签添加到 HTML 页面. AngularJS 通过指令扩展了 HTML,且通过表达式绑定数据到 HT ...

  8. AngularJS开发指南1:AngularJS简介

    什么是 AngularJS? AngularJS 是一个为动态WEB应用设计的结构框架.它能让你使用HTML作为模板语言,通过扩展HTML的语法,让你能更清楚.简洁地构建你的应用组件.它的创新点在于, ...

  9. 跨平台移动APP开发进阶(四)AngularJS简介

    AngularJS 是一个为动态WEB应用设计的结构框架.它能让你使用HTML作为模板语言,通过扩展HTML的语法,让你能更清楚.简洁地构建你的应用组件. 它的创新点在于,利用 数据绑定 和 依赖注入 ...

随机推荐

  1. JNI 从C文件向Java文件传递多个参数

    JNI C主函数 #include <jni.h> #include <string.h> #include <android/log.h> #include &q ...

  2. Ubuntu12.04-64bits搭建FFmpeg环境

    所有的环境搭建动作请参考FFMpeg官方网站:http://www.ffmpeg.org/index.html 1. 获取源代码: git clone git://source.ffmpeg.org/ ...

  3. linux ant 解决 错误: 找不到或无法加载主类 org.apache.tools.ant.launch.Launcher

    在使用ant进行java程序编译的时候出错.错误提示: Error: Could not find or load main class org.apache.tools.ant.launch.Lau ...

  4. JS中多个onload冲突解决办法

    一  多个window.onload冲突 在一个页面中有两个JavaScript 分别都用到了window.onload一个是:window.onload=externallinks,另一个是:win ...

  5. Get the largest sum of contiguous subarray in an int array

    When I finished reading this problem,I thought I could solve it by scanning every single subarray in ...

  6. linux下无法删除文件的原因

    不废话,直接上命令操作.记录备案以后方便查阅 [root@xxxxxxx .ssh]# rm -rf authorized_keys2 rm: 无法删除"authorized_keys2&q ...

  7. notepad++下载Subversion插件,显示intalltion of subversion failed

    notepad++安卓subversion的插件不成功,是因为我们下载TortoiseSVN客户端的版本跟subversion的版本不兼容 一.背景: 在新浪云平台上开发微信公众账号,因为要使用SVN ...

  8. C语言中volatilekeyword的作用

    一.前言 1.编译器优化介绍: 由于内存訪问速度远不及CPU处理速度,为提高机器总体性能,在硬件上引入硬件快速缓存Cache,加速对内存的訪问.另外在现代CPU中指令的运行并不一定严格依照顺序运行,没 ...

  9. nodejs保存文件的问题

    从前端到那里jar包失败: 保存到本地管理机jar包md5sum上传正确的值md5sum值不相等.并上传 处理 没有错误,说明保存过程中的错误: 前面是base64然后转码后jar包内容放进reque ...

  10. FileZilla命令行实现文件上传以及CreateProcess实现静默调用

    应用需求:         用户在选择渲染作业时面临两种情况:一是选择用户远程存储上的文件:二是选择本地文件系统中的文件进行渲染.由于渲染任务是在远程主机上进行的,实际进行渲染时源文件也是在ftp目录 ...