指令分类:
1)装饰器型指令
装饰器指令的作用是为DOM添加行为,使其具有某种能力。在AngularS中,大多数内置指令属于装饰器型指令,例如ng-click(单击事件)、ng-hide/ng-show(控制DOM元素的显示和隐藏)等
2)组件型指令
组件型指令是一个小型的整体,其中包含业务所需要显示的视图和交互逻辑,例如开发者要在页面添加某个功能
1、常用的内置指令
1.1 程序控制类

1.2 数据绑示类

<body ng-app="myApp" ng-controller="myCtrl">
    姓名:<input type="text" ng-model="name">
    <hr><!-- 差值表达式{{ }} -->
    <span>输入的姓名为:{{ name }}</span>
    <hr><!-- ng-bind指令 -->
    <span ng-bind="name">输入的姓名为:</span>
    <hr><!-- ng-model指令 -->
    姓名:<input type="text" ng-model="name+'666'">
    
</body>
</html>
<script>
    var app= angular.module('myApp',[]);
    app.controller('myCtrl',function($scope){
        // 定义属性name
        $scope.name = "lucy";
    });
</script>1.3 访问流程类

1) ng-if
语法格式:
<element ng-if="expression"></element>示例:
<body ng-app="myApp" ng-controller="myCtrl">
    篮球:<input type="checkbox" ng-model="isCheck">
    <div ng-if="isCheck">
        喜欢<input type="radio" name="hobby">
        一般<input type="radio" name="hobby">
        讨厌<input type="radio" name="hobby">
    </div>
</body>
</html>
<script>
    var app= angular.module('myApp',[]);
    app.controller('myCtrl',function($scope){
        $scope.isCheck = false;
    });
</script>

2) ng-switch
语法格式:
<element ng-switch on="expression">
    <element ng-switch-when="expression1">...</element>
    <element ng-switch-when="expression1">...</element>
    ...
    <element ng-switch-default>...</element>
</element>示例:实现每日食谱
<body ng-app="myApp" ng-controller="myCtrl">
    <div ng-switch on="day">
        周{{ day }}食谱
        <div ng-switch-when="1">食品1</div>
        <div ng-switch-when="2">食品2</div>
        <div ng-switch-when="3">食品3</div>
        <div ng-switch-when="4">食品4</div>
        <div ng-switch-when="5">食品5</div>
        <div ng-switch-when="6">食品6</div>
        <div ng-switch-default>食品7</div>
    </div>
</body>
</html>
<script>
    var app= angular.module('myApp',[]);
    app.controller('myCtrl',function($scope){
        let day = new Date().getDay();
        $scope.day = day;
    });
</script>

3) ng-repeat
语法格式:
<element ng-repeat="item in collection"></element>注意:当数组中有重复元素时,需要使用 track by $index

示例:
<body ng-app="myApp" ng-controller="myCtrl">
    <ul>
        <li ng-repeat="item in datas">
           {{item }} 
        </li>
    </ul>
    
</body>
</html>
<script>
    var app= angular.module('myApp',[]);
    app.controller('myCtrl',function($scope){
        $scope.datas = [10,20,30,40];
    });
</script>1.4 事件绑定类
AngularJS指令不会覆盖JavaScript的事件,例如鼠标单击HTML元素时,ng-click指令与JavaScript的 on-click 事件将都会执行。

1.5 状态设置类

1.6 加载处理类

2、自定义指令
2.1 基本语法
AngularJS中使用模块的 directive() 函数来自定义指令
var app = angular.module('app',[]);
app.directive('指令名称',function(){
    return{
        template,
        templateUrl,
        replace ,
        restrict,
        ...
    }
})




















