协慌网

登录 贡献 社区

如何使用 jQuery 打开 Bootstrap 模态窗口?

我正在使用 Twitter Bootstrap 模态窗口功能。当有人单击我的表单上的提交时,我想在单击表单中的 “提交按钮” 时显示模式窗口。

<form id="myform" class="form-wizard">
    <h2 class="form-wizard-heading">BootStap Wizard Form</h2>
    <input type="text" value=""/>
    <input type="submit"/>
</form>

<!-- Modal -->
<div id="myModal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
    <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
        <h3 id="myModalLabel">Modal header</h3>
    </div>
    <div class="modal-body">
        <p>One fine body…</p>
    </div>
    <div class="modal-footer">
        <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
        <button class="btn btn-primary">Save changes</button>
    </div>
</div>

jQuery 的:

$('#myform').on('submit', function(ev) {
    $('#my-modal').modal({
        show: 'false'
    }); 


    var data = $(this).serializeObject();
    json_data = JSON.stringify(data);
    $("#results").text(json_data); 
    $(".modal-body").text(json_data); 

    // $("#results").text(data);

    ev.preventDefault();
});

答案

Bootstrap 具有一些可以在模式上手动调用的功能:

$('#myModal').modal('toggle');
$('#myModal').modal('show');
$('#myModal').modal('hide');

您可以在此处看到更多信息: Bootstrap 模态组件

特别是方法部分

因此,您需要更改:

$('#my-modal').modal({
    show: 'false'
});

至:

$('#myModal').modal('show');

如果您要制作自己的自定义弹出窗口,请参考以下来自其他社区成员的视频:

https://www.youtube.com/watch?v=zK4nXa84Km4

另外,您可以通过数据使用属性

<button type="button" data-toggle="modal" data-target="#myModal">Launch modal</button>

在这种情况下,您无需编写 javascript。

您可以在此处查看更多信息: http : //getbootstrap.com/2.3.2/javascript.html#modals

最常见的是,当$('#myModal').modal('show');不起作用,这是由于两次包含 jQuery 引起的。包括 jQuery 2 次使模态不起作用。

删除链接之一以使其再次起作用。

此外,某些插件也会导致错误,在这种情况下,请添加

jQuery.noConflict(); 
$('#myModal').modal('show');