Day 2: AngularJS —— 对AngularJS的初步认识

简介: 我们发现了比较有趣的系列文章《30天学习30种新技术》,准备翻译,一天一篇更新,年终礼包。以下是第二天技术的译文。

编者注:我们发现了比较有趣的系列文章《30天学习30种新技术》,准备翻译,一天一篇更新,年终礼包。以下是第二天技术的译文。


昨晚我完爆了一天一技术的任务(完成的很好),谈的是关于Bower的一些知识,你可以在这里看一下文章,也可以去 reddit 看看大家的讨论。

今天我打算学习一下AngularJS的基本知识,并希望能用它做一个简单小应用。我也会在这篇文章里用到Bower,我不可能在一天之内学习完AngularJS,所以我打算用好几天时间来学习,每天涉及其中不同的点。

image.png


什么是AngularJS?

  1. 扩展HTML添加动态特性,因此我们可以轻松地构建现代web应用程序
  2. 以你想要的方式使用
  3. 带你回到HTML
  4. 声明方法
  5. 简单
  6. 通过双向数据绑定消除DOM操作,任何时候当模型改变时视图都会得到更新,反之亦然
  7. 你可以用它来构建单页Web应用程序。当你构建如路由,Ajax调用,数据绑定,缓存,历史记录和DOM操作这类的SPA应用时,会有很多的挑战。


AngularJS的主要组件是:

  1. 控制器:视图背后的代码
  2. 作用域:包含模型数据,粘合控制器和视图
  3. 模块:定义新的服务,或使用现有的服务、指令、过滤器等,模块可以依赖于另一个模块
  4. 指令:允许你通过定义自己项目特定的HTML指令来扩展HTML,学习HTML的新花样

image.png


为什么我会在意AngularJS?

对我而言有两个主要原因:

  1. 它是由谷歌支持,有很多开发者的大社区
  2. 全栈框架:这意味着我不需要依靠其他数百万计的脚本,它们会很好地整合在一起

前提准备

我们将使用Bower为示例应用程序安装AngularJS,如果你还没有安装bower,那么请看我前一篇博文


安装AngularJS

在系统的任何方便的位置创建一个叫 bookshop 的目录,用下面命令来安装AngularJS和Twitter bootstrap:

$ bower install angular

$ bower install bootstrap

上面的命令会在bookshop目录下创建一个叫bower_components的文件夹,里边有已安装的全部组件。


开始使用AngularJS

现在创建一个名为 index.html 的html文件,它将会是一个基于AngularJS的网上书店应用。

<!doctype html>

<html>

<head>

   <title>Bookshop - Your Online Bookshop</title>

   <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

   <divclass="container">

         <h2>Your Online Bookshop</h2>

   </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

</body>

</html>

如果你在浏览器打开这个文件,你会看到“你的网上书店”正在呈现,但这并不是AngularJS的厉害之处,所以接下来我们看看它真正有趣的地方:

<!doctype html>

<htmlng-app>

<head>

   <title>Bookshop - Your Online Bookshop</title>

   <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

   <divclass="container"ng-init="books=['Effective Java','Year without Pants','Confessions of public speaker','JavaScript Good Parts']">

       <h2>Your Online Bookshop</h2>

       <ulclass="unstyled">

           <ling-repeat="book in books">

               {{book}}

           </li>

       </ul>

   </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

</body>

</html>

上边这段代码有一些需要注意的点:

  1. 在HTML标签里边,我们已经定义了ng-app。这将初始化AngularJS应用程序,并告诉AngularJS要在这一部分活跃。所以,它在应用程序里是活跃整个html文件的。
  2. 我们所使用的第二个Angular指令是ng-init。这将初始化书籍数组中的一个,我们可以将它应用在我们的应用程序中。
  3. 最后一个有趣的部分,是用于遍历集合中的所有元素的ng-repeat指令。Angular将为每个元素增加 li 元素。所以,如果我们在Web浏览器中打开它,将会看到在一个列表中有四本书。

