有时候,自定义的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);
})
}
})

最新文章

  1. std::string的split函数
  2. inverse理解
  3. ASP.NET 5
  4. Java最全文件操作实例汇总
  5. Flip Game 分类: POJ 2015-06-15 14:59 22人阅读 评论(0) 收藏
  6. Hadoop上路-03_Hadoop JavaAPI
  7. 利用wireshark抓取Telnet的用户名和密码
  8. JSP - request - 1
  9. 关于$GLOBALS[&#39;ecs&#39;]-&gt;table()的问题?
  10. windows服务安装启动报错误1053:服务没有及时响应启动或控制请求
  11. Apache Arrow 内存数据
  12. ROS_Kinetic_13 ROS数据录制与回放
  13. 配置php环境的一个nginx.conf
  14. C++初始化列表(good)
  15. SSD win7优化步骤
  16. Linux下查看与修改mtu值
  17. Spring PropertyResolver 占位符解析(二)源码分析
  18. Android百度地图相关内容汇总
  19. 源码包安装Python3.6
  20. Mirror--如何TSQL查看镜像状态和镜像相关存储过程

热门文章

  1. 基于FPGA(DDS)的正弦波发生器
  2. mysql学习------错误日志和通用查询日志
  3. Nginx报错:upstream timed out (110: Connection timed out)和client intended to send too large body【转】
  4. 公共语言运行库(CLR)开发系列课程(2):Pinvoke 进阶 学习笔记
  5. 【前端vue开发】vue开发输入姓名,电话,公司表单提交组件
  6. 【前端vue开发】vue知识点超链接学习笔记
  7. 自己动手破解rar密码-ruby脚本实现
  8. 【LOJ】#2536. 「CQOI2018」解锁屏幕
  9. bzoj 1188
  10. Storm集群启动流程分析