11-Angular的自定义指令以及实例

前面的文章介绍了很多angular自带的指令,下面我们看看如何使用directive自定义指令。

先看一个例子:

<body>
    <div my-hello></div>
</body>

<script type="text/javascript">
var m1 = angular.module(‘myApp‘,[]);
m1.directive(‘myHello‘,function(){
    return {
        restrict : ‘A‘,
        replace : true,
        template : ‘<div>hello angular</div>‘
    };
});
</script>

1:我们定义了一个my-hello的指令。

2:使用directive完善这个指令,返回一个对象。有三个值:

  a) :restrict共四个值:E:标签指令,C:class指令,M:注释指令,A:属性指令

    如何使用 ?

    

  b):replace是否替换(M注释必须为true才能解析)看图:

    true:

    false:

  c):template内容,除此之外还有templateUrl,指定一个html模板文件。

下面再举个例子:

<div ng-controller="Aaa">
    <div my-tab my-id="div1" my-name="name" my-fn="show(num)" class="J-tab"></div>
    <div my-tab my-id="div2" my-name="name" my-fn="show(num)" class="J-tab"></div>
</div>
<script type="text/javascript">

var m1 = angular.module(‘myApp‘,[]);

m1.controller(‘Aaa‘,[‘$scope‘,function($scope){
    $scope.name = ‘xiecg‘;
    $scope.age = 18;
    $scope.show = function(num){
        console.log(num);
    };
}]);

m1.directive(‘myTab‘,function(){
    return {
        restrict : ‘ECMA‘,
        replace : true,    //替换的方式插入内容//绑定策略
        scope : {
            myId : ‘@‘,        //解析普通字符串
            myName : ‘=‘,    //解析数据
            myFn : ‘&‘        //函数
        },
        controller : [‘$scope‘,function($scope){
            //共享数据存放在这里
            $scope.name = ‘this is a xiecg‘;
        }],
        template : ‘<div id="{{myId}}">\
                    <input type="button" value="1" class="active" ng-click="myFn({num:456})">                    <input type="button" value="2">                    <input type="button" value="3">                    <div style="display:block;">{{myName}}</div>                    <div>2222</div>                    <div>3333</div>                </div>‘
    };
});

</script>

1:scope默认是false,为true表示独立作用域。

2:scope给予一个对象时,表示执行绑定策略,在template上调用这些数据。

  a):我们在DOM元素上my-id,我们使用@符号,表示解析普通字符串,说白了就是你写什麽就是什麽。

  b):使用=符号,表示解析数据。

  c):使用&符号,表示这绑定一个函数。

3:controller,表示绑定指令内部使用的数据。

好,下面来继续完善这个tab切换的例子!

完整代码:

<!DOCTYPE HTML>
<html ng-app="myApp">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Tab选项卡实例</title>
<style type="text/css">
    .J-tab .active{background-color:#03A9F4;}
    .J-tab div{display:none;}
</style>
<script type="text/javascript" src="js/jquery-1.11.1.js"></script>
<script type="text/javascript" src="js/angular.min.js"></script>
</head>
<body>

<div ng-controller="Aaa">
    <my-tab my-id="div1" my-data="sports" class="J-tab"></my-tab>
    <my-tab my-id="div2" my-data="time" class="J-tab"></my-tab>
</div>

<script type="text/javascript">

var m1 = angular.module(‘myApp‘,[]);
m1.controller(‘Aaa‘,[‘$scope‘,function($scope){
    $scope.sports = [
        {title : ‘篮球‘,content : ‘111111111‘},
        {title : ‘足球‘,content : ‘222222222‘},
        {title : ‘排球‘,content : ‘333333333‘}
    ];
    $scope.time = [
        {title : ‘上午‘,content : ‘444444444‘},
        {title : ‘中午‘,content : ‘555555555‘}
    ];
}]);

m1.directive(‘myTab‘,function(){
    return {
        restrict : ‘E‘,
        replace : true,
        scope : {
            myId : ‘@‘,
            myData : ‘=‘
        },
        controller : [‘$scope‘,function($scope){
            $scope.name = ‘this is a xiecg‘;
        }],
        template : ‘<div id="{{myId}}">                    <input ng-repeat="data in myData" type="button" ng-value="data.title" ng-class="{active:$first}">                    <div ng-repeat="data in myData" ng-style="{display:$first?\‘block\‘:\‘none\‘}">{{data.content}}</div>                </div>‘,
        link : function(scope,element,attr){
            element.on(‘click‘,‘input‘,function(){
                var self = $(this) , i = self.index();
                self.addClass(‘active‘).siblings(‘input‘).removeClass(‘active‘);
                self.siblings(‘div‘).eq(i).show().siblings(‘div‘).hide();
            });
        }
    };
});

</script>
</body>
</html>

link属性,表示当directive被angular编译后,执行该方法。这个方法接受三个参数,

a):scope表示controller下面的数据。

b):element表示当前的DOM元素。

c):attr表示这个DOM元素上的自定义属性。

补充:

在实际的开发过程中我们往往需要嵌套各种组件和指令。下面来介绍directive中的transclude和require。

<!DOCTYPE HTML>
<html ng-app="myApp">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>自定义指令间的互相交互</title>
<script type="text/javascript" src="js/angular.min.js"></script>
</head>
<body>

<div>
    <hello>
        <hi></hi>
    </hello>
