AngularJS 是一个 JS 框架,适用于以数据操作为主的 SPA (Single Page Application)应用。

不再是 “先查找元素在操作元素”,所有操作都以 “Model数据为中心”

AngularJS 的四大特性

  • 采用 MVC 模型

    1. Model:模型,业务数据;在 AngularJS 中,就是存储于特定作用范围内的变量
    2. View:视图,模型数据在页面中的呈现
    3. Controller:控制器,负责创建、修改、删除模型数据,AngularJS 中,使用function来创建控制器
  • 自动化双向数据绑定
  • 依赖注入
  • 模块化设计

AngularJS 中 ng 模块提供的指令

ngApp 用途:

- 初始化一个 AngularJS 应用程序
- 标记了AngularJS脚本的作用域

语法:

<element ng-app><element>
<element ng-app="xxx"><element>
<element data-ng-app="xxx"><element>

注意:一个 HTML 页面只允许使用一次 ngApp 指令,如果有多个 ng-app 指令,则只有第一个会被使用,同时只有 ngApp 范围内的 Angular 表达式才会被计算出对应的值。

ngInit:用于声明 Model 变量,初始化应用程序模型数据

语法:

<element ng-init="变量名=值;变量名1=值1">

注意:Model 变量声明时不能使用 var 关键字 和 new 关键字

  • 使用 ngInit 指令声明模型数据 ----- 将 Model 和 View 混杂在一起,不推荐使用
  • 使用Controller控制器 声明模型数据 ----- 实现了Model 和 View 的分离,且可以使用的数据类型更加广泛,推荐使用
1. 声明一个自定义的模块(module)
angular.module('模块名', []);
2. 在当前 AngularJS 应用中注册自定义模块
ng-app="模块名"
3. 在自定义模块中创建 Controller 函数,其中声明 Model 数据
$scope.模型变量名 = 值;
4. 在 View 中创建 Controller 对象的实例,指定其作用范围
<element ng-controller="控制器名"> 控制器的有效范围 </element>
5. 在控制器的作用范围内输入 Model 变量
使用 {{}} 输出 Model 变量的值

ngController:创建一个控制器对象的实例(即调用 Controller 函数)

语法:

<element ng-controller="控制器名"></element>

使用控制器创建的模型数据可以是如下类型:

1. String、Number、Boolean 基本类型的值
2. 数组类型
3. 使用任意方法创建的对象

ngBind:在当前元素的 innerHTML 上输出指定的表达式的值

语法:

<element ng-bind="表达式"></element>

此指令的作用与 {{}} 一样,只是可以防止闪动问题

ngRepear:为 HTML 增加循环功能,循环输出当前元素

语法:

<element ng-repeat=""></element>

ngIf:为 HTML 增加选择功能,只有在表达式值为true时,当前元素才添加到 DOM 树,否则就从 DOM 树上删除

语法:

<element ng-if=""></element>

$scope 和 $rootScope 的区别

  1. 每个控制器的实例都对应一个作用范围对象,即 $scope
  2. 在控制器中声明的 Model 数据,必须保存在一个作用范围内
  3. 为了在多个控制器共享数据,可以将 Model 数据保存在一个 “全局作用范围内” -- $rootScope -- 整个 AngularApp 中只能有一个 $rootScope 对象,而且这个对象是所有$scope 的父作用域对象
  4. 作用域对象间可以实现继承,只需要将某个控制器实例声明在另一个控制器实例的有效zuo'yong'yu'nei'bu'ji'ke
<body>
<div class="container">
<div ng-controller="c1">
<div ng-controller="c2"></div>
</div>
</div>
<script src="angular.js"></script>
<script>
angular.module('App', ['ng'])
.controller('c1', function($scope, $rootScope){
$scope.ename = '爸爸';
$rootScope.ename = '爷爷';
})
.controller('c2', function($scope){
$scope.ename = '孙子';
console.dir($scope);
})
</script>
</body>

上述代码就形成一个简单的继承关系。

