angular的directive中自定义属性作为条件中转

js:

const myapp = angular.module('myapp',[]);

myapp.controller('ctrl1',['$scope',function ($scope) {
    $scope.loadData= function () {
        console.log(" 执行了加载数据的函数1");
    };
}]);


myapp.controller('ctrl2',['$scope',function ($scope) {
    $scope.loadData2= function () {
        console.log(" 执行了加载数据的函数222");
    };
}]);

myapp.directive('hello',function () {
    return {
        restrict:'AE',
        template:"<div>load hello data<div>",
        replace:true,
        link:function (scope,element,attr) {               // scope是link函数接收来的,上面传过来的$scope
            element.bind('mouseenter',function () {
                // scope.loadData();                 // 调用上面传过来的$scope的方法,也可以用apply来调用
                // scope.$apply("loadData()");          // 用apply注意是传入字符串,并且字符串是完整的调用形式,即带括号()

                scope.$apply(attr.howtoload);    // 这里的howtoload是属性名,就是对应的函数名的一个变量名,别名
                                                    // 特别注意这里的属性用的是小写,这是个坑,就是在directive中自定义的属性,在js中要小写
                                                    // 不然,不报错,但是找不到,执行不到!
            })
        }
    }
});
 
 
 
html:
 
<div hello ng-controller="ctrl1" howToLoad="loadData()"></div>
<hello ng-controller="ctrl2" howToLoad="loadData2()"></hello>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值