Angular学习笔记

为何需要MVC

  • 代码规模越来越大,切分是大势所趋
  • 为了复用:逻辑,用法一样的模块
  • 后期维护方便:修改一块功能不影响其它功能
  • MVC只是手段,终极目标是模块化和复用
    1. 一切从模块开始
    2. 模块之间依赖注入
    3. 双向数据绑定

要点

Controller使用过程中的注意点

  1. 不复用----------------(一个控制器一般只负责一小块视图)

  2. 不操作DOM-------------(非其职责)/用Angularjs中directive操作DOM

  3. 不做数据格式化--------(ng有好用的表单控件)

  4. 不做数据过滤----------(ng有$filter服务)

  5. 不相互调用------------(一般不相互调用,控制器间的交互会通过事件进行)

Model复用

  • 视图复用:通过directive实现
  • *AngularJS的MVC是借助于$scope实现的
  • AngularJS的数据结构跟HTML的标签层级一样是树形的
  • $emit('')向上传播
  • $broadcast('')向下/同层传播

神奇的$scope

  1. 是一个pojo--(普通的JAVASCRIPT对象)
  2. 其工具方法---$watch/$apply
  3. 是执行环境---是表达式的执行环境(作用域)
  4. 树型结构-----与DOM标签平行
  5. 继承----------(子$scope对象会继承父$scope上的属性和方法)
  6. 只有一个根$scope对象--每个ng应用只有一个根$scope对象(一般位于ng-app)
  7. 可传播事件--类似DOM事件(可向上和向下)
  8. 是基础--(MVC和双向数据绑定)
  9. 调试--angular.element($0).scope();

AngularJS模块化实现

angular.module('app名',[])定义模块

基础笔记

  • $scope.$apply:

    • $apply会手动触发脏检查,如果$apply不传参数,会自动脏检查所有参数
      例--1秒检查改变一次$scope.date
        setInterval(function(){
            $scope.$apply(function(){$scope.data=new date;})
        },1000)
  • 其中机制: $apply首先会将传进的表达式给$eval解析 错误的话会传给$exciptionHandler报错 正确的话会传给$digest()执行

    • 真正触发脏检查的是$digest()
    • 所以直接调用$digest不够保险 应由$eval把关
  • $watch监听

    • 函数语法:
$watch(要监听值,function(newValue/改变后的值,oldValue/改变前的值){})
  • 当监听对象或监听对象中多个值时:
        $watch(要监听的对象/json、array等,function(newValue/,oldValue/){},true)

其中第三个值true表示对象中有一个值改变就触发

  • 数据共享

    1. $provide.provider+this.$get(){return }
      之后在controller中注入
      简便方法:factory,service
      factory可返回任何数据类型,而 service只能返回对象类型
  1. 通过作用域链取到相邻的controller相邻的
$scope($scope.$$prevSibling/$scope.$$nextSibling)
  • 过滤器

    • 在控制器中用过滤器 在参数中注入
      $filter(controller('mycontroller',function($scope,$filter){}))
    • 用法
var number = $filter('number')(3000)
//声明number变量赋值3000并用number过滤
  • 自定义方法
    在'|'后定义一个函数(在控制器中) 例:
$scope.checkName=function(obj){
if(obj.content.indexOf('h')===-1)return false; 
return true}
//匹配带有'h'的结果
  • controller的正确写法:

  • 将依赖注入由隐示写为显示
    (为了防止压缩代码时使$scope等参数无效)
.controller('mycontroller',function($scope,$filter){})
-->
.controller('mycontroller',['$scope','$filter',function(a,b){}])
//a就是$scope,b是$filter
  • angular中的注入属性$inject:

function controller(a){a就是$scope};controller.$inject=['$scope']
  • 内置渲染指令

      ng-include="'other.html'" / ng-include src="'other.html'" 在标签中引入另一个页面
    

    事件
    在标签中引用事件对象
    例:<button ng-click="change($event)">{{status}}</button>
    $scope.status=true;
    $scope.change=function(event){
    //将其转化为JQuery对象
    $scope.status=!$scope.status;
    $scope.element(event.target).html($scope.status)
    }
    自定义指令
    同一个元素上只能有一个template渲染 有多个时执行第二个会报错
    设定指令优先级:priority:1 /越大优先级越高
    AngularJS指令编译的三个阶段
    1.标准浏览器API转化
    将HTML转化为DOM
    2.Angular compile
    搜索匹配的directive,按照priority排序,并执行directive上的compile方法
    3.Angular link
    执行directive上的link方法,进行scope绑定与事件绑定

          compile中返回的值就是link 并会自动运行 之后的link不需要再定义
              编译阶段:
                  compile:function(tElement,tAttrs,transclude){
                      tElement:当前元素的JQeury对象
                      tAttrs:当前元素的属性
                      transclude:被替换对象的原始数据   /没有就是undefined
                      return{
                          //表示在编译阶段之前,指令连接到子元素之后运行
                          pre:function preLink(scope,iElement,iAttrs,controller){
                              scope:当前元素的作用域
                              iElement:当前元素的JQuery对象
                          },
                          //表示在所有子元素指令都连接之后才运行
                          post:function postLink(scope,iElement,iAttrs,controller){
    
                          }
                      }//返回的link函数
                  },
                  link:function(scope,iElement,iAttrs,controller){
                      //同compile中的postLink 若compile中以有 此处不要再定义
                  }
              compile和link的使用时机
                  compile:
                      想在DOM渲染前对它进行变形,并且不需要scope参数
                      想在所有相同的directive里共享某些方法,
                  link:
                      对特定的元素注册事件
                      需要用scope参数来实现DOM元素的一些行为
          指令中的controller:
              与之前的controller功能相同 会暴露一个API 供require调用 在多个指令之间互相通讯
          require:
              调用别的指令:directiveName 请求的指令名 默认从同级元素上找
                           ^directiveName 请求父级的指令
                           ?directiveName 指令可选 没有也不会报错
          scope:
              为当前指令创建一个新的作用域,而不是继承父作用域
              false:完全与外面的controller相同
              true:创建一个新的作用域 但会继承父作用域
              {}:独立的作用域 其中:& 将父作用域的属性封装成一个函数,将其内容写进该作用域内
                                   = 将该作用域与父作用域进行双向绑定,一个改变另一个也会跟着改变
                                   @ 将该作用域与父作用域单向绑定
                 *注意标签属性要对应
    

    constant,value
    用于在整个应用开始前定义一个全局的常量 之后在controller里通过注入调用
    属于$provider里的方法 简便方法:直接用.constant('名字','内容')
    constant可注入任何方法 value只可注入controller service factory
    run
    在config之后 其他服务之前运行
    表单
    $setPristine方法 将表单重置(只重置其中的class $dirty $pristine)
    字段是否未更改
    formName.inputName.$pristine
    字段是否更改
    formName.inputName.$dirty
    字段有效
    formName.inputName.$valid //=true
    字段无效
    formName.inputName.$invalid //=true
    字段错误信息
    formName.inputName.$error
    input 属性
    name/名字 ng-model/绑定数据 ng-required/是否必填 ng-minlength,ng-maxlength/最小最大长度 ng-pattern/自定义匹配模式 ng-change/值变化时回调
    ng-model属性
    ng-model是angular原生的directive指令 名为ngModel 可以在directive里require:'ngModel'引用他
    其带有的属性
    $parser 保存了从viewValue向modelValue绑定过程中的处理函数,他们将来会依次执行
    $formatters 保存的是modelValue向viewValue绑定过程中的处理函数
    $setViewValue 当view发生某件事,从view向model绑定调用$setViewValue 把viewValue保存下来
    $render 当模型发生变化时,应该怎么去更新视图,从model向view绑定 调用ctrl.$render方法 将viewValue渲染到页面上
    $setValidity 设置验证结果
    $viewValue 视图的值
    %modelValue 模型里的值

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

推荐阅读更多精彩内容