web-dev-qa-db-fra.com

UnCaught SweetAlert: 2e argument inattendu?

J'ai un problème avec sweetalert, je voudrais afficher l'alerte de la boîte de confirmation au clic sur le bouton mais cela ne fonctionne pas

Voici mon code JS:

$(document).ready(function(){
$('[data-confirm]').on('click', function(e){
    e.preventDefault(); //cancel default action

//Recuperate href value
var href = $(this).attr('href');


var message = $(this).data('confirm');

//pop up
swal({
    title: "Are you sure ??",
    text: message, 
    type: "warning",
    showCancelButton: true,
    cancelButtonText: "Cancel",
    confirmButtonText: "confirm",
    confirmButtonColor: "#DD6B55"},

function(isConfirm){
    if(isConfirm) {
    //if user clicks on "confirm",
    //redirect user on delete page

    window.location.href = href;
    }
});
});
});

HTML:

<a data-confirm='Are you sure you want to delete this post ?' 
href="deletePost.php?id=<?= $Post->id ?>"><i class="fa fa-trash">
</i> Delete</a>

Tous les fichiers requis sont importés.

Le code que vous utilisez est antérieur à la dernière version 2. Veuillez lire Mise à niveau à partir de 1.X.

Vous devez utiliser promesse pour garder une trace de l'interaction de l'utilisateur.

Code mis à jour

$(document).ready(function(){
    $('[data-confirm]').on('click', function(e){
        e.preventDefault(); //cancel default action

        //Recuperate href value
        var href = $(this).attr('href');
        var message = $(this).data('confirm');

        //pop up
        swal({
            title: "Are you sure ??",
            text: message, 
            icon: "warning",
            buttons: true,
            dangerMode: true,
        })
        .then((willDelete) => {
          if (willDelete) {
            swal("Poof! Your imaginary file has been deleted!", {
              icon: "success",
            });
            window.location.href = href;
          } else {
            swal("Your imaginary file is safe!");
          }
        });
    });
});

Notes

  • type ont été remplacés par l'option icône.
  • ShowCancelButton, CancelbuttonText, confirmButtonText et confirmButtonColor remplacés par des boutons uniquement.
  • dangerMode: true pour rendre le bouton de confirmation rouge.
12
5less