AngularJS安装配置与基础概要整理(上)
以前整理的,可供参考。
安装:
1.首先要安装node.js和它的npm包管理系统。(nodejs相关待整理)
2.安装grunt
.grunt是一个基于任务的Javascript工程命令行构建工具。
在dos窗口输入:npm install grunt-cli -g
具体模块安装:npm install(grunt或grunt模块的名称) --save-dev
3.安装Karma runner
在dos窗口输入:npm install karma-cli -g
安装Karma:npm install karma --save-dev
安装你项目需要的组件:npm install karma-jasmine karma-chrome-launcher --sava-dev
4.下载angular.js
在这个网站下载:https://code.angularjs.org/
选定一个2.0以前的版本。
一、AngularJS简介
AngularJS是一个JavaScript框架。它可通过<script>标签添加到HTML页面。
AngularJS通过指令扩展了HTML,且通过表达式绑定数据到HTML。
1.AngularJS通过ng-directives扩展了HTML。
Ng-app指令定义一个AngularJS应用程序。
Ng-model指令把元素值(比如输入域的值)绑定到应用程序。
Ng-bind指令把应用程序数据绑定到HTML视图。
2.什么是AngularJS
AngularJS使得开发现代的单一页面应用程序变得更加容易。
·AngularJS把应用程序数据绑定到HTML元素。
·AngularJS可以克隆和重复HTML元素。
·AngularJS可以隐藏和显示HTML元素。
·AngularJS可以在HTML元素“背后”添加代码。
·AngularJS支持输入验证。
3.AngularJS指令
AngularJS指令是以ng作为前缀的HTML属性。
Ng-init指令初始化AngularJS应用程序变量。
* HTML5允许扩展的(自制的)属性,以data-开头。
AngularJS属性以ng-开头,但是可以使用data-ng-来让网页对HTML5有效。
4.AngularJS表达式
AngularJS表达式写在双大括号内:{{expression}}。
AngularJS表达式把数据绑定到HTML,这与ng-bind指令有异曲同工之妙。
AngularJS将在表达式书写的位置“输出”数据。
AngularJS表达式很像Javascript表达式:它们可以包含文字、运算符和变量。
5.AngularJS应用
AngularJS模块(module)定义了AngularJS应用。
AngularJS控制器(Controller)用于控制AngularJS应用。
Ng-app指令定义了应用,ng-controller定义了控制器。
AngularJS模块定义应用:
Var app = angular.module(‘myApp’,{});
AngularJS控制器控制应用:
App.controller(‘myCtrl’,function($scope){ $scope.firstName = “John”; $scope.lastName = “Doe”; })
二、AngularJS表达式
AngularJS使用表达式把数据绑定到HTML。
1.AngularJS数字
<div ng-app=”” ng-init=”quantity=1;cost=5”>
<p>总价:{{quantity * cost}}</p>
</div>
使用ng-bind的相同实例:
<div ng-app=”” ng-init=”quantity=1;cost=5”> <p>总价:<span ng-bind=”quantity * cost”></span></p> </div>
2.AngularJS字符串
<div ng-app=”” ng-init=”firstName=’John’;lastName=’Doe’”> <p>姓名:{{firstName + “ “ + lastName}}</p> </div>
使用ng-bind的相同实例:
<div ng-app=”” ng-init=”firstName=’John’;lastName=’Doe’”> <p>姓名:<span ng-bind=”firstName + ‘ ‘ + lastName”></span></p> </div>
3.AngularJS对象
<div ng-app=”” ng-init=”person={firstName:’John’,lastName:’Doe’}”> <p>姓为{{person.lastName}}</p> </div>
4.AngularJS数组
<div ng-app=”” ng-init=”points=[1,15,19,2,40]”> <p>第三个值为{{points[2]}}</p> </div>
5.AngularJS表达式与JavaScript表达式
类似于JavaScript表达式,AngularJS表达式可以包含字母,操作符,变量。
与JavaScript表达式不同,AngularJS表达式可以写在HTML中;AngularJS表达式不支持条件判断,循环及异常;AngularJS表达式支持过滤器。
三、AngularJS指令
AngularJS通过被称为指令的新属性来扩展HTML。
AngularJS通过内置的指令来为应用添加功能。
AngularJS允许你自定义指令。
1.AngularJS指令
AngularJS指令是扩展的HTML属性,带有前缀ng-。
Ng-app指令初始化一个AngularJS应用程序。
Ng-init指令初始化应用程序数据。
Ng-model指令把元素值(比如输入域的值)绑定到应用程序。
2.数据绑定
AngularJS中的数据绑定,同步了AngularJS表达式与AngularJS数据。
在下一个示例中,两个文本域是通过两个ng-model指令同步的。
<div ng-app=”” ng-init=”quantity=1;price=5;”> <h2>价格计算器</h2> 数量:<input type=”number” ng-model=”quantity”> 价格:<input type=”number” ng-model=”price”> <p><b>总价:</b>{{quantity*price}}</p> </div>
3.重复HTML元素
Ng-repeat指令会重复一个HTML元素:
<div ng-app=”” ng-init=”names=[‘Jani’,’Hege’,’Kai’]”> <p>使用ng-repeat来循环数组</p> <ul> <li ng-repeat=”x in names”> {{x}} </li> </ul> </div>
Ng-repeat指令用在一个对象数组上:
<div ng-app=”” ng-init=”names=[{name:’Jani’,country:’Norway’},{name:’Hege’,country:’Sweden’},{name:’Kai’,country:’Denmark’}]”> <p>循环对象:</p> <ul> <li ng-repeat=”x in names”> {{x.name + ‘,’ + x.country}} </li> </ul> </div>
* AngularJS完美支持数据库的CRUD(增加Create、读取Read、更新Update、删除Delete)应用程序。把实例中的对象想象成数据库中的记录。
4.ng-app指令
Ng-app指令定义了AngularJS应用程序的根元素。
Ng-app指令在网页加载完毕时会自动引导(自动初始化)应用程序。
5.ng-init指令
Ng-init指令为AngularJS应用程序定义了初始值。
通常情况下,不使用ng-init。您将使用一个控制器或模块来代替它。
6.ng-model指令
Ng-model指令绑定HTML元素到应用程序数据。
Ng-model指令也可以:
·为应用程序数据提供类型验证(number、email、required)。
·为应用程序数据提供状态(invalid、dirty、touched、error)。
·为HTML元素提供CSS类。
·绑定HTML元素到HTML表单。
7.ng-repeat指令
Ng-repeat指令对于集合中(数组中)的每个项会克隆一次HTML元素。
8.创建自定义的指令
可以使用.directive函数来添加自定义的指令。
要调用自定义指令,HTML元素上需要添加自定义指令名。
使用驼峰法来命名一个指令,runoobDirective,但在使用它时需要以-分割,runoob-directive:
<body ng-app=”myApp”> <runoob-directive></runoob-directive> <script> Var app = angular.module(“myApp”,[]); App.directive(“runoobDirective”,function(){ Return{ Template : “<h1>自定义指令!</h1>” }; }); </script> </body>
可以通过以下方式来调用指令:
·元素名
·属性
·类名
·注释
以下实例方式也能输出同样结果:
元素名:
<runoob-directive></runoob-directive>
属性:
<div runoob-directive></div>
类名:
<div class=”runoob-directive”></div>
注释:
<!-- 指令:runoob-directive -->
*需要在该实例添加replace属性,否则评论是不可见的。
*必须设置restrict的值为”M”才能通过注释来调用指令。
<body ng-app=”myApp”> <!-- directive: runoob-directive --> <script> Var app = angular.module(“myApp”,[]); App.directive(“runoobDirective”,function(){ Return { Restrict : “M”, Replace : true, Template : “<h1>自定义指令!</h1>” }; }); </script> </body>
9.限制使用
可以限制指令只能通过特定的方式来调用。
通过添加restrict属性,并设置值为”A”,来设置指令只能通过属性的方式来调用:
Var app = angular.module(“myApp”,[]); App.directive(“runoobDirective”,function(){ Return { Restrict : “A”, Template : “<h1>自定义指令!</h1>” }; });
Restrict值可以是以下几种:
·E只限元素名使用
·A只限属性使用
·C只限类名使用
·M只限注释使用
Restrict默认值为EA,即可以通过元素名和属性名来调用指令。
四、AngularJS模型
Ng-model指令用于绑定应用程序数据到HTML控制器(input,select,textarea)的值。
可以将输入域的值与AngularJS创建的变量绑定。
<div ng-app=”myApp” ng-controller=”myCtrl”> 名字:<input ng-model=”name”> </div> <script> Var app = angular.module(‘myApp’,[]); App.controller(‘myCtrl’,function($scope){ $scope.name = “John Doe”; }) </script>
1.双向绑定
双向绑定,在修改输入域的值时,AngularJS属性的值也将修改:
<div ng-app=”myApp” ng-controller=”myCtrl”> 名字:<input ng-model=”name”> <h1>你输入了:{{name}}</h1> </div>
2.验证用户输入
<form ng-app=”” name=”myForm”> Email: <input type=”email” name=”myAddress” ng-model=”text”> <span ng-show=”myForm.myAddress.$error.email”> 不是一个合法的邮箱地址 </span> </form>
*以上实例中,提示信息会在ng-show属性返回true的情况下显示。
3.应用状态
Ng-model指令可以为应用数据提供状态值(invalid,dirty,touched,error):
<form ng-app=”” name=”myForm” ng-init=”myText = ‘test@runoob.com’”> Email: <input type=”email” name=”myAddress” ng-model=”myText” required> <p>编辑邮箱地址,查看状态的改变。</p> <h1>状态</h1> <p>Valid:{{myForm.myAddress.$valid}}(如果输入的值是合法的则为true)。</p> <p>Dirty:{{myForm.myAddress.$dirty}}(如果值改变则为true)。</p> <p>Touched:{{myForm.myAddress.$touched}}(如果通过触屏点击则为true)。</p> </form>
4.CSS类
Ng-model指令基于它们的状态为HTML元素提供了CSS类:
<style> Input.ng-invalid{ Background-color: lightblue; } </style>
<form ng-app=”” name=”myForm”> 输入你的名字: <input name=”myName” ng-model=”myText” required> </form> <p>编辑文本域,不同状态背景颜色会发生变化</p> <p>文本域添加了required属性,该值时必须的,如果为空则是不合法的。</p>
Ng-model指令根据表单域的状态添加/移除以下类:
·ng-empty
·ng-not-empty
·ng-touched
·ng-untouched
·ng-valid
·ng-invalid
·ng-dirty
·ng-pending
·ng-pristine
AngularJS安装配置与基础概要整理(上)的更多相关文章
- OpenStack-Ocata版+CentOS7.6 云平台环境搭建 — 2.安装配置OpenStack基础服务
节点配置情况说明: 控制节点:controller: IP:192.168.164.128 hostname&hosts:likeadmin 计算加点:Nova: IP:192.168.164 ...
- AngularJS基础概要整理(下)
五.AngularJS Scope(作用域) Scope(作用域)是应用在HTML(视图)和JavaScript(控制器)之间的纽带. Scope是一个对象,有可用的方法和属性. Scope可应用在视 ...
- linux上安装配置samba服务器
linux上安装配置samba服务器 在linux上安装配置samba服务器 在这给大家介绍一个不错的家伙,samba服务.如果您正在犯愁,如何在Windows和Linux之间实现资源共享,就请看看这 ...
- ELK6.x_Kafka 安装配置文档
1. 环境描述 1.1. 环境拓扑 如上图所示:Kafka为3节点集群负责提供消息队列,ES为3节点集群.日志通过logstash或者filebeat传送至Kafka集群,再通过logstash发 ...
- 一步一步跟我学hadoop(1)----hadoop概述和安装配置
这几年云计算大数据非常火,借这个东风.今天開始学习apache的分布式计算框架hadoop,希望不要太落后. Hadoop说明 对于hadoop.apache官方wiki给出的说明为 Apache H ...
- Mysql主从安装配置
Mysql主从安装配置 环境: 主从服务器上的MySQL数据库版本同为5.1.34 主机IP:192.168.0.1 从机IP:192.168.0.2 一. MySQL主服务器配置 1.编辑配置 ...
- Angularjs 2 绝对零基础的教程(1):从安装配置开始
写在前面 适合人群: 1. 愿意未来从事前端工作,并以此开拓自己未来职业 2. 有任何一种编程语言基础 3. 喜欢简单粗暴学一门实用的技术,而不是做科研. Angular 2 比 Angular 1 ...
- Django基础之安装配置
安装配置 一 MVC和MTV模式 著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层:他们之间以一种插件似的,松耦合的方式连接在一起. 模型负责业务对象与数据库的 ...
- SharePoint Framework (SPFx)安装配置以及开发-基础篇
前言 SharePoint Framework(SPFx),是页面 和Webpart的模型,完全支持本地开发(即完全可以脱离SharPoint环境在本地进行开发),SPFx包含了一系列的client- ...
随机推荐
- git的几种回滚 git revert 和 git reset的区别
git的几种回滚 git revert 和 git reset的区别:强烈建议:对HEAD不熟的话最好不要用HEAD,直接用commitID吧,我遇到的问题:reset HEAD~1之后,可能是别人提 ...
- URAL 1244. Gentlemen(DP)
题目链接 这题不难啊...标记一下就行了.表示啥想法也没有. #include <cstring> #include <cstdio> #include <string& ...
- java画图程序_图片用字母画出来
最近在研究怎样将图片用字母在文本编辑工具中“画”出来. 你看了这个可能还不知道我想说什么? 我想直接上图,大家一定就知道了 第一张:小猫 原图:http://www.cnblogs.com/hongt ...
- RSA_RSA算法原理(一)
如果你问我,哪一种算法最重要?我可能会回答"公钥加密算法". 因为它是计算机通信安全的基石,保证了加密数据不会被破解.你可以想象一下,信用卡交易被破解的后果. 进入正题之前,我先简 ...
- C# PInvoke(DllImport使用) 进阶教程(一)转
我们曾经熟悉的WindowsAPI, 我们曾经花费了大量精力写的代码,难道我们就要轻易放弃吗 不过当下微软已经把向下兼容性放在很重要的位置.C#程序员使用已有的代码来作为自己程序的一部分是很普通的事情 ...
- 看好你的门-客户端传数据-用java修改referer
1.简单说明 Referer.origin用来表明,浏览器向WEB服务器表明自己来自哪里.但是就它本身而言,并非完全安全. 写一个例子,可以任意修改http信息头中的referer.origin 2. ...
- AJAX回调(调用后台方法返回数据)
记得先要导入jquery.js. 格式一 $.ajax({"Key1":"value1","key2":"value2" ...
- java程序实现删除本地文件
import java.io.File; public class Test { public static void main(String args[]) { Test t = new Te ...
- 关于格式转换 “%a.bs”
这个形式的格式转换符用于输出, 如果a <= b, 那么输出的字符串串长大于等于a, 小于b; 否则, 输出的串长按照a指定的输出. (不够,用空格补齐)
- 关于java多线程
package testSynchronized; /** * * 当使用this也就是该文件中的testclass对象作为对象锁时, * 两个线程都使用该对象锁访问该对象的同步代码块, * 是顺序执 ...