AngularJS 学习之路(1)的更多相关文章

  1. luluzero的angularJs学习之路_angularJs示例代码

    最近开始自学 angularJs这个前端MVC框架,感觉在前端实现MVC很酷有木有.哈哈哈... 先说说我对前端MVC的一个基本的理解吧(刚开始学习接触得还比较浅显,理解可能会有些不到位,还请各位大神 ...

  2. angularJS 学习之路

    AngularJS 通过 ng-directives 扩展了 HTML. ng-app 指令定义一个 AngularJS 应用程序.也就是angularjs作用的入口  作用在什么标签或者整个body ...

  3. AngularJS学习之旅

    开篇 最近由于项目上可能需要用到AngularJS,公司将技术学习.调研的任务安排了下来,因此开始了我的AngularJS学习之路. 在这之前没写过技术博客,主要是由于太懒,另外自愧文笔不好,因此一直 ...

  4. Python学习之路目录(收藏整理)

    目录 Python之路[第一篇]:Python简介和入门 Python之路[第二篇]:Python基础(一) Python之路[第三篇]:Python基础(二) Python之路[第四篇]:模块    ...

  5. jQuery学习之路(1)-选择器

    ▓▓▓▓▓▓ 大致介绍 终于开始了我的jQuery学习之路!感觉不能再拖了,要边学习原生JavaScript边学习jQuery jQuery是什么? jQuery是一个快速.简洁的JavaScript ...

  6. Android开发学习之路-RecyclerView滑动删除和拖动排序

    Android开发学习之路-RecyclerView使用初探 Android开发学习之路-RecyclerView的Item自定义动画及DefaultItemAnimator源码分析 Android开 ...

  7. RPC远程过程调用学习之路(一):用最原始代码还原PRC框架

    RPC: Remote Procedure Call 远程过程调用,即业务的具体实现不是在自己系统中,需要从其他系统中进行调用实现,所以在系统间进行数据交互时经常使用. rpc的实现方式有很多,可以通 ...

  8. webService学习之路(三):springMVC集成CXF后调用已知的wsdl接口

    webService学习之路一:讲解了通过传统方式怎么发布及调用webservice webService学习之路二:讲解了SpringMVC和CXF的集成及快速发布webservice 本篇文章将讲 ...

  9. [精品书单] C#/.NET 学习之路——从入门到放弃

    C#/.NET 学习之路--从入门到放弃 此系列只包含 C#/CLR 学习,不包含应用框架(ASP.NET , WPF , WCF 等)及架构设计学习书籍和资料. C# 入门 <C# 本质论&g ...

随机推荐

  1. mac+apache+php+phpmyadmin集成php开发环境配置

    刚开始才接触php才发现macos还是比较强大了,macbook不仅是时尚达品还很实用哦. --------------他山之石-------------------------- http://da ...

  2. 联想Y50耳机插入耳机孔后没有声音解决办法

    症状:博主本子Y50,前阵子关机时,提示win10要下载更新并安装,开机后发现将耳机插入耳机孔后死活听不到声音(笔记本自带的音响有声音).期间怀疑过耳机坏了的问题,检查过耳机在手机上能正常播放声音.最 ...

  3. Spark入门实战系列--5.Hive(上)--Hive介绍及部署

    [注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .Hive介绍 1.1 Hive介绍 月开源的一个数据仓库框架,提供了类似于SQL语法的HQ ...

  4. Hadoop阅读笔记(五)——重返Hadoop目录结构

    常言道:男人是视觉动物.我觉得不完全对,我的理解是范围再扩大点,不管男人女人都是视觉动物.某些场合(比如面试.初次见面等),别人没有那么多的闲暇时间听你诉说过往以塑立一个关于你的完整模型.所以,第一眼 ...

  5. nodejs 回调地狱解决 promise async

    nodejs毁掉地狱是一直被人诟病的,以下总结一下解决毁掉地狱的一些方法.(暂时研究的比较浅) 1.promise promise模式在任何时刻都处于以下三种状态之一:未完成(unfulfilled) ...

  6. 经验总结:HTTP返回505错误小记

    昨天调试代码的时候,用http请求一个图片,返回的结果为如下: HTTP/1.1 505 HTTP Version Not Supported Server: Apache-Coyote/1.1 Da ...

  7. 【数据压缩】Huffman编码

    1. 压缩编码概述 数据压缩在日常生活极为常见,平常所用到jpg.mp3均采用数据压缩(采用Huffman编码)以减少占用空间.编码\(C\)是指从字符空间\(A\)到码字表\(X\)的映射.数据压缩 ...

  8. 关于WEB Service&WCF&WebApi实现身份验证之WEB Service篇

    在这个WEB API横行的时代,讲WEB Service技术却实显得有些过时了,过时的技术并不代表无用武之地,有些地方也还是可以继续用他的,我之所以会讲解WEB Service,源于我最近面试时被问到 ...

  9. Dapper学习 - Dapper.Rainbow(三) - Read

    前面已经介绍了新增/修改/删除了, 接下来介绍一下Rainbow的Read方法. 一.Read -- Rainbow原生 1. 先看测试代码 var conStr = ConfigurationMan ...

  10. 在DevExpress中使用WizardControl控件构建多步向导界面

    利用好的界面控件,往往能做成比较界面体验效果.在一些界面操作里面,我们可能把它拆分为几部进行处理,这个时候引入WizardControl向导控件应该是比较不错的选择了.多步的处理方式,可以让用户避免一 ...