</div>

<script type="text/javascript">

var m1 = angular.module(‘myApp‘,[]);

m1.directive(‘hello‘,function(){
    return {
        restrict : ‘E‘,
        replace : true,
        transclude : true,   //允许自定义指令的嵌套,通过ng-transclude指定嵌套的范围
        controller : function($scope){
            $scope.name = ‘xiecg‘;
            this.name = ‘xiecg‘;    //使用this共享给其他指令
        },
        template : ‘<div>hello angular <h1 ng-transclude></h1></div>‘
    };
});

m1.directive(‘hi‘,function(){
    return {
        restrict : ‘E‘,
        replace : true,
        require : ‘^hello‘,//hello指令属性hi指令的父级,需要用^符号指定。如果无法指定,使用?容错处理。
        template : ‘<span>hi angular {{name}}</span>‘,
        link : function(scope,element,attr,reController){
            console.log(reController);    //得到父级hello指令中共享出来的数据
        }
    };
});

</script>
</body>
</html>

学习笔记,如有不足,请指正!转载请保留原文链接,谢谢。

最後,微博求粉,谢谢。

时间: 2024-10-20 02:47:06

11-Angular的自定义指令以及实例的相关文章

angular创建自定义指令的四种方式

angular除了内置的部分指令,还可以通过.directive来自定义指令.要调用自定义指令,HTML 元素上需要添加自定义指令名.使用驼峰法来命名一个指令:nsHeader,在调用时使用需要-来分割:ns-header.自定义指令调用的的方式有四种,如下: 元素名 属性 类名 注释 1.使用元素名调用: 1 <!DOCTYPE html> 2 <html ng-app="myApp"> 3 <head> 4 <meta charset=&q

angular的自定义指令---详解

1.angualr指令 在angualr自己里面有许多丰富的指令,但都是平时所常见的,但对于自己所需要的可能有所欠缺,所以自己可能会摒弃原声指令,自己封装更为健壮灵活的指令: 其实angular里面的指令也是基于下面所用到的步骤来创建的,只不过他都添加到了全局中,所以可以直接使用: 2.创建自定义指令 首先创建模块app,再使用app的服务directive方法, 创建指令内容第一个参数自定义的名字,第二个参数是自定义参数属性对象,该对象包括的属性基本在代码注释解释清楚: // a.创建模块 v

angular directive 自定义指令--属性方式简单学习

1. 自定义指令 - @directive import { Component, Directive, HostListener, ElementRef } from '@angular/core' @Directive({ selector: '[input-trim]', host: { '(keyup)': 'keyUpFunc($event.target)', '(click)': 'onClick($event.target)', 'role-data': 'input-trim'

-_-#【Angular】自定义指令directive

AngularJS学习笔记 <!DOCTYPE html> <html ng-app="Demo"> <head> <meta charset="utf-8"> <title></title> </head> <body> <script src="jquery-1.8.3.min.js"></script> <scrip

angular自定义指令scope属性学习笔记

指令在angular项目中的应用非常频繁,当它自带的指令不能满足我们的需求时,我们就需要自定义指令: 在angular,作用域是一个很重要的概念.同样的,要定义一个指令,我们也需要设置他的sope: angular为自定义指令提供了三种scope:①不创建独立的作用域,直接使用父作用域(false):②创建一个继承自它的父级作用域的独立作用域(true):③创建一个完全与外部隔离的作用域({}):

Angular中的内置指令和自定义指令

NG中的指令,到底是什么(what)? 为什么会有(why)?以及怎样使用(how)? What: 在NG中,指令扩展HTML功能,为 DOM 元素调用方法.定义行为绑定数据等. Why: 最大程度减少DOM操作,实现数据绑定,与业务逻辑进行交互. How: 指令主要分为两种:内置指令和自定义指令,通过下面的例子,简单记录一下如何去使用. 内置指令 在官方API文档上罗列了很多指令,内置指令可以分为:普通指令 和 事件指令,他们都是作用于HTML之上的,通过添加属性的方式来实现的.简单看一下一些

Angular17 Angular自定义指令

1 什么是HTML HTML文档就是一个纯文本文件,该文件包含了HTML元素.CSS样式以及JavaScript代码:HTML元素是由标签呈现,浏览器会为每个标签创建带有属性的DOM对象,浏览器通过渲染这些DOM节点来呈现内容,用户在浏览器中看到的内容就是浏览器渲染DOM对象后的结果. 2 指令的分类 组件.属性指令.结构性指令 具体的知识点请参见<Angular2揭秘> 3 指定义指令常用到的一些常量 3.1 Directive 用于装饰控制器类来指明该控制器类是一个自定义指令控制器类 3.

Angular自定义指令(directive)

angular自定义指令,意我们可以通过angula自己定义指令,来实现我们的特殊要求,为所欲为,一支穿云箭,千军万马来相见 多少年的老规矩了,先看代码: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <meta http-equiv="X-UA-Compatible" content=&quo

angular指令详解--自定义指令

自定义指令 directive()这个方法是用来定义指令的: angular.module('myApp', []) .directive('myDirective', function ($timeout, UserDefinedService) { // 指令定义放在这里 }); directive() 方法可以接受两个参数:1. name(字符串)指令的名字,用来在视图中引用特定的指令.2. factory_function (函数)这个函数返回一个对象,其中定义了指令的全部行为.$com