AngularJS入门教程(零):引导程序


Posted in Javascript onDecember 06, 2014

我们现在开始准备编写AngularJS应用——phonecat。这一步骤(步骤0),您将会熟悉重要的源代码文件,学习启动包含AngularJS种子项目的开发环境,并在浏览器端运行应用。

进入angular-phonecat目录,运行如下命令:

git checkout -f step-0

该命令将重置phonecat项目的工作目录,建议您在每一学习步骤运行此命令,将命令中的数字改成您学习步骤对应的数字,该命令将清除您在工作目录内做的任何更改。

运行以下命令:

node scripts/web-server.js

来启动服务器,启动后命令行终端将会提示Http Server running at http://localhost:8000,请不要关闭该终端,关闭该终端即关闭了服务器。在浏览器中输入http://localhost:8000/app/index.html来访问我们的phonecat应用。

现在,在浏览器中您应该已经看到了我们的初始应用,很简单,但说明我们的项目已经可以运行了。

应用中显示的“Nothing here yet!”是由如下HTML代码构建而成,代码中包含了AngularJS的关键元素,正是我们需要学习的。

app/index.html

<!doctype html>

<html lang="en" ng-app>

<head>

    <meta charset="utf-8">

    <title>My HTML File</title>

    <link rel="stylesheet" href="css/app.css">

    <link rel="stylesheet" href="css/bootstrap.css">

    <script src="lib/angular/angular.js"></script>

</head>

<body>

<p>Nothing here {{'yet' + '!'}}</p>

</body>

</html>

代码在做什么呢?

ng-app指令:

<html lang="en" ng-app>

ng-app指令标记了AngularJS脚本的作用域,在<html>中添加ng-app属性即说明整个<html>都是AngularJS脚本作用域。开发者也可以在局部使用ng-app指令,如<div ng-app>,则AngularJS脚本仅在该<div>中运行。

AngularJS脚本标签:

<script src="lib/angular/angular.js"></script>

这行代码载入angular.js脚本,当浏览器将整个HTML页面载入完毕后将会执行该angular.js脚本,angular.js脚本运行后将会寻找含有ng-app指令的HTML标签,该标签即定义了AngularJS应用的作用域。

双大括号绑定的表达式:

<p>Nothing here {{'yet' + '!'}}</p>

这行代码演示了AngularJS模板的核心功能——绑定,这个绑定由双大括号{{}}和表达式'yet' + '!'组成。

这个绑定告诉AngularJS需要运算其中的表达式并将结果插入DOM中,接下来的步骤我们将看到,DOM可以随着表达式运算结果的改变而实时更新。

AngularJS表达式Angular expression是一种类似于JavaScript的代码片段,AngularJS表达式仅在AngularJS的作用域中运行,而不是在整个DOM中运行。

引导AngularJS应用

通过ngApp指令来自动引导AngularJS应用是一种简洁的方式,适合大多数情况。在高级开发中,例如使用脚本装载应用,您也可以使用bootstrap手动引导AngularJS应用。

AngularJS应用引导过程有3个重要点:

1.注入器(injector)将用于创建此应用程序的依赖注入(dependency injection);
2.注入器将会创建根作用域作为我们应用模型的范围;
3.AngularJS将会链接根作用域中的DOM,从用ngApp标记的HTML标签开始,逐步处理DOM中指令和绑定。

一旦AngularJS应用引导完毕,它将继续侦听浏览器的HTML触发事件,如鼠标点击事件、按键事件、HTTP传入响应等改变DOM模型的事件。这类事件一旦发生,AngularJS将会自动检测变化,并作出相应的处理及更新。

上面这个应用的结构非常简单。该模板包仅含一个指令和一个静态绑定,其中的模型也是空的。下一步我们尝试稍复杂的应用!

我工作目录中这些文件是干什么的?

上面的应用来自于AngularJS种子项目,我们通常可以使用AngularJS种子项目来创建新项目。种子项目包括最新的AngularJS代码库、测试库、脚本和一个简单的应用程序示例,它包含了开发一个典型的web应用程序所需的基本配置。

对于本教程,我们对AngularJS种子项目进行了下列更改:
1.删除示例应用程序;
2.添加手机图像到app/img/phones/;
3.添加手机数据文件(JSON)到app/phones/;
4.添加Twitter Bootstrap文件到app/css/ 和app/img/。

练习

试试把关于数学运算的新表达式添加到index.html:

