web-dev-qa-db-fra.com

Comment afficher un message de confirmation avant de supprimer?

Je veux obtenir un confirmer le message en cliquant sur Supprimer (peut-être un bouton ou une image). Si l'utilisateur sélectionne 'Ok', la suppression est effectuée. Sinon, si vous cliquez sur 'Cancel', rien ne se passe.

J'ai essayé de faire écho à cela lorsque le bouton a été cliqué, mais en faisant écho à des choses, mes zones de saisie et zones de texte perdent leurs styles et leur design.

173
Shyam K

Ecrivez ceci dans onclick événement du bouton:

var result = confirm("Want to delete?");
if (result) {
    //Logic to delete the item
}
290
Ved

Vous pouvez mieux utiliser comme suit

 <a href="url_to_delete" onclick="return confirm('Are you sure you want to delete this item?');">Delete</a>
245
Raghav Rach

Voici comment procéder avec du code JavaScript non intrusif et le message de confirmation en attente dans le code HTML.

<a href="/delete" class="delete" data-confirm="Are you sure to delete this item?">Delete</a>

Ceci est pur Vanilla JS, compatible avec IE 9+:

var deleteLinks = document.querySelectorAll('.delete');

for (var i = 0; i < deleteLinks.length; i++) {
  deleteLinks[i].addEventListener('click', function(event) {
      event.preventDefault();

      var choice = confirm(this.getAttribute('data-confirm'));

      if (choice) {
        window.location.href = this.getAttribute('href');
      }
  });
}

Voyez-le en action: http://codepen.io/anon/pen/NqdKZq

49
DevAntoine
function ConfirmDelete()
{
  var x = confirm("Are you sure you want to delete?");
  if (x)
      return true;
  else
    return false;
}


<input type="button" onclick="ConfirmDelete()">
23
user1697128

Essaye ça. Ça marche pour moi

 <a href="delete_methode_link" onclick="return confirm('Are you sure you want to Remove?');">Remove</a>
14
Shuhad zaman

améliorer sur user1697128 (car je ne peux pas encore commenter dessus)

<script>
    function ConfirmDelete()
    {
      var x = confirm("Are you sure you want to delete?");
      if (x)
          return true;
      else
        return false;
    }
</script>    

<button Onclick="return ConfirmDelete();" type="submit" name="actiondelete" value="1"><img src="images/action_delete.png" alt="Delete"></button>

annulera l'envoi du formulaire si on appuie sur annuler

11
Jaxx0rr

Je voudrais offrir la façon dont je fais ceci:

<form action="/route" method="POST">
<input type="hidden" name="_method" value="DELETE"> 
<input type="hidden" name="_token" value="the_token">
<button type="submit" class="btn btn-link" onclick="if (!confirm('Are you sure?')) { return false }"><span>Delete</span></button>
</form>
7
zeros-and-ones

c'est très simple et une ligne de code

<a herf="#" title="delete" class="delete" onclick="return confirm('Are you sure you want to delete this item')">Delete</a>
4
Mohammed Muzammil

HTML:

<a href="#" class="delete" data-confirm="Are you sure to delete this item?">Delete</a>

Utilisation de jQuery:

$('.delete').on("click", function (e) {
    e.preventDefault();

    var choice = confirm($(this).attr('data-confirm'));

    if (choice) {
        window.location.href = $(this).attr('href');
    }
});
4
julionc
<form onsubmit="return confirm('Are you sure?');" />

fonctionne bien pour les formulaires. Question spécifique au formulaire: JavaScript Form Submit - Boîte de dialogue Confirmer ou annuler l'envoi

HTML

<input onclick="return myConfirm();" type="submit" name="deleteYear" class="btn btn-danger" value="Delete">

Javascript

<script>
function myConfirm() {
  var result = confirm("Want to delete?");
  if (result==true) {
   return true;
  } else {
   return false;
  }
}
3
nazmulhaqued
<a href="javascript:;" onClick="if(confirm('Are you sure you want to delete this product')){del_product(id);}else{ }" class="btn btn-xs btn-danger btn-delete" title="Del Product">Delete Product</a>

