我正在使用基础模态与角度(http://pineconellc.github.io/angular-foundation/)的集成,并且在模式上发送关于关闭的正确信息时遇到问题:这就是我所拥有的
模态:
<script type="text/ng-template" id="dataBlockType.html">
<h4>Select Type</h4>
<select ng-model="blockTHereSelect" ng-options="type.name for type in items track by type.id">
</select>
{{blockTHereSelect.name}}
<button class="button" ng-click="ok()">OK</button>
<a class="close-reveal-modal" ng-click="cancel()">×</a>
</script>
<!-- type modal -->
控制器内部的模态功能:
$scope.openModal = function () {
var modalInstance = $modal.open({
templateUrl: 'dataBlockType.html',
controller: ModalInstanceCtrl,
resolve: {
items: function () {
return $scope.dataTypes;
}
}
});
//return of modal
modalInstance.result.then(function (returnAns) {
$scope.storeTempName = returnAns;
console.log($scope.storeTempName);
//push new information from modal in
$scope.dataBlockstypes.push({id:"",name: "" , blocks: [], typeId: "" });
}, function () {
//return function if needed
});
};
模态控制器:
var ModalInstanceCtrl = function ($scope, $modalInstance, items) {
$scope.blockTHereSelect = {};
//bring in retuned list to populate modal select list
$scope.items = items;
//pass back selection
$scope.ok = function () {
$modalInstance.close($scope.blockTHereSelect);
};
//close
$scope.cancel = function () {
$modalInstance.dismiss('cancel');
};
};
所以这适用于传递信息以从原始控制器(yay)填充模态。但我似乎遇到问题的地方是传回所选的选项名称和ID。我的想法是,如果我只是传回附加到它的模型($ scope.blockTHereSelect),它将传递和对象,然后我可以调用.id和.name。然而,它作为一个空对象返回,如果我尝试单独发送$ scope.blockTHereSelect.id和$ scope.blockTHereSelect.name,它们将返回undefined。我似乎有点难过,我认为它可能与模型或范围在模态控制器中的工作方式有关。感谢任何帮助,似乎无法解决这个问题。 谢谢!