AngularJS学习笔记(一)——一些基本知识
(一)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学习笔记(一)——一些基本知识的更多相关文章
- AngularJs学习笔记--Forms
原版地址:http://code.angularjs.org/1.0.2/docs/guide/forms 控件(input.select.textarea)是用户输入数据的一种方式.Form(表单) ...
- AngularJs学习笔记--expression
原版地址:http://code.angularjs.org/1.0.2/docs/guide/expression 表达式(Expressions)是类Javascript的代码片段,通常放置在绑定 ...
- AngularJs学习笔记--directive
原版地址:http://code.angularjs.org/1.0.2/docs/guide/directive Directive是教HTML玩一些新把戏的途径.在DOM编译期间,directiv ...
- AngularJs学习笔记--Guide教程系列文章索引
在很久很久以前,一位前辈向我推荐AngularJs.但当时我没有好好学习,仅仅是讲文档浏览了一次.后来觉醒了……于是下定决心好好理解这系列的文档,并意译出来(英文水平不足……不能说是翻译,有些实在是看 ...
- AngularJs学习笔记--bootstrap
AngularJs学习笔记系列第一篇,希望我可以坚持写下去.本文内容主要来自 http://docs.angularjs.org/guide/ 文档的内容,但也加入些许自己的理解与尝试结果. 一.总括 ...
- AngularJs学习笔记--html compiler
原文再续,书接上回...依旧参考http://code.angularjs.org/1.0.2/docs/guide/compiler 一.总括 Angular的HTML compiler允许开发者自 ...
- AngularJs学习笔记--concepts(概念)
原版地址:http://code.angularjs.org/1.0.2/docs/guide/concepts 继续.. 一.总括 本文主要是angular组件(components)的概览,并说明 ...
- AngularJS学习笔记2——AngularJS的初始化
本文主要介绍AngularJS的自动初始化以及在必要的适合如何手动初始化. Angular <script> Tag 下面通过一小段代码来介绍推荐的自动初始化过程: <!doctyp ...
- IP地址和子网划分学习笔记之《预备知识:进制计数》
一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...
- AngularJs学习笔记--Using $location
原版地址:http://code.angularjs.org/1.0.2/docs/guide/dev_guide.services.$location 一.What does it do? $loc ...
随机推荐
- 看你的门-攻击服务器(4)-HTTP参数注入攻击
首先需要声明.这纯粹是没有远见和有点真才实学开发一个愚蠢的观点,只为web参考系统安全. 1.HTTP参数注入攻击 參数,被用做后端HTTP请求中的參数,这个时候就有可能会导致HTTP參数注入. 一个 ...
- apache本地多域配置(wampserver本地多域配置)
当我们在当地发展.通常在浏览器中输入 http://localhost/项目目录名 测试Web文件,你有没有想过在本地浏览器中,输入自己设定的名字进入项目目录,名相关的问题. 比方我想配置一个主域名w ...
- ehcache历史变迁及常用API的使用(转)
ehcache是一个用Java实现的使用简单,高速,实现线程安全的缓存管理类库,ehcache提供了用内存,磁盘文件存储,以及分布式存储方式等多种灵活的cache管理方案.同时ehcache作为开放源 ...
- Eclipse build launcher 3具体步骤
1. 下载launcher 3源代码 (需要FQ) git clone https://android.googlesource.com/platform/packages/apps/Launche ...
- hdu 4870 Rating(可能性DP&高数消除)
Rating Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- hdu 1542 Atlantis 段树区,并寻求,,,尼玛真坑人数据,不要打开一小阵!
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- Binary Tree Maximum Path Sum [leetcode] dp
a(i):在节点i由于单边路径的最大结束 b(i):在节点i路径和 a(i) = max{ i->val, i->val + max{a(i->left), a(i->righ ...
- Flex列在一个表格式的数字值
1.问题背景 一般的.表格中展示的比率.对照率的处理是:保留两位小数,并向上保留 2.实现实例 <? xml version="1.0" encoding="utf ...
- Android环境结构Android Studio解决方法不能启动,第一次
android Studio 下载和eclipse 的android开发环境的搭建下载包: 联系: http://pan.baidu.com/s/1kTKJZkN password: qxqf And ...
- C++ Primer 学习笔记_56_ 类和数据抽象 --消息处理演示示例
拷贝控制 --消息处理演示样例 说明: 有些类为了做一些工作须要对复制进行控制. 为了给出这种样例,我们将概略定义两个类,这两个类可用于邮件处理应用程序.Message类和 Folder类分别表示电子 ...