未捕获的SweetAlert:意外的第二个论点?

时间:2017-10-11 14:22:28

标签: javascript sweetalert

我遇到了sweetalert的问题,我想在按钮点击时显示确认框警告但是它无法正常工作

这是我的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>

导入所有必需的文件。

1 个答案:

答案 0 :(得分:10)

您使用的代码来自最新版本2.之前请阅读Upgrading from 1.X.

您应该使用promise来跟踪用户互动。

更新了代码

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

备注

  • 类型已替换为图标选项。
  • 仅使用按钮替换了showCancelButton,CancelbuttonText,confirmButtonText和confirmButtonColor。
  • dangerMode:如果确认按钮为红色,则为true。