AngularJSAngularJS学习篇(三)

开创于定义之命令

除开 AngularJS 内置的通令外,我们尚可创造于定义指令。

公可使 .directive 函数来填补加起定义的吩咐。

要是调用自定义指令,HTML 元素上需要丰富自定义指令名。

以驼峰法来命名一个命, myAngular,
但在使用它们常用为  分割, my-angular:

君得由此以下办法来调用指令:

  • 元素名
  • 属性
  • 类名
  • 注释

元素名

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="angular-1.6.3/angular.js"></script>
</head>
<body>
<div ng-app="myDirective">
    <my-angular></my-angular>
</div>
<script>
    var app=angular.module("myDirective",[]);
    app.directive("myAngular", function() {//注意名称myAngular---<my-angular>
        return {
            template : "<p>自定义指令!</p>"
        };
    });
</script>
</body>
</html>

属性:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="https://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> 
</head>
<body ng-app="myApp">

<div runoob-directive></div>

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        template : "<h1>自定义指令!</h1>"
    };
});
</script>

</body>
</html>

类名:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="https://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> 
</head>
<body ng-app="myApp">

<div class="runoob-directive"></div>

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        restrict : "C",
        template : "<h1>自定义指令!</h1>"
    };
});
</script>

<p><strong>注意:</strong> 你必须设置 <b>restrict</b> 的值为 "C" 才能通过类名来调用指令。</p>

</body>
</html>

注释:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="https://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> 
</head>
<body ng-app="myApp">

<!-- directive: runoob-directive -->

<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        restrict : "M",
        replace : true,
        template : "<h1>自定义指令!</h1>"
    };
});
</script>

<p><strong>注意:</strong> 我们需要在该实例添加 <strong>replace</strong> 属性, 否则评论是不可见的。</p>

<p><strong>注意:</strong> 你必须设置 <b>restrict</b> 的值为 "M" 才能通过注释来调用指令。</p>

</body>
</html>

限制使用

您得界定而的下令只能通过特定的点子来调用。

restrict 值可以是以下几种:

  • E 作为元素名以
  • A 作为性能使用
  • C 作为类名使用
  • M 作为注释使用

restrict 默认值为 EA, 即可以由此元素名以及性能名来调用指令。

 

相关文章