按钮调用模式对话框:单击按钮时,将触发事件,结果事件引用e.relatedTarget未定义。那么,如何从处理程序中获取调用按钮? e似乎没有包含对调用按钮的任何引用。
<!-- Button trigger modal -->
<button class="btn btn-primary btn-lg" data-toggle="modal" data-target="#myModal">
Launch demo modal
</button>
<!-- Modal -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</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>
jQuery的:
$('#myModal').on('show.bs.modal', function (e) {
console.log(e.relatedTarget) // do something...
})
答案 0 :(得分:19)
请查看以下Bootply example。
运行时,show事件似乎包含对e.relatedTarget
的正确引用。
$('#myModal').on('show.bs.modal', function (e) {
var button = e.relatedTarget;
if (button != null)
{
alert("Launch Button ID='" + button.id + "'");
}
})
查看Bootply example以查看您自己的代码是否与其不同。 (我直接从您提供的link复制了原始的Bootstrap示例代码段。)
我希望这会有所帮助。祝你好运。
答案 1 :(得分:12)
谢谢Geo1004 ..我已经使用JS来触发&#34; show&#34;关于模态的事件,但我错过了第二个参数。所以event.relatedTarget未定义。
如果其他人正在使用JS路由(而不是使用数据属性),我会确保您将按钮作为jQuery对象发送 -
$( "#myModal" ).modal( "show", $( "#buttonBeingClicked" ) );
答案 2 :(得分:9)
这是一种解决方法。您可以使用JS打开模态,并设置relatedTarget。 你不应该错过传递按钮作为'模态'方法的第二个参数。
您将能够传递数据引用(此处为address-target)
$('.listing_btn').on 'click', ->
$('.modal').modal('show', $(@))
$('#modal').on 'show.bs.modal', (event)->
button = $(event.relatedTarget)
address_id = button.data('address-target')
console.log address_id
答案 3 :(得分:4)
我遇到了同样的问题,整个晚上都浪费了时间来修复它。 我的bootstrap.js版本只是旧的而且$(event.relatedTarget)不适用于&#39; show.bs.modal&#39;事件。 任何有相同问题的人都应该先检查他的bootstrap版本。 然后简单地坚持官方网站示例: http://getbootstrap.com/javascript/#modals-related-target 您将在$(event.relatedTarget)中找到您的引用。
答案 4 :(得分:2)
$('#myModal').on('show.bs.modal', function (e) {
console.log($(e.relatedTarget)); // You will get the element you want! Cheers
})