Подтвердите диалоговое окно в angularjs

Как я могу применить диалоговое окно подтверждения в кнопке ниже в angularjs?

<button class="btn btn-sm btn-danger" ng-click="removeUser($index)">Delete</button>

Именно так.

<span><a class="button" onclick="return confirm('Are you sure to delete this record ?')" href="delete/{{ item.id }}">Delete</span>

Обновить

В настоящее время я делаю это так

    function removeUser(index) {
      var isConfirmed = confirm("Are you sure to delete this record ?");
      if(isConfirmed){
        vm.users.splice(index, 1);
      }else{
        return false;
      }
    };

4 ответа

Решение

Вот фрагменты,

каким должен быть ваш HTML,

<button class="btn btn-sm btn-danger" ng-confirm-click="Are you sure to delete this record ?" confirmed-click="removeUser($index)">Delete</button>

Пожалуйста, включите эту директиву в ваш файл angularjs,

app.directive('ngConfirmClick', [
    function(){
        return {
            link: function (scope, element, attr) {
                var msg = attr.ngConfirmClick || "Are you sure?";
                var clickAction = attr.confirmedClick;
                element.bind('click',function (event) {
                    if ( window.confirm(msg) ) {
                        scope.$eval(clickAction)
                    }
                });
            }
        };
}])

Ваша угловая область, основанная на вашей функции удаления, упомянутой выше,

$scope.removeUser = function(index) {
    vm.users.splice(index, 1);
}
$scope.removeUser= function (ind){
 if (confirm("Are you sure?")) {
    alert("deleted"+ s);
    $window.location.href = 'delete/'+ s;
 }
}

http://jsfiddle.net/ms403Ly8/61/

Я бы отделил бит сообщения от бита действия удаления, чтобы вы могли повторно использовать бит подтверждения в других частях вашего приложения: я использую директиву так:

angular.module('myModule').directive("ngConfirmClick", [
  function() {
   return {
     priority: -1,
      restrict: "A",
      link: function(scope, element, attrs) {
        element.bind("click", function(e) {
          var message;
          message = attrs.ngConfirmClick;
          if (message && !confirm(message)) {
           e.stopImmediatePropagation();
           e.preventDefault();
          }
        });
      }
    };
  }
]);

затем используйте функцию контроллера с действием delete:

$scope.removeUser(index) {
  //do stuff
}

и в представлении я бы использовал ng-click:

<span><a class="button" ng-confirm-click="Are you sure?" ng-click="removeUser(item.id}}">Delete</span>

Надеюсь, поможет.

Вы можете попробовать этот поршень: http://plnkr.co/edit/xJJFxjYeeHmDixAYPu4c?p=preview Вы можете создать директиву для диалога.

var app = angular.module('plunker', []);

 app.controller('MainCtrl', function($scope, $window) {

   $scope.delete = function(id) {
     $window.location.href = 'delete/'+ id;
   }
 });

 app.directive('ngConfirmClick', [
    function(){
        return {
            link: function (scope, element, attr) {
                var msg = attr.ngConfirmClick || "Are you sure?";
                var clickAction = attr.confirmedClick;
                element.bind('click',function (event) {
                    if ( window.confirm(msg) ) {
                        scope.$eval(clickAction)
                    }
                });
            }
        };
}])
Другие вопросы по тегам