javascript - angularJS指令如何暴露API给外面的controller使用?
问题描述
<button>expand</button><my-menu></my-menu>
我想点击按钮就展开menu,但怎么将menu的API暴露出来给button使用呢?或者有没有其他更好的做法?
问题解答
回答1:不需要暴露什么API, 你只需要在指令上使用自定义属性进行数据双向绑定即可。比如你需要显示隐藏,你就在指令上使用一个display属性,例如:
<my-menu display='someCtrlValue' ></my-menu>
然后在你的控制器中去控制这个值,比如
if(condition){ $scope.someCtrlValue = true; }
当然指令中你只需要指定双向绑定的属性即可;
Module.directive('myMenu', function(){ return { scope: { display : ’=’ } ... } })回答2:
你可以在写my-menu指令的时候,指定一个双向绑定属性,比如collapse,然后通过<my-menu collapse='val'></my-menu>这样使用,然后通过button的ng-click事件控制val变量(true/false)就可以。然后在定义指令时,通过独立作用域实现双向绑定,可参考http://xgfe.github.io/2015/12...这篇文章
回答3:提供一个方法可以在指令中进行emit, 然后controller进行on监听另外,一般指令是外部像内部传值 才能达到指令的灵活性 ,如果这样每次修改API不是得修改指令了?
相关文章:
1. MYSQL新建用户设置可以远程访问的问题2. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)3. java - mybatis怎么实现在数据库中有就修改,没有就添加4. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题5. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?6. 各位谁知道这个CSS时候哪里出错了???7. mysql - 我的myeclipse一直连显示数据库连接失败,不知道为什么8. mysql 5.7单表300万数据,性能严重下降,如何破?9. mysql - SQL操作时间的函数?10. mysql 为何insert的时候会有lock wait timeout 异常
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)