我曾经在我的html'computing-td-plan.html'里面有这个
<tr ng-repeat="foodCalculation in selectedMealCalc.calculated_foods">
<td>{{foodCalculation.food.name}}</td>
<td>{{foodCalculation.gram_amount}} g</td>
<td>{{foodCalculation.kcal}} kcal</td>
<td>{{foodCalculation.proteina}} g</td>
<td>{{foodCalculation.cho}} g</td>
<td>{{foodCalculation.lipideos}} g</td>
<td class="text-center">
<button class="btn btn--principal btn--xs" ng-click="edtiFoodCalc(selectedmealcalc, foodCalculation, $index)">Editar</button>
<button class="btn btn--principal btn--xs" ng-click="removeFoodCalc(selectedmealcalc, foodCalculation)">Remover</button>
</td>
</tr>
然后我创建一个像上面这样的指令。
<div class="row">
<div class="col-md-12" ng-show="( items | filter: { food_option: option } ).length > 0">
Opção {{ option }}
<table class="table table-calculo table-striped">
<thead>
<tr>
<th>Alimento</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="foodCalculation in ( items | filter: { food_option: option } ) track by $index">
<td>{{foodCalculation.food.name}}</td>
<td class="text-center">
<button class="btn btn--principal btn--xs" ng-click="edtiFoodCalc(selectedmealcalc, foodCalculation, $index)">Editar</button>
<button class="btn btn--principal btn--xs" ng-click="removeFoodCalc(selectedmealcalc, foodCalculation)">Remover</button>
</td>
</tr>
</tbody>
</table>
</div>
</div>
我在'calculate-td-plan.html'中将此指令称为
<div ng-repeat="option in [0,1,2,3,4]">
<meal-option option="{{option}}"
items="selectedMealCalc.calculated_foods"
selectedmealcalc="selectedMealCalc"></meal-option>
</div>
这是我的指令JS。
'use strict';
angular.module('nutriApp').directive('mealOption', ['$compile', function($compile) {
var mealOption = {
restrict: 'E',
templateUrl: 'views/checkins/meal-options.html',
require: 'foodSelector',
scope: {
option: "@",
items: "=",
selectedmealcalc: "="
}
};
mealOption.controller = ['$scope', 'Food', function($scope, Food) {
$scope.sumFood = {};
$scope.summerizeOption = function(foods) {
if(foods.length > 0){
$scope.sumFood = Food.summerize(foods);
}
};
}];
return mealOption;
}]);
但是现在我称之为edtiFoodCalc
和removeFoodCalc
的功能不起作用。
当我把ng-controller
放在我的指令中它起作用时,(只调用方法)但我不能得到相同的范围。
<div class="row" ng-controller="CheckinsPlansCtrl">
我试图用edtiFoodCalc
编辑,我没有得到我想要的结果。我认为当我做ng-controller
时,ng-repeat
会创建新的范围,而当我没有指令代码时,代码就可以了。
<div ng-repeat="option in [0,1,2,3,4]">
<meal-option option="{{option}}"
items="selectedMealCalc.calculated_foods"
selectedmealcalc="selectedMealCalc"></meal-option>
</div>
您可以使用angular的&
绑定,它允许指令的范围将值传递回父范围。这些值不需要在控制器中定义 - 它们可以在指令中定义,然后发送回控制器。
例如,给定一个控制器和指令:
// Controller
app.controller('MainCtrl', function($scope) {
$scope.funcA = function(value, index) {
console.log("Called funcA from " + value + " with index " + String(index));
};
$scope.funcB = function(value, index) {
console.log("Called funcB from " + value + " with index " + String(index));
}
});
// Directive
app.directive('arrayDirective', function() {
return {
templateUrl: "array_directive.html",
scope: {
controllerFuncA: "&controllerFuncA",
controllerFuncB: "&controllerFuncB"
},
link: function (scope, element, attr) {
scope.items = ["a","b","c","d","e"];
scope.callControllerFuncA = function(i) {
console.log("Calling controller funcA!");
scope.controllerFuncA({from: "directive", index: i});
};
scope.callControllerFuncB = function(i) {
console.log("Calling controller funcB!");
scope.controllerFuncB({from: "directive", index: i});
};
}
};
});
以下模板:
<!-- Controller template -->
<body ng-controller="MainCtrl">
<array-directive controller-func-a="funcA(from, index)" controller-func-b="funcB(from, index)"></array-directive>
</body>
<!-- Directive template -->
<div>
<div ng-repeat="item in items">
<div>{{item}}</div>
<div><a href="#" ng-click="callControllerFuncA($index)">Call Controller Func A</a></div>
<div><a href="#" ng-click="callControllerFuncB($index)">Call Controller Func B</a></div>
</div>
</div>
然后,您可以在指令中使用controllerFuncA
和controllerFuncB
来调用相应的父控制器函数funcA
和funcB
。请注意,这些指令函数将对象作为参数,其中对象的键对应于传递给<array-directive>
标记上的指令的键。
请参阅随附的小提琴并观看开发人员控制台以获取完整示例:https://plnkr.co/edit/3h8J00ndBk4OQ16C8hf2