zoukankan      html  css  js  c++  java
  • AngularJS自定义Directive与controller的交互

    有时候,自定义的Directive中需要调用controller中的方法,即Directive与controller有一定的耦合度。

    比如有如下的一个controller:

    app.controller('MyCtrl',function($scope){
       $scope.load = function(){
           console.log('loading more...')
       }
    });

    现在自定义一个Direcitve,需要调用MyCtrl这个controller中的load方法。

    app.directive('enter', function(){
        return function($scope, ele, attrs){
            ele.bind('mouseenter', function(){
                $scope.load();
            })
        }
    })

    页面这样调用:

     <div ng-controller="MyCtrl">
        <div enter>enter to load more</div>
      </div>

    如果想调用MyCtrl中的其它方法呢?这时候就需要更改direcitve中的编码。由此可见在directive以硬编码的方法是调用controller中的方法是不太合理的。

    那么把变化的可能性放在页面上会怎样呢?

    给enter一个属性值,该属性值表示调用哪个方法。

      <div ng-controller="MyCtrl">
        <div enter="load()">enter to load more</div>
      </div>
      

    这样,总比在directive中硬编码要灵活一些。

    directive相应改成这样:

    app.directive('enter', function(){
        return function($scope, ele, attrs){
            ele.bind('mouseenter', function(){
                $scope.$apply('load()');
            })
        }
    })

    可是,以上写法还不是最合理的,因为在调用上下文的$apply方法的时候传入的实参也是字符串。

    别忘了,link函数中还有一个形参attrs,通过这个可以获取任意属性值。

    app.directive('enter', function(){
        return function($scope, ele, attrs){
            ele.bind('mouseenter', function(){
                $scope.$apply(attrs.enter);
            })
        }
    })
  • 相关阅读:
    如何添加和删除本地存储中的数据?
    本地存储和cookies之间的区别是什么?
    那么如何使用WebSQL?
    WebSQL是HTML 5规范的一部分吗?
    WebSQL是什么?
    什么是本地存储的生命周期?
    本地存储和cookies之间的区别是什么?
    什么是多线程中的上下文切换?
    web workers是什么,为什么我们需要web workers?
    连接点?
  • 原文地址:https://www.cnblogs.com/darrenji/p/5084245.html
Copyright © 2011-2022 走看看