<!-- language: lang-js -->
<script>
function del_product(id){
    $('.process').css('display','block');
    $('.process').html('<img src="./images/loading.gif">');
    $.ajax({
        'url':'./process.php?action=del_product&id='+id,
        'type':"post",
        success: function(result){
            info=JSON.parse(result);
            if(result.status==1){
                setTimeout(function(){
                    $('.process').hide();
                    $('.tr_'+id).hide();
                },3000);
                setTimeout(function(){
                    $('.process').html(result.notice);
                },1000);
            } else if(result.status==0){
                setTimeout(function(){
                    $('.process').hide();
                },3000);
                setTimeout(function(){
                    $('.process').html(result.notice);
                },1000);
            }
        }
    });
}
</script>
3
himos

Entraine toi

<form name=myform>
<input type=button value="Try it now" 
onClick="if(confirm('Format the hard disk?'))
alert('You are very brave!');
else alert('A wise decision!')">
</form>

Original Web:

http://www.javascripter.net/faq/confirm.htm

3
KingRider

Si vous êtes intéressé par une jolie solution rapide au format css, vous pouvez utiliser SweetAlert

$(function(){
  $(".delete").click(function(){
      swal({   
                  title: "Are you sure?",   
                  text: "You will not be able to recover this imaginary file!",   
                  type: "warning",   
                  showCancelButton: true,   
                  confirmButtonColor: "#DD6B55",   
                  confirmButtonText: "Yes, delete it!",   
                  closeOnConfirm: false 
          }, 
          function(isConfirmed){ 
        if(isConfirmed) {
          $(".file").addClass("isDeleted");
          swal("Deleted!", "Your imaginary file has been deleted.", "success"); 
        }
      }
    );
  });
});
html { zoom: 0.7 } /* little "hack" to make example visible in stackoverflow snippet preview */
body > p { font-size: 32px }

