(一)Hello Angular

index.html

<!DOCTYPE html>
<html ng-app>
<head>
<title>Test AngularJS</title>
<meta charset="utf-8">
</head>
<body>
<div ng-controller="HelloAngular">
<p>{{greeting.text}},Angular</p>
</div>
</body>
<script src="js/angular.min.js"></script>
<script src="controller/HelloAngular.js"></script>
</html>

HelloAngular.js

function HelloAngular($scope) {
$scope.greeting = {
text: 'Hello'
};
}

angular.min.js

这个文件在网上随便那里下个吧,比如新浪的前端库地址:http://lib.sinaapp.com/js/angular.js/angular-1.1.0/angular.min.js

min是压缩后的文件,在indexl中直接引入链接也可,但还是下载到本地方便呢

在浏览器打开index.hml,看看输出吧~

PS:上面的index.html中的使用ng-controller的方式存在一点点问题,就是快速刷新网页或者是很多数据的时候会有短暂的显示{{greeting.text}},我们可以通过如下的方式解决。

<p>{{greeting.text}},Angular</p>

把index.html中的上面那句换成

<p><span ng-bind="greeting.text"></span>,Angular</p>

在网页没加载好的情况下会显示“,Angular”,而不是“{{greeting.text}},Angular”

(二)错误的控制器使用方法

不要使用通用控制器,进行继承或调用等,每个控制器只负责一小部分的逻辑即可

如下的控制器和首页引用代码是不建议使用的样例:

HTML

<div ng-controller="CommonController">
<div ng-controller="Controller1">
<p>{{greeting.text}}, Angular</p>
<button ng-click="test1()">Click1</button>
</div>
<div ng-controller="Controller2">
<p>{{greeting.text}}, Angular</p>
<button ng-click="test2()">Click2</button>
</div>
<button ng-click="common()">Common</button>
</div>

Controller

function CommonController($scope) {
$scope.common = function() {
alert("Common");
};
} function Controller1($scope) {
$scope.greeing = {
text: 'Hello1'
};
$scope.test1 = function() {
alert("Test1");
};
} function Controller2($scope) {
$scope.greeing = {
text: 'Hello2'
};
$scope.test2 = function() {
alert("Test2");
};
}

虽然可以正常的工作,但是建议把公共的代码抽象成“服务”来实现。

(三)ng-model 的时时显示

<!DOCTYPE html>
<html ng-app>
<head>
<title>Test AngularJS</title>
<meta charset="utf-8">
</head>
<body>
<div>
<input ng-model="qq" />
<p>{{ qq }}</p>
</div>
</body>
<script src="js/angular.min.js"></script>
</html>

上面就是效果,输入什么下面就同步的显示什么

(四)ng-repeat

下面的代码片段是一个简单的循环

<div>
<ol>
<li ng-repeat="name in names">
{{name}} from {{department}}
</li>
</ol>
</div>

可以定义全局的rootScope,这是全局可用的

function CreetCtrl($scope, $rootScope) {
$rootScope.department = 'Angular';
} function ListCtrl ($scope) {
$scope.names = ['David', 'Dong', 'Sellea'];
}

(五)路由,模块,依赖注入

(一)中的控制器定义的是全局变量,这样做是不好的,而且也不模块化

var helloModule = angular.module('HelloAngular', []);
helloModule.controller('helloNgCtrl', ['$scope', function($scope){
$scope.greeting = {
text: 'Hello'
};
}]);

路由自带的也可以,不过使用angular-ui-router这个模块会更好

依赖注入的功能使得AngularJS可以方便的引入模块,在引入最小数量模块的同时实现功能

Hello World会写后,接下来学习些双向数据绑定什么的,这些概念都是第一次听说,AngularJS真是个蛮有趣的东西

