javascript - 通过点击标签调用 jQuery 模型

标签 javascript jquery

我正在尝试实现一项功能,当用户点击标签时会弹出模态窗口。

问题

  • 我无法使用 Label 元素打开,但如果我使用按钮(具有相同的代码),它就可以打开。
  • 如果我删除 hello 上的注释,我可以看到警报(因此代码在 jquery 语句中输入

这是我的代码(只是来自引导站点的代码)

HTML

<label id="some-label">Something</label>

<!-- Modal -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="myModalLabel">Modal title</h4>
      </div>
      <div class="modal-body">
        ...
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
      </div>
    </div>
  </div>
</div>

JS

$('#some-label').on('click', function() {
     //alert("hello"); 
     $('#myModal').show();        
 });

最佳答案

您的代码不起作用,因为您绕过了用于显示模态的标准 Bootstrap 逻辑。您正在调用 show(),但由于 fade 类,该元素仍设置为 opacity: 0,因此不显示任何内容。

要解决此问题,请在触发元素上使用适当的 data 属性(data-targetdata-toggle)。然后你不需要包含任何明确的 JS,因为 Bootstrap 会为你完成繁重的工作:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" />

<label id="some-label" data-toggle="modal" data-target="#myModal">Something</label>

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="myModalLabel">Modal title</h4>
      </div>
      <div class="modal-body">
        ...
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
      </div>
    </div>
  </div>
</div>

关于javascript - 通过点击标签调用 jQuery 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47352043/

相关文章:

jquery - HTML 设置激活并具有不同的背景颜色

javascript - 在 JavaScript 中的 html 元素上切换事件监听器

javascript - 使用 javascript(或 jQuery)选择和操作 CSS 伪元素,例如::before 和::after

javascript - 使用kafka消费者进行数据库操作或http调用

javascript - JavaScript 会干扰其他内容的加载吗?

jquery - History.pushState 在浏览器后退按钮上中断

javascript - jQuery-UI 可拖动和可放置的项目变为不可拖动

javascript - 对象的 ACE 编辑器自动完成

javascript - 总是成功的 jQuery promise ?

javascript - 如何仅禁用上个月的日期