<p>1 + 2 = {{ 1 + 2 }}</p>

总结

现在让我们转到步骤1,将一些内容添加到web应用程序。

Javascript 相关文章推荐
javascript 异常处理使用总结
Jun 21 Javascript
jQuery 获取对象 基本选择与层级
May 31 Javascript
复制Input内容的js代码_支持所有浏览器,修正了Firefox3.5以上的问题
Jun 21 Javascript
Textbox控件注册回车事件及触发按钮提交事件具体实现
Mar 04 Javascript
js鼠标及对象坐标控制属性详细解析
Dec 14 Javascript
extjs 如何给column 加上提示
Jul 29 Javascript
js实现文本框只允许输入数字并限制数字大小的方法
Aug 19 Javascript
完美解决UI-Grid表格元素中多个空格显示为一个空格的问题
Apr 25 Javascript
详解JavaScript栈内存与堆内存
Apr 04 Javascript
详解JavaScript中关于this指向的4种情况
Apr 18 Javascript
javascript实现移动端上传图片功能
Aug 18 Javascript
vue+openlayers绘制省市边界线
Dec 24 Vue.js
AngularJS入门教程之学习环境搭建
Dec 06 #Javascript
AngularJS入门教程之Hello World!
Dec 06 #Javascript
JavaScript中的Web worker多线程API研究
Dec 06 #Javascript
JavaScript实现的一个日期格式化函数分享
Dec 06 #Javascript
JavaScript实现twitter puddles算法实例
Dec 06 #Javascript
JavaScript实现的一个计算数字步数的算法分享
Dec 06 #Javascript
angularjs中的e2e测试实例
Dec 06 #Javascript
You might like
笑谈配置,使用Smarty技术
2007/01/04 PHP
php 注册时输入信息验证器的实现详解
2013/07/05 PHP
php 强制下载文件实现代码
2013/10/28 PHP
PHP安全的URL字符串base64编码和解码
2014/06/19 PHP
PHP计算数组中值的和与乘积的方法(array_sum与array_product函数)
2016/04/01 PHP
IE 缓存策略的BUG的解决方法
2007/07/21 Javascript
Jquery cookie操作代码
2010/03/14 Javascript
JavaScript实现复制功能各浏览器支持情况实测
2013/07/18 Javascript
javaScript基础语法介绍
2015/02/28 Javascript
jquery实现鼠标滑过显示二级下拉菜单效果
2015/08/24 Javascript
AngularJS实现分页显示数据库信息
2016/07/01 Javascript
D3.js封装文本实现自动换行和旋转平移等功能
2016/10/14 Javascript
利用js来实现缩略语列表、文献来源链接和快捷键列表
2016/12/16 Javascript
详解vue表单验证组件 v-verify-plugin
2017/04/19 Javascript
angular 基于ng-messages的表单验证实例
2017/05/04 Javascript
Vue Prop属性功能与用法实例详解
2019/02/23 Javascript
vue router带参数页面刷新或回退参数消失的解决方法
2019/02/27 Javascript
js 将线性数据转为树形的示例代码
2019/05/28 Javascript
[02:25]DOTA2英雄基础教程 熊战士
2014/01/03 DOTA
Python3 入门教程 简单但比较不错
2009/11/29 Python
Python XML RPC服务器端和客户端实例
2014/11/22 Python
Python实现模拟登录网易邮箱的方法示例
2018/07/05 Python
Python中print和return的作用及区别解析
2019/05/05 Python
python3下pygame如何实现显示中文
2020/01/11 Python
Python常驻任务实现接收外界参数代码解析
2020/07/21 Python
使用Python解析Chrome浏览器书签的示例
2020/11/13 Python
联想香港官方网站及网店:Lenovo香港
2018/04/13 全球购物
潘多拉意大利官方网上商城:网上选购PANDORA珠宝
2018/10/07 全球购物
哥德堡通行证:Gothenburg Pass
2019/12/09 全球购物
旅游管理专业个人求职信范文
2013/12/24 职场文书
法学院毕业生求职信
2014/06/25 职场文书
2014年派出所工作总结
2014/11/21 职场文书
向女朋友道歉的话
2015/01/20 职场文书
2016年五四青年节校园广播稿
2015/12/17 职场文书
MySql子查询IN的执行和优化的实现
2021/08/02 MySQL
关于pytest结合csv模块实现csv格式的数据驱动问题
2022/05/30 Python