(一)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. EJB(一)认识ejb

    什么是ejb? 相同仍旧在这个系列博客之处,谈谈对ejb的认识和理解.         sun微公司对于ejb的定义大体是这种,ejb是一套用于开发和部署分布式组件的的架构.採用ejb的架构应用能够是 ...

  2. 提升Mac os x 10.10+xcode6.1之后,Cocoapods发生故障的解决方案

    提升Mac OS X 10.10+Xcode 6.1之后.Cocoapods图书馆管理也依赖于相应升级.现在最新的Release版本号是 0.34.在之前的版本号.当数据库更新和管理,你会遇到一个错误 ...

  3. Androida规划nt打包

    1.准备工作 (1)首先安装好ant工具 (2)生成keystore 在jdk的bin文件夹下 输入 keytool -genkey -alias android.keystore -keyalg R ...

  4. 一张图让你看清Java集合类(Java集合类的总结)

    如今关于Java集合类的文章非常多,可是我近期看到一个非常有意思图片,基本上把Java集合的整体框架都给展现出来了.非常直观. watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  5. windows 10 install oracle 12c error:[ INS-30131 ]

    "[ INS-30131 ] the Initial Setup That Is Required to Run the Installation Program Validation Wa ...

  6. css Tab选项卡1

    利用   锚点原理 以及overflow:hiden 结合,实现纯  css  tab 方式 兼容ie6 + 适合单个tab   不需要js          注意点  红色方框的   a 对应a   ...

  7. android 内存泄漏分析技巧

    java虚拟机执行一般都有一个内存界限,超过这个界限,就会报outofmemory.这个时候一般都是存在内存泄漏.解决内存泄漏问题,窃以为分为两个步骤:分析应用程序是否真的有内存泄漏,找到内存泄漏的地 ...

  8. Cocos2d-x使用Luajit将Lua脚本编译成bytecode,启用加密

    http://www.cocoachina.com/bbs/read.php?tid=205802 lua脚本进行加密,查了一下相关的资料 ,得知lua本身能够使用luac将脚本编译为字节码(byte ...

  9. python 3.4.0 简单的print &#39;hello world&#39;,出错--SyntaxError: invalid syntax

    问题描写叙述: win7下安装的python 3.4.0版本号, 在命令行里写入简单的输出语句: print 'hello world' 然后enter,结果返回结果为: SyntaxError: i ...

  10. 一张地图告诉你,只JavaScript不够!

    这将是JavaScript语法,你真的会一JavaScript嘛.看看这个图片!超好用JavaScript一本书的摘录游.熊儿.快去学习! 版权声明:本文博客原创文章.博客,未经同意,不得转载.