代码改变世界

angularJS

2018-05-31 18:12  bsdbqling  阅读(92)  评论(0)    收藏  举报
  • ng-app指令

让 body 元素成为 AngularJS 应用的根元素:

<body ng-app="">

<p>我的第一个表达式: {{ 5 + 5 }}</p>

</body>
  • ng-app 指令用于告诉 AngularJS 应用当前这个元素是根元素。

    所有 AngularJS 应用都必须要要一个根元素。

    HTML 文档中只允许有一个 ng-app 指令,如果有多个 ng-app 指令,则只有第一个会被使用。

<div ng-app="myApp" ng-controller="myCtrl">
{{ firstName + " " + lastName }}
</div>

<script>
var app = angular.module("myApp", []);
app.controller("myCtrl", function($scope) {
    $scope.firstName = "John";
    $scope.lastName = "Doe";
});
</script>
  • ng-controller 指令(见上面的例子)
  • ng-controller 指令用于为你的应用添加控制器。

    在控制器中,你可以编写代码,制作函数和变量,并使用 scope 对象来访问。

  • ng-repeat 指令

  • ng-repeat 指令用于循环输出指定次数的 HTML 元素。

    集合必须是数组或对象。

  • <table ng-controller="myCtrl" border="1">
    <tr ng-repeat="x in records">
      <td>{{x.Name}}</td>
      <td>{{x.Country}}</td>  
    </tr>
    </table>
    
    <script>
    var app = angular.module("myApp", []);
    app.controller("myCtrl", function($scope) {
      $scope.records = [
        {
          "Name" : "Alfreds Futterkiste",
          "Country" : "Germany"
        },
        {
          "Name" : "Berglunds snabbk",
          "Country" : "Sweden"
        },
        {
          "Name" : "Centro comercial Moctezuma",
          "Country" : "Mexico"
        },
        {
          "Name" : "Ernst Handel",
          "Country" : "Austria"
        }
      ]
    });
    </script>

     repeat-finish渲染完成后的事件

  • 业务中有时需要在异步获取数据并用ng-repeat遍历渲染完页面后执行某个操作,angular本身并没有提供监听ng-repeat渲染完成的指令,所以需要自己动手写。有经验的同学都应该知道,在ng-repeat模板实例内部会暴露出一些特殊属性$index/$first/$middle/$last/$odd/$even,$index会随着每次遍历(从0开始)递增,当遍历到最后一个时,$last的值为true,so,通过判断$last的值来监听ng-repeat的执行状态,怎么在遍历过程中拿到$last的值:自定义指令

    小实例,我只写了最重要的部分

  • //要循环的数据
    $scope.data = [
        {
            str: 'a'
        },
        {
            str: 'b'
        },
        {
            str: 'c'
        }
    ]
    //自定义指令repeatFinish
    app.directive('repeatFinish',function(){
        return {
            link: function(scope,element,attr){
                console.log(scope.$index)
                if(scope.$last == true){
                    console.log('ng-repeat执行完毕')
                }
            }
        }
    })
    <div id="box">
        <span ng-repeat="item in data" repeat-finish>{{item.str}}</span>
    </div>
  • 打开控制台,会打印出0,1,2,当$index = 2点时候,$last值为true,ng-repeat渲染完毕 

    so easy!

    当然指令最好是能够复用,在这个指令内写具体的业务逻辑不利于复用,可以通过给指令指定一个处理函数renderFinish

    <div id="box">
        <span ng-repeat="item in data" repeat-finish="renderFinish()">{{item.str}}</span>
    </div>

    再通过指令的attr参数获取这个处理函数

    app.directive('repeatFinish',function(){
        return {
            link: function(scope,element,attr){
                console.log(scope.$index)
                if(scope.$last == true){
                    console.log('ng-repeat执行完毕')
                    scope.$eval( attr.repeatFinish )
                }
            }
        }
    })
    //controller里对应的处理函数
    $scope.renderFinish = function(){
        console.log('渲染完之后的操作')
    }

    attr获取到的属性只是一个字符串表达式,$scope.$eval方法是专门执行AngularJS表达式的,通过它处理函数得以执行,这样,指令用在不同的地方,可传递不同的处理函数。

    有些业务比较复杂,可能ng-repeat渲染完成之后,需要执行多个操作并且这多个操作有多个前端完成,需要用到angular的事件,在repeatFinish指令的link函数内触发一个事件,各位前端同学监听该事件完成各自的操作

    app.directive('repeatFinish',function(){
        return {
            link: function(scope,element,attr){
                console.log(scope.$index)
                if(scope.$last == true){
                    console.log('ng-repeat执行完毕')
                    //向父控制器传递事件
                    scope.$emit('to-parent');
                    //向子控制器传递事件
                    scope.$broadcast('to-child');
                }
            }
        }
    })
    //父控制器中监听事件
    $scope.$on('to-parent',function(){
        //父控制器执行操作
    })
    
    //子控制器中监听事件
    $scope.$on('to-child',function(){
        //子控制器执行操作
    })

    如何在当前控制器下监听到该事件呢?angular没有向当前控制器传递事件的方法,可以先向父(子)控制器传递事件,父(子)控制器监听到事件后反过来向子(父)控制器传递事件。

  • ng-cloak指令
  • ng-cloak 指令用于在 AngularJS 应用在加载时防止 AngularJS 代码未加载完而出现的问题。

    AngularJS 应用在加载时,文档可能会由于AngularJS 代码未加载完而出现显示 AngularJS 代码,进而会有闪烁的效果, ng-cloak 指令是为了防止该问题的发生。

  • $scope指令
  • AngularJS 应用组成如下:

    • View(视图), 即 HTML。
    • Model(模型), 当前视图中可用的数据。
    • Controller(控制器), 即 JavaScript 函数,可以添加或修改属性。

    scope 是模型。

    scope 是一个 JavaScript 对象,带有属性和方法,这些属性和方法可以在视图和控制器中使用。

  • <div ng-app="myApp" ng-controller="myCtrl">
        <input ng-model="name">
        <h1>{{greeting}}</h1>
        <button ng-click='sayHello()'>点我</button>    
    </div>
    
    <script>
    var app = angular.module('myApp', []);
    app.controller('myCtrl', function($scope) {
        $scope.name = "Runoob";
        $scope.sayHello = function() {
            $scope.greeting = 'Hello ' + $scope.name + '!';
        };
    });

     效果: