Bootstrap模态立即关闭,应该延迟

woo*_*gie 4 javascript jquery twitter-bootstrap

在此示例中,单击contact导航菜单上的选项卡将打开引导模式.如果用户在小于10的模态文本框中输入一个字符串,则会出现警告并且模态不会关闭.如果字符串大于10,则会在模式中附加一条消息,说明类似的情况success...,并且模态应该延迟一个咒语然后消失.使用当前代码验证部分和模态显示工作,但在它消失之前没有延迟.为什么当前代码不起作用,我该如何解决?

小提琴 JS

$(document).ready(function () {

            $('#modalClose').click(function () {
                var validResult = getLength('#tbName', 10);
                if (validResult) {
                    var successMessage = $('<div>').text('Successfully saved to database...').css('color', 'green');
                    $('.modal-body').append(successMessage);
                    $('#contact').delay(5000).modal('hide');
                }
                else {
                    alert('input did not meet validation, try again');
                    $('#tbName').val('').focus();
                }
            });
            function getLength(el, x) {
                var len = $(el).val().length
                return len > x
            }
            $('#contact').on('hide.bs.modal', function () {
                $('#tbName').val('');
            });
            $('#contact').on('shown.bs.modal', function () {
                $('#tbName').focus();
            });
        });
Run Code Online (Sandbox Code Playgroud)

PSL*_*PSL 10

您应该使用setTimeout而不是delay,延迟适用于动画队列.

  window.setTimeout(function(){
     $('#contact').modal('hide');
  }, 2000); //2000 milliseconds i.e 2 seconds, you can change it to the value as you need
Run Code Online (Sandbox Code Playgroud)

演示