上边是以字符串数组的形式使用数据,但也可以用存储对象的方式,如下:

<!doctype html>

<htmlng-app>

<head>

       <title>Bookshop - Your Online Bookshop</title>

       <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

       <divclass="container"ng-init="books=[{'name': 'Effective Java', 'author':'Joshua Bloch'},{'name': 'Year without Pants', 'author':'Scott Berkun'},{ 'name':'Confessions of public speaker','author':'Scott Berkun'},{'name':'JavaScript Good Parts','author':'Douglas Crockford'}]">

               <h2>Your Online Bookshop</h2>

               <ulclass="unstyled">

                       <ling-repeat="book in books">

                               <span>{{book.name}} written by {{book.author}}</span>

                       </li>

               </ul>

       </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

</body>

</html>

在上面的代码中,我们创建了一个书籍数组对象,其中每本书对象都有名字和作者。最后,我们在列表中同时列出作者姓名和书籍名称。


使用过滤器

Angular提供了过滤器,这有助于格式化数据。你可以使用过滤器来格式化日期、货币、大小写字符、排列顺序和基于搜索的过滤。下面就是一个教你如何利用过滤器来大写的作者姓名和按书名来排序的例子:

<!doctype html>

<htmlng-app>

<head>

   <title>Bookshop - Your Online Bookshop</title>

   <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

   <divclass="container"ng-init="books=[{'name': 'Effective Java', 'author':'Joshua Bloch'},{'name': 'Year without Pants', 'author':'Scott Berkun'},{ 'name':'Confessions of public speaker','author':'Scott Berkun'},{'name':'JavaScript Good Parts','author':'Douglas Crockford'}]">

       <h2>Your Online Bookshop</h2>

       <ulclass="unstyled">

           <ling-repeat="book in books | orderBy :'name'">

               <span>{{book.name}} written by {{book.author | uppercase}}</span>

           </li>

       </ul>

   </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

</body>

</html>

正如你所看到的,我们在 ng-repeat 指令中使用了按顺序排列的过滤器,在显示作者姓名时用一个大写过滤器。

为了添加一个搜索过滤器,添加搜索输入的文本框,然后使用一个过滤器以搜索限制结果,如下:

<!doctype html>

<htmlng-app>

<head>

   <title>Bookshop - Your Online Bookshop</title>

   <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

   <divclass="container"ng-init="books=[{'name': 'Effective Java', 'author':'Joshua Bloch'},{'name': 'Year without Pants', 'author':'Scott Berkun'},{ 'name':'Confessions of public speaker','author':'Scott Berkun'},{'name':'JavaScript Good Parts','author':'Douglas Crockford'}]">

       <h2>Your Online Bookshop</h2>

              <inputtype="search"ng-model="criteria">

       <ulclass="unstyled">

           <ling-repeat="book in books | filter:criteria | orderBy :'name'">

               <span>{{book.name}} written by {{book.author | uppercase}}</span>

           </li>

       </ul>

   </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

</body>

</html>

使用控制器

控制器是AngularJS的主要组件之一,它们是给视图提供动力和数据的代码。在我们的例子中,我们可以将测试数据初始化代码移到一个控制器,创建一个名为app.js的JavaScript文件,它将容纳我们应用程序所有特定的JavaScript代码。

functionBookCtrl($scope){

       $scope.books = [

               {'name': 'Effective Java', 'author':'Joshua Bloch'},

               {'name': 'Year without Pants', 'author':'Scott Berkun'},

               { 'name':'Confessions of public speaker','author':'Scott Berkun'},

               {'name':'JavaScript Good Parts','author':'Douglas Crockford'}

       ]

}

$scope 控制器和视图之间的粘合剂,而且会注入到BookCtrl。现在我们添加书籍数组的对象到 $scope 对象,这个对象对视图是可见的。

现在改变index.html使用BookCtrl,如下:

<!DOCTYPE html>

<htmlng-app>

