Angular入门

Angular 简介

什么是 AngularJS

  • 一款非常优秀的前端高级 JS 框架
  • 最早由 Misko Hevery 等人创建
  • 2009 年被 Google 公式收购,用于其多款产品
  • 目前有一个全职的开发团队继续开发和维护这个库
  • 有了这一类框架就可以轻松构建 SPA 应用程序
  • 轻松构建 SPA(单一页面应用程序)
  • 单一页面应用程序:
    • 只有一个页面(整个应用的一个载体)
    • 内容全部是由AJAX方式呈现出啦的
  • 其核心就是通过指令扩展了 HTML,通过表达式绑定数据到 HTML。

为什么使用 AngularJS

  • 更少的代码,实现更强劲的功能
  • 将一些以前在后台开发中使用的思想带入前端开发
  • 带领当前市面上的框架走向模式化或者架构化

AngularJS 的核心特性

  • MVC
  • 模块化
  • 自动化双向数据绑定
  • 指令系统

相关链接

Angular 上手

安装 Angular

使用总结

运行官方文档

CDN的优势

Content Delivery Network

  • 节省自己服务器的带宽压力和流量

Angular 基础概念

MVC 思想

什么是 MVC 思想

  • 将应用程序的组成划分为三个部分:Model View Controller
  • 控制器的作用就是初始化模型用的,组织调度相应的处理模型;
  • 模型就是用于存储数据的,处理数据与业务逻辑
  • 视图用于以有好的方式向用户展现数据
    优势:每个模块分工明确,职责清晰,复用。
    目的:模块化和复用
mvc.png
  • 登陆案例
  • 模型
    • 我们数据库中所有用户的信息
    • 接受控制器传来的用户名和密码进行校验的业务逻辑并返回true/false
  • 控制器
    • 接受用户在界面上填写的用户名和密码
    • 将用户名和密码交给模型
  • 视图
    • 给用户呈现一个表单
    • 接受用户输入内容,并将其提交给控制器
    • 根据控制器返回的数据,响应用户页面

模块(Module)

//创建一个名字叫MyApp的模块,第二个参数指的是该模块依赖哪些模块
var myApp = angular.module("MyApp",[]),
  • 建立模块,通过ng-app指令指定不同的模块,划分应用程序结构,对页进行业务上的划分;模块间相互独立
  • 也可以将重复使用的指令或过滤器之类的做成模块便于使用
  • angular.module方法传递两个参数才是创建模块,一个参数是获取模块
  • 便于协同分工和维护

控制器(Controller)

angular.mdule ('OneApp',[])
            .controller('HelloController',[
                '$scope',
                function($scope){
                    $scope.p={
                        name:'zhangsan'
                     };
                  }
              ]);
控制器的三种职责
  • 为应用中的模型设置初始状态
  • 通过$scope对象把数据模型或函数行为暴露给视图
    -监视模型的变化,做出相应的动作
    例如

$scope.$watch('totalCart',calculateDiscount)
watch只能监视$scope中已有的属性

视图模型($scope)

  • 视图和控制器之间的桥梁
  • 用于在视图和控制器之间传递数据
  • 利用$scope暴露数据模型(数据、行为)

表达式(Expression)

作用

把 数据绑定到html上

语法

写在双大括号内{{expression}}
包含文字,运算符,变量

与JavaScript表达式对比

单向数据绑定

双向数据绑定

Angular 指令系统

ng-app指令


angular找到第一个ng-app过后就不会再找,手动的让第二个div被myApp2管理

angular.bootstrap(document.querySelector('[ng-app="myApp2"]'),['myApp2']);

也可以通过模块依赖关系,创建一个总模块,依赖其他多个模块

angular.module('myApp', ['myApp1', 'myApp2']);

ng-bind指令

ng-bind指令在绑定的值包含HTML时会转义,为了安全(跨站脚本攻击),需要引入sanitize.js,并且该模块要添加依赖ngSanitize模块。

<script src="bower_components/angular-sanitize/angular-sanitize.js"></script>

使用自定义的模块才可以依赖别的包里面定义模块,angular定义的默认模块没有依赖任何
angular.module('myApp', ['ngSanitize']);

ng-model指令

用于绑定应用程序数据到html控制器(input select text)的值,可以将输入的值与angularJS创建的变量绑定。

ng-repeat指令

ng-class指令

ng-show /ng-hide指令

ng-link/ng-src指令

自定义指令

过滤器filter

作用

常见的过滤器有

date过滤器

主要用于时间格式的转换

limitTo过滤器
filter过滤器

filter过滤器会根据设置的检索数据过滤未匹配到的数据内容,也可以通过设置检索条件为一个对象,实现在指定属性中检索


通过自定义一个比较函数,在前台为filter指定的第二个参数实现

json过滤器

可以将一个对象以json形式解析,利用它,我们可以在界面上直观的查看一些对象的成员,这也是调试的好办法。

自定义过滤器

实现自定义数据格式转换

Form表单

Form表单-----验证

Form表单-----验证规则

服务(service)

创建服务

通过模块的service方法创建一个服务

内置服务——$http

此服务是AngularJS中处理AJAX的服务
请求数据方式$http.jsonp(url).success(function(res){}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • angular简介 angular是一个框架,诸多类库的集合,以数据和逻辑为核心; MVC modal-view-...
    Rella7阅读 564评论 0 2
  • AngularJS是什么?AngularJs(后面就简称ng了)是一个用于设计动态web应用的结构框架。首先,它是...
    200813阅读 1,583评论 0 3
  • 简介# AngularJS 是一个为动态WEB应用设计的结构框架,提供给大家一种新的开发应用方式,这种方式可以让你...
    Simple_habits阅读 571评论 0 9
  • Angular 简介 什么是 AngularJS 一款非常优秀的前端高级 JS 框架 最早由 Misko Heve...
    Looog阅读 844评论 0 7
  • 前几天,孩子情绪崩溃,睡觉前大哭,说爸爸妈妈不喜欢她,自己不是亲生的,让爸爸妈妈把自己送走,随便送给谁都行。再...
    寓见阅读 263评论 0 2