Angularjs传递函数从控制器到指令(或指令呼叫控制器功能) - 与参数
问题描述:
我的问题很简单,我只是想通过一个控制器功能指令。换句话说,我只是想从指令中调用一个控制器函数。Angularjs传递函数从控制器到指令(或指令呼叫控制器功能) - 与参数
var myapp =angular.module('myapp',[]);
myapp.controller('myCtrl',['$scope','$timeout',function($scope,$timeout){
$scope.fnItemsOnAdded = function(itms){
alert('Hi, I am in controller add. Here are your Items: '+JSON.stringify(itms));
}
$scope.fnItemsOnCancel = function(itms){
alert('Hi, I am in controller cancel. Here are your Items: '+JSON.stringify(itms));
}
}]);
myapp.directive('myPicker',['$timeout',function($timeout){
var dtv={};
dtv.template = '<li ng-repeat="itm in ngModel.ItemsList"><label><input type="checkbox" ng-model="itm.IsSelected" />{{itm.Name}}</label></li>';
dtv.template += '<a href="javascript:void(0)" ng-click="addItems()" class="addItems">add items</a>';
dtv.template += '<a href="javascript:void(0)" ng-click="cancelItems()" class="cancel">cancel</a>';
dtv.scope = { postUrl: '@', jsonadd: '&', jsoncancel: '&' };
dtv.restrict = 'A';
dtv.link = function($scope,elm,attrs){
$scope.ngModel={};
$scope.ngModel.SelectedKeys=[];
$timeout(function(){
$scope.ngModel.ItemsList = [
{Name:"Item1",IsSelected:false},
{Name:"Item2",IsSelected:false},
{Name:"Item3",IsSelected:false},
{Name:"Item4",IsSelected:true},
{Name:"Item4",IsSelected:false},
];
},100);
$scope.addItems = function(){
//Dummy logic to update SelectedKeys
for(var idx =0;idx<$scope.ngModel.ItemsList.length;idx++){
if($scope.ngModel.ItemsList[idx].IsSelected){
$scope.ngModel.SelectedKeys.push($scope.ngModel.ItemsList[idx]);
}
}
alert("i'm in directive add. Lemme call parent controller");
$scope.jsonadd($scope.ngModel.SelectedKeys);
}
$scope.cancelItems = function(){
alert("i'm in directive cancel. Lemme call parent controller");
$scope.jsonadd($scope.ngModel.SelectedKeys);
}
}
return(dtv);
}]);
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="myapp" ng-controller="myCtrl">
<div class="jqmWindow" id="myPickListDiv" my-picker jsonadd="fnItemsOnAdded" jsoncancel="fnItemsOnCancel" post-url="/myurl"></div>
</div>
- 我试图this approach但它不会触发功能,不抛出任何错误要么。
- 我试图this和this的方法 - 它返回一个错误$申请正在进行中。
任何人可以帮我,我要去哪里错在这里。我认为它与$ scope继承或约定有关。
我知道我在这里做了一些小错误,只是我在我赶弄不明白。
非常感谢您的帮助!
答
你快到了。传递参数的语法有点奇怪。
在你的HTML,使用类似
<div my-picker jsonadd="fnItemsOnAdded(items)"...
,并在你的指令......
$scope.jsonadd({items: $scope.ngModel.SelectedKeys})
的钥匙,传递给分离范围功能(jsonadd
,jsoncancel
)对象需要匹配属性中使用的参数名称。
我不知道在哪里SelectedKeys
来源于但我以为你只是省略的东西简洁。
是的你是对的,我很抱歉我错过了SelectedKeys部分。非常感谢你的有见地的答复。 Lemme现在就试试这个。 – amitthk 2015-02-23 03:29:16
我其实已经尝试了你的建议,并且它能正常工作[这里](http://jsfiddle.net/amitthk/y68zhoLu/)。但同样的事情在我的应用程序中不起作用。我在我的应用程序中唯一的区别是我的页面上有相同的ng-app内的3个控制器。我的指令是在我的原始控制器“myCtrl”在上面的情况。在我的代码中似乎还有其他一些疯狂的错误,我似乎不明白。无论如何非常感谢你的帮助。 – amitthk 2015-02-23 04:42:10