我将一个值传递给我的 mdDialog 控制器以编辑模式中的内容,但用户取消模式时无法保存任何调整,但如果我更改为模式中的内容,我会看到后面的列表中发生的更改(在父视图上),当我取消模式时,更改不会撤消。选项 bindToController 设置为 true,因此应传递副本而不是引用。
vm.editFaq = function (faqToEdit, ev){
var useFullScreen = ($mdMedia('sm') || $mdMedia('xs')) && vm.customFullscreen;
$mdDialog.show({
controller: 'editFaqController'
, controllerAs: 'dvm'
, templateUrl: './app/components/faq/modals/editFaq.html'
, parent: angular.element(document.body)
, targetEvent: ev
, clickOutsideToClose: true
, fullscreen: useFullScreen
, locals: { faq : faqToEdit }
, bindToController: true
}).then(function(result){
if(result){
_.findWhere(vm.allFaqs, { _id: faqToEdit._id }) = result;
}
});
$scope.$watch(function () {
return $mdMedia('xs') || $mdMedia('sm');
}, function (wantsFullScreen) {
$scope.customFullscreen = (wantsFullScreen === true);
});
};
所以当 to modal 被隐藏时,“then”promise 被调用并且可以提交调整。