自定义指令directive

1.自定义指令

在angular中,module下面的directive方法用于创建自定义指令,用法:

m1.directive(‘myTab‘,function(){

  return {

    restrict : ‘AE‘,

    replace : true,

    templateUrl : ‘‘,

};

});

大致用法如上,在directive的第二个参数里面return出一个对象,对象里面有各种属性。

restrict----指定创建的指令是什么类型,A--attr属性指令,E--element标签指令,C---class指令,M---注释指令.常用的就是A和E。

replace---是否用模板来替换元素

templateUrl---指定模板字符串

还有一些:

controller---指令控制器。这里面可以定义一些指定公用的数据和方法。如:

controller : [‘$scope‘,function($scope){
  $scope.name = ‘meng‘;
  $scope.show = function(n){
    alert(n+1);
  }
}],

scope---作用域,共有三个值

默认值false。

表示继承父作用域;

true

表示继承父作用域,并创建自己的作用域(子作用域);

{}

表示创建一个全新的隔离作用域;

隔离作用域中有三种绑定策略[email protected],=,&

@ --- 使用@(@attr)来进行单向文本(字符串)绑定

= --- 使用=(=attr)进行双向绑定变量

& --- 使用&来调用父作用域中的函数

link:一个函数,用于操作dom,添加事件,指令间相互调用

该函数一共有4个参数,scope,element,attr,reController

scope --- 该指令的作用域

element--- 该指令解析后的顶层元素

attr-- 属性

指令之间交互 通过transclude和require

设置transclude:true之后,就可以通过ng-transclude来嵌套指令

require---字符串代表另一个指令的名字,它将会作为link函数的第四个参数

没有前缀,指令会在自身提供的控制器中进行查找,如果找不到任何控制器,则会抛出一个error

?如果在当前的指令没有找到所需的控制器,则会将null传给link连接函数的第四个参数

^如果在当前的指令没有找到所需的控制器,则会查找父元素的控制器

?^组合

<!doctype html>
<html ng-app="myApp">
<head>
  <script src="http://cdn.staticfile.org/angular.js/1.2.10/angular.min.js"></script>
</head>
<body>

  <outer-directive>
     <inner-directive></inner-directive>
     <inner-directive2></inner-directive2>
  </outer-directive>
  <script>
    var app = angular.module(‘myApp‘, []);
    app.directive(‘outerDirective‘, function() {
          return {
               scope: {},
               restrict: ‘AE‘,
               controller: function($scope) {
                  this.say = function(someDirective) {
                     console.log(‘Got:‘ + someDirective.message);
                  };
               }
           };
    });
    app.directive(‘innerDirective‘, function() {
          return {
               scope: {},
               restrict: ‘AE‘,
               require: ‘^outerDirective‘,
               link: function(scope, elem, attrs, controllerInstance) {
                       scope.message = "Hi,leifeng";
                       controllerInstance.say(scope);
               }
          };
    });
    app.directive(‘innerDirective2‘, function() {
          return {
               scope: {},
               restrict: ‘AE‘,
               require: ‘^outerDirective‘,
               link: function(scope, elem, attrs, controllerInstance) {
                       scope.message = "Hi,shushu";
                       controllerInstance.say(scope);
               }
          };
    });

  </script>

</body>
</html>
m1.directive(‘myTab‘,function(){
    return {
        restrict : ‘E‘,
        replace : true,
        scope : {
            myId : ‘@‘,
            myData : ‘=‘
        },
        controller : [‘$scope‘,function($scope){
            $scope.name = ‘meng‘;
        }],
        templateUrl : ‘temp3.html‘,
        link : function(scope,element,attr){
            //console.log(scope.name);
            //console.log(element);
            //console.log(attr.myId);

                 }
});    
时间: 2024-11-03 20:57:23

自定义指令directive的相关文章

AngularJS之基础-5 路由(定义路由、使用路由)、自定义指令(Directive)

一.定义路由 ng-view - AngularJS 支持通过在单页面上的多个视图的单页应用 - ng-view 标记只是简单地创建一个占位符 - 使用 ng-template - 创建使用script标签的HTML视图 - 使用 - 定义类型作为主模块中 ng-template 的脚本块 $routeProvider - 映射相应的HTML页面或ng-template - 附加一个控制器使用相同键的服务   - 注意: - 需要angular-route.js脚本文件的引用 二.使用路由 锚点

vue自定义指令(Directive中的clickoutside.js)的理解

.array p { counter-increment: longen; margin-left: 10px } .array p::before { content: counter(longen) "." } .alink { font-size: 16px; color: blue } 阅读目录 vue自定义指令clickoutside.js的理解 回到顶部 vue自定义指令clickoutside.js的理解 vue自定义指令请看如下博客: vue自定义指令 一般在需要 DO

angular 自定义指令 directive transclude 理解

项目中断断续续的用了下angular,也没狠下心 认真的学习.angular 特别是自定义指令这块 空白. transclude 定义是否将当前元素的内容转移到模板中.看解释有点抽象. 看解释有点抽象Demo: <!DOCTYPE html> <html lang="en" ng-app='myApp'> <head> <meta charset="UTF-8"> <title>Angularjs</

vue 自定义指令directive

//自定义指令:directive 的传参--可以数据也可以是字符串 Vue.directive('scroll', function (binding) { window.addEventListener('scroll', function () { if (document.body.scrollTop + window.innerHeight >= document.body.clientHeight-20) { var fnc = binding; fnc(); } }) }); 调用

vue.js实现内部自定义指令和全局自定义指令------directive

在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东 directive 这个单词是我们写自定义指令的关键字哦 之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表现状态 bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作. inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中). update:

angularjs 一篇文章看懂自定义指令directive

 壹 ? 引 在angularjs开发中,指令的使用是无处无在的,我们习惯使用指令来拓展HTML:那么如何理解指令呢,你可以把它理解成在DOM元素上运行的函数,它可以帮助我们拓展DOM元素的功能.比如最常用ng-click可以让一个元素能监听click事件,这里你可能就有疑问了,同样都是监听为什么不直接使用click事件呢,angular提供的事件指令与传统指令有什么区别?我们来看一个例子: <body ng-controller="myCtrl as vm"> <d

vue自定义指令directive

vue中指令分为全局指令和局部指令 先来看全局自定义指令: 第一个参数是指令的名字,第二个参数可以是函数也可以是对象,先来看函数: 函数中接收三个参数: el在这里是input元素 bindings里是一些绑定信息: 其中expression是指绑定的变量名字,这里是content name是指令名字 value是绑定数据的值,上面content为空,所以目前value为空 v-slice上还可以写修饰符 还可以传参: vnode虚拟节点: vnode中contex是vue实例,其中的conte

自定义指令-directive (转)

1.指令作用域中的@ 作用是把当前属性作为字符串传递. 前台代码: <div ng-controller="MyCtrl">       <drink water="{{pureWater}}"></drink></div> Js代码: <script type="text/javascript"> var myModule = angular.module("MyModule

-_-#【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