javascript - x 秒后淡出模态框

标签 javascript jquery

我正在使用remodal在我的网站上获取联系表格。

我希望表单成功发送后 1 或 2 秒后自动关闭模式框。

成功时用于关闭模式框的行是 inst.close();

我已经尝试过这个 inst.close().FadeOut(3000);但这没有用。

感谢您的帮助

我的联系表代码:

// Contact Form
$(document).ready(function() {
    $("#contactfrm").submit(function(e) {
        e.preventDefault();
        var inst = $.remodal.lookup[$('[data-remodal-id=modal]').data('remodal')]; // this was added by me
        var name = $("#name").val();
        var email = $("#email").val();
        var message = $("#message").val();
        var dataString = 'name=' + name + '&email=' + email + '&message=' + message;

        function isValidEmail(emailAddress) {
            var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
            return pattern.test(emailAddress);
        };
        if (isValidEmail(email) && (message.length > 1) && (name.length > 1)) {
            $.ajax({
                type: "POST",
                url: "sendmessage.php",
                data: dataString,
                success: function() {
                    $('button[name="submit"]').hide();
                    $('.error').hide()
                    $('.success').fadeIn(1000);
                    inst.close(); // this was added by me
                }
            });

        } else {
            $('.error').fadeIn(1000);
        }
        return false;
    });

});

最佳答案

我认为您需要使用回调函数:

$('.success').fadeIn(1000, function() {
    inst.fadeOut(1000, function() {
        this.close();
    });
 });

关于javascript - x 秒后淡出模态框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27347088/

相关文章:

javascript - 如何在连接 JavaScript 句子时添加空格

javascript - jQuery 数据表 - 如何设置列名称

javascript - 如何对表进行可选择的限制

javascript - 我想使用 javascript 或 jquery 更改内容

javascript - 当用户更改位置或坐标更改时更新 map 上标记的位置

javascript - 使用 add/removeClass 更改过渡持续时间

javascript - div/段落标签中的最大字符数

javascript - 为什么 Bootstrap 模式在关闭模式并锚定到页面后删除我的滚动条

javascript - 无需 document.write 即可动态生成列表?

javascript - Three.js 中的对象遍历是什么意思?