Переданное значение все еще редактируется после отмены углового mddialog

0

Я передаю значение моему контроллеру 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);
    });
};

Поэтому, когда модальное скрыто, вызывается "то" обещание и корректировки могут быть совершены.

  • 0
    Используйте angular.copy при назначении значения объекта или массива другой переменной, и это значение объекта не следует изменять, см. Stackoverflow.com/questions/33043850/… .
Теги:
angular-material
mddialog

2 ответа

1
Лучший ответ

Я использовал angular.copy, друг сказал мне, что даже с bindToController или какой-либо другой вариант mdDialog, который сказал работать, всегда передает ссылку на объект.

0

вы можете решить так:

     vm.editFaq = function   (faqToEdit, ev){

 var useFullScreen = ($mdMedia('sm') || $mdMedia('xs')) && vm.customFullscreen;

          faqToEdit = angular.copy(faqToEdit);

          $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;
            }
          });

        }

Ещё вопросы

Сообщество Overcoder
Наверх
Меню