AngularJS学习笔记(一)——一些基本知识的更多相关文章

  1. AngularJs学习笔记--Forms

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/forms 控件(input.select.textarea)是用户输入数据的一种方式.Form(表单) ...

  2. AngularJs学习笔记--expression

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/expression 表达式(Expressions)是类Javascript的代码片段,通常放置在绑定 ...

  3. AngularJs学习笔记--directive

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/directive Directive是教HTML玩一些新把戏的途径.在DOM编译期间,directiv ...

  4. AngularJs学习笔记--Guide教程系列文章索引

    在很久很久以前,一位前辈向我推荐AngularJs.但当时我没有好好学习,仅仅是讲文档浏览了一次.后来觉醒了……于是下定决心好好理解这系列的文档,并意译出来(英文水平不足……不能说是翻译,有些实在是看 ...

  5. AngularJs学习笔记--bootstrap

    AngularJs学习笔记系列第一篇,希望我可以坚持写下去.本文内容主要来自 http://docs.angularjs.org/guide/ 文档的内容,但也加入些许自己的理解与尝试结果. 一.总括 ...

  6. AngularJs学习笔记--html compiler

    原文再续,书接上回...依旧参考http://code.angularjs.org/1.0.2/docs/guide/compiler 一.总括 Angular的HTML compiler允许开发者自 ...

  7. AngularJs学习笔记--concepts(概念)

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/concepts 继续.. 一.总括 本文主要是angular组件(components)的概览,并说明 ...

  8. AngularJS学习笔记2——AngularJS的初始化

    本文主要介绍AngularJS的自动初始化以及在必要的适合如何手动初始化. Angular <script> Tag 下面通过一小段代码来介绍推荐的自动初始化过程: <!doctyp ...

  9. IP地址和子网划分学习笔记之《预备知识:进制计数》

    一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...

  10. AngularJs学习笔记--Using $location

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/dev_guide.services.$location 一.What does it do? $loc ...

随机推荐

  1. Cocos2dx-3.1.1 冒险01----&gt; 文件夹结构、新项目project创建并执行

    windows开发环境:window7.vs2012.python2.7.6 Cocos2d-x 3.1.1的完整文件夹例如以下:比起曾经的2.x的版本号来说分类更规范了 watermark/2/te ...

  2. 示例:Netty 处理 TCP数据分包协议

    一个.Netty解决TCP协议的数据分包的想法 我们知道通过TCP协议发送接收数据时,假设数据过大.接收到的数据会是分包的.比方:                                   ...

  3. 【C++知识汇总】运营商 &amp; 运算符重载

    [运算符]        在进行运算时,假设右括号的话我们知道先运算哪个,那假设没有括号了.算术运算符,关系运算符,逻辑运算符,位运算符.赋值运算符,++.--运算符等等,那么多的运算符.我们先算哪边 ...

  4. [SignalR]注册路由

    原文:[SignalR]注册路由 1.注册SignalR路由 在Asp.Net中,若是SignalR 1.*版本,在Global.asax文件中定义如下: 在Asp.Net中,若是SignalR 2. ...

  5. 我异常-VS2012“System.AccessViolationException: 试图读取或写入保护内存。”

       我的系统是win7 64位 系统 安装的是 Visual studio 2012.从SVN上下载了源代码.一个B/S的系统.能正常载入登陆页,但在输入登录信息要登录的时候,就报错了:     - ...

  6. 文件类似的推理 -- 超级本征值(super feature)

         基于内容的变长分块(CDC)技术,能够用来对文件进行变长分块.而后用来进行反复性检測,广泛用于去重系统中.后来又出现了对相似数据块进行delta压缩,进一步节省存储开销. 所以就须要一种高效 ...

  7. 记2014“蓝桥杯全国软件大赛&quot;决赛北京之行

    5月29,30日 最终到了这一天.晚上有数据结构课,10点多的火车,我们就没有去上课,下午在宿舍里收拾东西,晚上8点左右从南校出发,9点半多到达火车站和老师学长学姐们会和. 第一次去北京,第一次买的卧 ...

  8. SVN常见错误两项纪录

    1.svn cleanup failed–previous operation has not finished; run cleanup if it was interrupted 也许前clean ...

  9. Android-采用Matrix对Bitmap加工

    1.Android正在使用Matrix放.旋转.平移.斜切等变换的. Matrix是一个3*3的矩阵,其值相应例如以下: 以下给出详细坐标相应变形的属性|scaleX, skewX, translat ...

  10. Oracle 用户权限管理方法

    Oracle 用户权限管理方法 sys;//系统管理员,拥有最高权限 system;//本地管理员,次高权限 scott;//普通用户,密码默认为tiger,默认未解锁 sys;//系统管理员,拥有最 ...