.delete { cursor: pointer; color: #00A }
.isDeleted { text-decoration:line-through }
<script src="https://code.jquery.com/jquery-2.1.3.min.js"></script>
<script src="http://t4t5.github.io/sweetalert/dist/sweetalert-dev.js"></script>
<link rel="stylesheet" href="http://t4t5.github.io/sweetalert/dist/sweetalert.css">

<p class="file">File 1 <span class="delete">(delete)</span></p>
3
Buksy

définir un message de conformation lorsque vous supprimez quelque chose dans php & mysql ...

utilisez ce code de script:

<script>
    function Conform_Delete()
    {
       return conform("Are You Sure Want to Delete?");
    }
</script>

utilisez ce code html:

<a onclick="return Conform_Delete()" href="#">delete</a>
2
ashik
function del_confirm(msg,url)
        {
            if(confirm(msg))
            {
                window.location.href=url
            }
            else
            {
                false;
            }

        }



<a  onclick="del_confirm('Are you Sure want to delete this record?','<filename>.php?action=delete&id=<?<id> >')"href="#"></a>
1
alpesh

Je sais que c'est vieux, mais j'avais besoin d'une réponse et non de celles-ci mais la réponse de alpesh fonctionnait pour moi et voulait partager avec des gens qui pourraient avoir le même problème.

<script>    
function confirmDelete(url) {
    if (confirm("Are you sure you want to delete this?")) {
        window.open(url);
    } else {
        false;
    }       
}
</script>

Version normale:

<input type="button" name="delete" value="Delete" onClick="confirmDelete('delete.php?id=123&title=Hello')">

Ma version PHP:

$deleteUrl = "delete.php?id=" .$id. "&title=" .$title;
echo "<input type=\"button\" name=\"delete\" value=\"Delete\" onClick=\"confirmDelete('" .$deleteUrl. "')\"/>";

Ce n'est peut-être pas la bonne façon de le faire publiquement, mais cela a fonctionné pour moi sur un site privé. :)

1
emotality
var txt;
var r = confirm("Press a button!");
if (r == true) {
   txt = "You pressed OK!";
} else {
   txt = "You pressed Cancel!";
}
var txt;
var r = confirm("Press a button!");
if (r == true) {
    txt = "You pressed OK!";
} else {
    txt = "You pressed Cancel!";
}
1

Utilisation de jQuery:

$(".delete-link").on("click", null, function(){
        return confirm("Are you sure?");
    });
1
Apeli

Voici un autre exemple simple de JS pur utilisant className et liant un événement à celui-ci.

var eraseable =  document.getElementsByClassName("eraseable");

for (var i = 0; i < eraseable.length; i++) {
    eraseable[i].addEventListener('click', delFunction, false); //bind delFunction on click to eraseables
}

function delFunction(){        
     var msg = confirm("Are you sure?");      
     if (msg == true) { 
        this.remove(); //remove the clicked element if confirmed
    }   
  };
<button class="eraseable">
<img class="eraseable" src="http://zelcs.com/wp-content/uploads/2013/02/stackoverflow-logo-dumpster.jpg" style="width:100px;height:auto;">
Delete me</button>

<button class="eraseable">
<img class="eraseable" src="http://zelcs.com/wp-content/uploads/2013/02/stackoverflow-logo-dumpster.jpg" style="width:100px;height:auto;">
Delete me</button>

<button class="eraseable">
<img class="eraseable" src="http://zelcs.com/wp-content/uploads/2013/02/stackoverflow-logo-dumpster.jpg" style="width:100px;height:auto;">
Delete me</button>
0
Arun Sharma
<a href="javascript:;" onClick="if(confirm('Are you sure you want to delete this product')){del_product(id);}else{ }" class="btn btn-xs btn-danger btn-delete" title="Del Product">Delete Product</a>


function del_product(id){
    $('.process').css('display','block');
    $('.process').html('<img src="./images/loading.gif">');
    $.ajax({
        'url':'./process.php?action=del_product&id='+id,
        'type':"post",
        success: function(result){
            info=JSON.parse(result);
            if(result.status==1){
            setTimeout(function(){
                    $('.process').hide();
                    $('.tr_'+id).hide();
                },3000);
                setTimeout(function(){
                    $('.process').html(result.notice);
                },1000);
            }else if(result.status==0){
                setTimeout(function(){
                    $('.process').hide();
                },3000);
                setTimeout(function(){
                    $('.process').html(result.notice);
                },1000);

                }
            }
        });
}
0
xahoigiaitri

Angularjs Avec Javascript Supprimer exemple

code HTML

<button ng-click="ConfirmDelete(single_play.play_id)" type="submit" name="actiondelete" value="1"><img src="images/remove.png" alt="Delete"></button>

"single_play.play_id" est une variable angularjs supposant que vous souhaitiez passer un paramètre au cours de l'action de suppression

Code Angularjs à l'intérieur du module d'application

$scope.ConfirmDelete = function(yy)
        {
            var x = confirm("Are you sure you want to delete?");
            if (x) {
             // Action for press ok
                $http({
                method : 'POST',
                url : 'sample.php',
                headers: {'Content-Type': 'application/x-www-form-urlencoded'},
                data: $.param({ delete_play_id : yy})
                }).then(function (response) { 
                $scope.message = response.data;
                });
            }
            else {
             //Action for cancel
                return false;
            }
        } 
0
Rijo

Pour "message de confirmation à la suppression", utilisez:

                       $.ajax({
                        type: "POST",
                        contentType: "application/json; charset=utf-8",
                        url: "Searching.aspx/Delete_Student_Data",
                        data: "{'StudentID': '" + studentID + "'}",
                        dataType: "json",
                        success: function (data) {
                            alert("Delete StudentID Successfully");
                            return true;
                        }
0
Arvind Upadhyay.

Il est beaucoup plus difficile de le faire pour les cases d'option sélectionnées. Voici la solution:

<select onchange="if (this.value == 'delete' && !confirm('THIS ACTION WILL DELETE IT!\n\nAre you sure?')){this.value=''}">
    <option value=''> &nbsp; </option>
    <option value="delete">Delete Everything</option>
</select>
0
Tarik
<script>
function deleteItem()
{
   var resp = confirm("Do you want to delete this item???");
   if (resp == true) {
      //do something
   } 
   else {
      //do something
   }
}
</script>

appeler cette fonction en utilisant onClick

0
Pranav V R

Le gestionnaire onclick doit renvoyer false après l'appel de la fonction. Pour par exemple.

onclick="ConfirmDelete(); return false;">

0
Amit
<SCRIPT LANGUAGE="javascript">
function Del()
{
var r=confirm("Are you sure?")
if(r==true){return href;}else{return false;}
}
</SCRIPT>

votre lien pour cela:

<a href='edit_post.php?id=$myrow[id]'> Delete</a>
0
Azat

Je pense que la solution la plus simple et discrète serait:

Lien:

<a href="http://link_to_go_to_on_success" class="delete">Delete</a>

Javascript:

$('.delete').click(function () {
    return confirm("Are you sure?");
});
0
Cookalino