通过单击标签来调用jQuery

时间:2017-11-17 13:44:05

标签: javascript jquery

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

问题

  • 我无法使用Label元素打开,但如果我使用一个按钮(使用相同的代码),它就能正常工作。
  • 如果我删除你好的评论,我可以看到警报(所以代码在jquery语句中输入

这是我的代码(只是来自bootstrap网站的代码)

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();        
 });

1 个答案:

答案 0 :(得分:4)

您的代码无法正常工作,因为您绕过标准引导程序逻辑来显示模态。您正在调用show(),但由于opacity: 0类,该元素仍设置为fade,因此不会显示任何内容。

要解决此问题,请在触发元素(datadata-target)上使用相应的data-toggle属性。然后你不需要包含任何明确的JS,因为Bootstrap将为你做繁重的工作:

&#13;
&#13;
<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>
&#13;
&#13;
&#13;