<head>

   <title>Bookshop - Your Online Bookshop</title>

   <linkrel="stylesheet"type="text/css"href="bower_components/bootstrap/dist/css/bootstrap.min.css">

</head>

<body>

   <divclass="container"ng-controller="BookCtrl">

       <h2>Your Online Bookshop</h2>

       <inputtype="search"ng-model="criteria">

       <ulclass="unstyled">

           <ling-repeat="book in books | filter:criteria | orderBy :'name'">

               <span>{{book.name}} written by {{book.author | uppercase}}</span>

           </li>

       </ul>

   </div>

<scripttype="text/javascript"src="bower_components/angular/angular.min.js"></script>

<scripttype="text/javascript"src="app.js"></script>

</body>

</html>

今天就这些内容,这也只是冰山一角。我将会用很多天来学习AngularJS的特性,它真的是一个神奇又强大的库。

相关文章
|
7月前
|
并行计算 异构计算
建立Hugging Face模型调用环境
本文介绍了如何在环境中导入transformers库,并从Hugging Face网站下载模型。如果使用镜像网站,需获取access token。部分模型需申请仓库权限,建议使用国外信息填写。有GPU的用户需先配置CUDA和pytorch-gpu。
|
7月前
|
消息中间件 运维 容灾
朗新科技集团用云消息队列 RocketMQ 版“快、准、狠”破解业务难题
展望未来,朗新科技集团将进一步深化与阿里云消息队列团队的合作,依托自身丰富的能源领域技术实践,以及阿里云强大的基础设施、产品能力,携手推进行业数字化进程,促进能源科技行业的发展。
249 50
|
10月前
|
机器学习/深度学习 敏捷开发 人工智能
软件测试的艺术:确保质量的哲学与实践
【8月更文挑战第21天】在软件工程的世界中,测试不仅仅是一项技术活动,它更像是一门艺术和哲学。本文旨在探索软件测试的核心价值和基本原则,强调其在软件开发生命周期中的重要性。通过分析测试的不同阶段和策略,我们揭示了如何通过细致的测试规划、创造性的测试设计、以及持续的改进过程来提升软件质量和用户体验。文章将展示如何在不断变化的技术环境中保持测试活动的相关性和有效性,同时也会讨论测试团队如何适应敏捷开发模式,以及如何利用自动化工具来提高测试效率。最终,我们将探讨测试的未来趋势,包括人工智能和机器学习在测试中的应用前景。
|
存储 Java API
Spring揭秘:Environment接口应用场景及实现原理!
Environment接口提供了强大且灵活的环境属性管理能力,通过它,开发者能轻松地访问和配置应用程序运行时的各种属性,如系统属性、环境变量等。 同时,Environment接口还支持属性源的定制和扩展,使得开发者能根据实际需求灵活地定制属性的加载和解析方式。
303 1
Spring揭秘:Environment接口应用场景及实现原理!
|
机器学习/深度学习 人工智能 自然语言处理
AWS宣布提供Claude 3模型访问
【2月更文挑战第16天】AWS宣布提供Claude 3模型访问
215 2
AWS宣布提供Claude 3模型访问
|
设计模式 Java Windows
23种设计模式,抽象工厂模式的概念优缺点以及JAVA代码举例
【4月更文挑战第10天】抽象工厂模式是一种创建型设计模式,它提供了一个接口用于创建相关或依赖对象的家族,而不需要指定具体类。该模式允许客户端在不知道具体类的情况下,通过其共同的接口来创建一组产品。
107 7
|
数据可视化 搜索推荐
【数据可视化】预制菜行业分析(一)——国内发展情况
近年来,预制菜开始从大型连锁餐饮企业的中央厨房渗透到外卖餐饮平台,并逐渐从 B 端走向 C 端。消费者购买后只需要简单加工即可食用,省去了食材采购、处理步骤,具有便捷、高效、口味保持度高的特点。
|
安全 编译器 调度
多线程之线程安全问题
多线程之线程安全问题
设置 XShell 的默认全局配色方案
设置 XShell 的默认全局配色方案
615 0