javascript – Bootstrap模态数据解除不起作用

因此,data-dismiss =“modal”不适用于我的 HTML添加的按钮,但适用于通过JS插入按钮HTML添加到模态的按钮.这让我觉得我添加脚本标签的位置/顺序有问题.

我的脚本标签按此顺序排列:

<script src="/Scripts/jquery-2.1.1.js"></script>
<script src="/Scripts/bootstrap.js"></script>
<script src="/Scripts/respond.js"></script>
<script src="/Scripts/Shared/site.js"></script>

我尝试将它们放在< head>中.我把它们移到了< / body>之前的最后一件事.我把它们移到模态html之前和之后.

UPDATE

这是我的代码的简化版本:

<!DOCTYPE html>
<html>
<head>
    <Meta charset="utf-8" />
    <Meta name="viewport" content="width=device-width,initial-scale=1.0">
    <title>Title</title>
    <link href="/Content/bootstrap.css" rel="stylesheet"/>
    <link href="/Content/font-awesome.css" rel="stylesheet"/>
    <link href="/Content/site-bootstrap.css" rel="stylesheet"/>
    <link href="/Content/site.css" rel="stylesheet"/>

    <script src="/Scripts/modernizr-2.8.3.js"></script>
</head>
<body>
    <div id="Popup" class="modal fade">
        <div class="modal-dialog">
            <div class="modal-content">
                <div id="PopupHeader">
                    <button type="button" id="PopupX" class="close" data-dismiss="modal"><span aria-hidden="true">&times;</span><span class="sr-only">Close</span></button>
                    <h4 id="PopupTitle" class="modal-title floatLeft"></h4>
                    <div class="clear"></div>
                </div>
                <div class="modal-body bgColorWhite">
                    <div id="PopupContent">Test</div>
                </div>
                <div id="PopupButtons" class="modal-footer bgColorWhite">
                    <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
                </div>
            </div>
        </div>
    </div>

    <script src="/Scripts/jquery-2.1.1.js"></script>
    <script src="/Scripts/bootstrap.js"></script>
    <script src="/Scripts/respond.js"></script>
    <script src="/Scripts/Shared/site.js"></script>
</body>
</html>

一个说明:

如果我通过JS添加关闭”按钮,也就是X,它也可以.它已经在模式中导致了问题.

有什么建议?

解决方法

我弄清楚了我的问题.就是在我自己的JS文件中,我想添加到每个按钮点击事件,event.stopPropagation();由于这是一个方法,并且我不希望每次调用它时多次添加到同一个按钮,我会删除之前的单击事件,这将删除Bootstrap的dismiss click事件.

所以,如果你有同样的问题并且你已经正确添加了Bootstrap的所有JS,请检查你自己的代码以确保你没有覆盖/删除事件.

UPDATE

只是为了澄清,event.stopPropagation()可以防止数据解除工作.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...