AngularJs学习第二天

Angular VS jQuery

  • jQuery:库

    • 封装了一些常用的方法,我们主动调用这些方法
  • Angular:框架

    • 框架提供了一些结构或者模式,
    • 我们按照框架提供的规则去写代码
    • 然后由框架自己去执行相应的操作
  • 思想上:
    jQuery: 提高了dom操作的开发效率。
    Angular: 不提倡dom操作,几乎没有dom操作(底层还是操作的dom)
    + angular中操作dom angular.element() ,叫做jqLite

angular.element

  • 轻量级的jQuery,
    注意:在获取dom对象时传入的参数是一个原生dom对象

复习并总结Angular开发流程

0.通过npm/bower/暴力的方式/cdn 拿到想到angular.js文件。
1.在HTML代码中引入angular.js这个文件
2.在HTML代码上加上ng-app指令,告诉angular来管理我们的代码,这个指令只能使用一次
3.在JS代码中通过angular.module('模块名',[])创建一个模块,然后在HTML中的ng-app指令指定一下模块名'ng-app="模块名"'

  1. 在JS代码中创建控制器xxx.controller('控制器的名字',function(){}),在HTML代码中通过ng-controller指令由我们当前的控制器来管理数据模型ng-controller="控制器的名字"
  2. 建模(根据页面原型抽象出数据模型), 最终得到视图模型(ViewModel)
  3. 通过$scope来暴露页面上所需要使用的一些数据
  4. 在HTML代码中通过ng-model/ng-click/{{}} 将刚刚暴露的数据绑定到页面上去
  5. 在JS中写一些具体业务相关的代码

复习MVC

  • MVC是一种设计思想,它是约定了程序的结构应该是怎么。
  • 每一个组成原件都会有一个明确的职责。
  • 提高代码的结构和可维护性(代码的执行效率肯定是不会提高的,10行代码,会分到10个不同的方法。);

$scope

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

ViewModel

  • $scope 实际上就是MVVM中所谓的VM(视图模型)
  • 正是因为$scope在Angular中大量使用甚至盖过了C(控制器)的概念,所以很多人(包括我)把Angular称之为MVVM框架
  • 这一点倒是无所谓,具体看怎么用罢了

模块

模块的创建

通过anuglar.mdoule()方法来创建模块.

*注意,如果传入两个参数就是去创建模块,如果只传入第一个参数,就会变成获取模块。*

模块的划分式

1.根据项目中具体的功能去划分模块

2.根据具体的文件功能的类型去划分模块

控制器的创建方式

传统的方式创建控制器(不推荐使用这种方式)

    // 通过全局函数来创建控制器
        // angular会把我们创建的全局函数作为控制器使用
        function demoController($scope){
            $scope.name='小明';
        }

面向对象的方式创建控制器

    <div ng-controller="demoController as obj ">
        {{obj.name}}
        {{age}}
    </div>
    <!-- 1.引入angular.js文件 -->
    <script src="node_modules/angular/angular.js"></script>
    <script>
        // 3.创建模块
        var app =angular.module('myApp',[]);

        // 4.创建控制器
        app.controller('demoController',function($scope){
            // 可以当作构造函数来使用
            this.name="小明";
            $scope.age=12;
        })
    </script>

安全的创建控制器的方式

  • 原因:angular在控制器的回调函数中是通过参数名来传递参数的。
  • 通过将第二个参数改为数据组:数据的最后一个参数还是原来的fucntion,数据前的参数是我们想要anuglar传递的参数的字符串形式,fucntion里的参数需要与数组前面的元素一对应。
    app.controller('demoController',['$scope','$log',function($scope,$log){}])

依赖注入的原理

  • 核心是toString()
  • 获取函数形参的方式

指令

  • 在 AngularJS 中将前缀为 ng- 这种属性称之为指令,其作用就是为 DOM 元素调用方法、定义行为绑定数据等

  • 简单说:当一个 Angular 应用启动,Angular 就会遍历 DOM 树来解析 HTML,根据指令不同,完成不同操作

  • ng-bind

    • 用来解决表达式闪烁问题
    • <p ng-bind="数据模型"></p>
      注意:只能够在双标签中使用ng-bind指令
  • ng-cloak

    • 用来解决表达式闪烁问题
    • <p class="ng-cloak">{{name}}</p>
    • 利用angular在加载会移除页面上所以名为ng-cloak的样式名的特性。
  • ngSanitize模块
    npm install angular-sanitize

    • 使用的是ng-bind-html指令来渲染数据模型。
  • ng-repeat

    • 可以用来循环输出数组

    • 写在哪个元素上就是循环哪个元素。

    • 语法:类似于forin 循环

      <div ng-repeat="item in data ">{{item}}</div>
      + track by $index 解决数组中数据有重得的问题
      + <li ng-repeat="item in tesData track by $index"></li>

    • 还可以用来渲染key,value对

    • ng-repeat 在遍历里会暴露一些数据模型,

      • $even:提供了一个布尔值,当为true时表示当前数据是第偶数条数据,从索引0开始计算
      • $odd:提供了一个布尔值,当为true时表示当前数据是第奇数条数据,从索引0开始计算
      • $first,$last ,$middle
        ng-class:
    • 从多种样式中选择一个样式

      • 语法:类似于从一个key,value对象中获取其中一个属性的值
      • ng-class="{'A':'red','B':'blue','C':'green'}"
    • 从多种样式中选择多个

      • 语法:也是写一个key,value对象,这里的key是我们提供的类样式名,value是一个布尔值,为true时对应的key会被作为样式名加入到class中

ng-hide/ng-show

  • ng-hide:需要一个布尔值:当为true时为隐藏当前元素
  • ng-show: 需要一个布尔值:当为true时为显示当前元素

ng-if:需要一个布尔值:当为true时为显示当前元素
为false时是删除当前元素

ng-switch:与ng-switch-when同用,类似与js中的switch case

    <div ng-switch="name">
            <div ng-switch-when="小明">我是小明</div>
            <div ng-switch-when="小红">我是小红</div>
            <div ng-switch-when="小月">我是小月</div>
    </div>

其他常用指令

  • ng-checked:
    • 单选/复选是否选中,是单向数据绑定
  • ng-selected:
    • 是否选中
  • ng-disabled:
    • 是否禁用
  • ng-readonly:
    • 是否只读

常用事件指令

不同于以上的功能性指令,Angular还定义了一些用于和事件绑定的指令:

  • ng-blur:失去焦点
  • ng-focus:获得焦点
  • ng-change:改变事件
  • ng-copy:复制事件
  • ng-click: ng-click="add()"
  • ng-dblclick:双击事件
  • ng-submit: 表单提交事件

指令的标准使用方式

data-xxx,在使用angular指令时,只需要在原先的指令前加上data-前缀。
x-

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

推荐阅读更多精彩内容