[AngularJS] AngularJS系列(1) 基础篇
目录
一年前开始使用AngularJS(以后简称ng),如今ng已经出2了.虽说2已完全变样,但是1.x还是足够优秀。
什么是AngularJS?
ng是一个js框架,目前最新版本为1.5.8.
官网:https://angularjs.org/
下载:
Install-Package AngularJS.Core
npm install angular@1.5.8
为什么使用/ng特性
ng是非常少有的双向绑定框架。
特性:
- MV*
- 模块化开发
- 双向绑定
- 指令系统
Hello World
构建1个ng页面 非常容易
<!DOCTYPE html>
<html ng-app>
<head>
<title>AngularJS</title>
<script src="//cdn.bootcss.com/angular.js/1.5.8/angular.min.js"></script>
</head>
<body>
<h1>{{model}}</h1>
<input type="text" ng-model="model">
</body> </html>
这几乎是ng最简单的hello world 页面
其中
ng-app ng内置指令,标记ng管理的区域
{{model}} 则为ng的双括号插值语法,此处输出模型model的值
ng-model ng内置指令,用来绑定具体模型
内置指令
在ng中:在HTML中ng-xxx的为指令
ng中包含:
ng-app
- 指定ng管理区域
ng-init
- 初始化
ng-model
- 双向数据绑定指令
ng-bind
- 绑定数据(默认会对HTML数据转义)
ng-cloak
- 加载前隐藏,加载完显示(ng模块加载完会移出特性)
ng-repeat
- 循环遍历(每个元素作用域上有$id $index $first $last $middle $even $odd属性与item并齐)
- (key,value) in data track by $index
ng-class
- ng-class="{red:true}" 根据对象设置class
ng-show / ng-hide / ng-if
- 是否显示 / 隐藏 / 存在 (ng-if通过注释标记能还原)
ng-src / ng-href
- 防止默认请求的表达式错误
ng-switch
- 当大量判断逻辑的时候,减少ng-show等的使用
ng-checked / ng-selected / ng-readonly / ng-disabled
- 一般可用ng-model(以上4个指令不是双向绑定,可实现全选勾选框代码)
ng-change / ng-copy / ng-click / ng-dblclick / ng-focus / ng-blur / ng-submit
- ng常用事件指令
内置过滤器
为了对数据做一些常用的操作,ng定义了一些内置的过滤器
<!DOCTYPE html>
<html ng-app>
<head>
<title>AngularJS</title>
<script src="//cdn.bootcss.com/angular.js/1.5.8/angular.min.js"></script>
</head>
<body ng-init="model=10">
<h1>{{model | currency}}</h1>
<input type="text" ng-model="model">
</body>
</html>
ng-init 初始化模型数据
{{model | currency}} 的currency则为货币过滤器
- currency (货币处理)
{{num | currency : '¥'}}
- date (日期格式化,参考代码中的DATE_FORMATS)
{{date | date : 'yyyy-MM-dd hh:mm:ss EEEE'}}
- filter(匹配子串)
{{ childrenArray | filter : {name : 'i'} }} //匹配name属性中含有i的
- json(格式化json对象)
{{ jsonTest | json}}
- limitTo(限制数组长度或字符串长度)
{{ childrenArray | limitTo : 2 }} //将会显示数组中的前两项
- lowercase(小写)
- uppercase(大写)
- number(格式化数字)
- orderBy(排序)
模块化开发
在实际开发环境中,不会像上述例子中 一行js代码都不写.
在ng中,我们的代码一般在某个模块下进行开发的.
方式一:
<!DOCTYPE html>
<html ng-app="myApp">
<head>
<title>AngularJS</title>
<script src="Scripts/angular.min.js"></script>
</head>
<body ng-controller="HelloCtrl">
<h1>{{model}}</h1>
<input type="text" ng-model="model">
<script>
var app = angular.module('myApp', []);
app.controller('HelloCtrl', ['$scope', function ($scope) {
$scope.model = 'Hello World';
}]);
</script>
</body>
</html>
方式二(也可同时创建多个页面模块):
<!DOCTYPE html>
<html>
<head>
<title>AngularJS</title>
<script src="Scripts/angular.min.js"></script>
</head>
<body ng-controller="HelloCtrl">
<h1>{{model}}</h1>
<input type="text" ng-model="model">
<button type="button" ng-click="test()">Test</button>
<script>
var app = angular.module('myApp', []);
app.controller('HelloCtrl', ['$scope', function ($scope) {
$scope.model = 'Hello World';
}]);
angular.bootstrap(document, ['myApp']);//使用模块初始化页面
</script>
</body>
</html>
简单解释上面的API
angular.bootstrap()
angular.bootstrap(dom,['myApp']) 手动加载模块myApp
angular.module()
angular.module('myApp',[],cfgFn)
//创建模块angular.module('myApp)
//获取模块
module.run()
module.run(function(){})
//相当于程序的Main方法
module.controller()
module.controller('HomeCtrl',function(){})
//创建控制器module.controller('HomeCtrl',['$scope',function(scope){}])
//创建控制器(推荐)
在ng中建议将业务逻辑放在controller中执行。
本文地址:http://www.cnblogs.com/neverc/p/5903257.html
[AngularJS] AngularJS系列(1) 基础篇的更多相关文章
- 从0到1用react+antd+redux搭建一个开箱即用的企业级管理后台系列(基础篇)
背景 最近因为要做一个新的管理后台项目,新公司大部分是用vue写的,技术栈这块也是想切到react上面来,所以,这次从0到1重新搭建一个react项目架子,需要考虑的东西的很多,包括目录结构.代码 ...
- 【webpack 系列】基础篇
Webpack 基础篇 基本概念 Webpack 是一个现代 JavaScript 应用程序的静态模块打包器.当 webpack 处理应用程序时,它会递归地构建一个依赖关系图,其中包含应用程序需要的每 ...
- SQL系列总结——基础篇(三)
之前的两篇文章SQL系列总结:<基础篇一>, <基础篇二>已经介绍了一些基本的数据库知识.现在让我们来从头开始构建一个数据库.到管理数据库和对象. 架构开始! 1.创建 ...
- SQL系列总结——基础篇(一)
数据库与表.列的关系其实就像是一个Excel工作薄(workbook)与Excel表格(sheet)以及表格中的列的关系一样.关系数据库中最基本的对象有3个:表.列.用户 基本的概念名词 ...
- Android自定义控件系列之基础篇
一.概述 在android开发中很多UI控件往往需要进行定制以满足应用的需要或达到更加的效果,接下来就通过一个系列来介绍自定义控件,这里更多是通过一些案例逐步去学习,本系列有一些典型的应用,掌握好了大 ...
- [一天一个进阶系列] - MyBatis基础篇
前言:一直以来,很多人都是拿来主义,只停留在会使用的阶段,从未去研究挖掘其原理,剖析本质.现在慢慢探讨一下其内幕,抛砖引玉 一.简介 1)常用的持久化框架 Hibernate:是一款Java世界中最著 ...
- Python高级网络编程系列之基础篇
一.Socket简介 1.不同电脑上的进程如何通信? 进程间通信的首要问题是如何找到目标进程,也就是操作系统是如何唯一标识一个进程的! 在一台电脑上是只通过进程号PID,但在网络中是行不通的,因为每台 ...
- sql系列(基础篇)-前言 课前补充知识
前言 课前补充知识 Number(p,s) Number(p,s):数字类型,p 表示数字的有效长度(从数字的左边第 1 位不为 0 的開始算起,直到最右边的长度.取值范围 0~38 位),s 表示数 ...
- sql系列(基础篇)-第一章 关于sysdate
第一章 主要的SQL语句 1. 查询数据库系统时间,常以server默认的格式进行显示(依据数据库的字符集而定): 注意:dual 为数据库中的虚表,隶属于管理员 sys 用户,但全部的用户都能够訪 ...
随机推荐
- Web Essentials之HTML和CSS操作技巧
返回Web Essentials功能目录 一些Javascript功能也可以用于TypeScript. 本篇目录 功能 ZenCoding LESS 功能 最小化HTML文件 选中要最小化的.html ...
- 循序渐进做项目系列(1):最简单的C/S程序——让服务器来做加法
(本文是专门针对未接触过C/S开发的初学者而写的,C/S开发高手请自动忽略啊~~) 还在写“Hello world!”式的单机程序吗?还在各种拖控件吗?是否自己都觉得有点low呢?来个质的飞跃吧!看看 ...
- Linux 网络编程(IO模型)
针对linux 操作系统的5类IO模型,阻塞式.非阻塞式.多路复用.信号驱动和异步IO进行整理,参考<linux网络编程>及相关网络资料. 阻塞模式 在socket编程(如下图)中调用如下 ...
- dojo的发展历史
dojo的开始要从2004年初开始说起,那时dojo之父 Alex Russell 在Informatica公司内从事一个名为netWindows的项目,这个项目的目的是在浏览器环境下提供创建窗口化界 ...
- 原创教程:《metasploit新手指南》介绍及下载
原创教程:<metasploit新手指南>介绍及下载 1.1 作者简介 这份教程并不是“玄魂工作室”原创,但是我还是要力推给大家.相比那些一连几年都在问“我怎么才能入门”的人而言,我们更欣 ...
- 一个App完成入门篇(一)-从Hello world开始
程序员学习新技术都是通过Hello World开始的,我们也不例外.第一课我们简单了解利用do平台开发App的基本流程,能了解到的知识点是: 开发环境搭建 创建开发者账号 新建项目 拖拽一个组件 修改 ...
- html表格相关
<html> <head> <style type="text/css"> thead {color:green} tbody {color:b ...
- xamarin UWP图片读取
xamarin使用listview时经常会使用图片,而图片的图片源设置在uwp平台中是有平台特性的,这点请注意区分处理.也就是说在android和IOS上正常的处理在uwp下却是错误的方式. 如同一张 ...
- 每天一个linux命令(57):ss命令
ss是Socket Statistics的缩写.顾名思义,ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容.但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的 ...
- 《机器学习实战》 code debug
摘要:最近在看<机器学习实战>,在code的过程中总是会报一些小错误,所以发下debug过的地方:由于是跳着看的,所以只是其中一部分,希望之后能把这本书我遇见的全部错误都在此更正下. 内容 ...