将数据属性传递给模式引导程序
Posted
技术标签:
【中文标题】将数据属性传递给模式引导程序【英文标题】:Pass data attribute to modal bootstrap 【发布时间】:2018-01-25 15:30:27 【问题描述】:<a class="my_link" data-val="user1" href="#">modal link</a>
我有这个链接来打开一个引导模式,但我需要传递数据属性“data-val”。我尝试使用javascript,但没有得到它。你能帮帮我吗?
【问题讨论】:
Passing data to a bootstrap modal的可能重复 对我不起作用 您需要将链接的href
或data-toggle
属性设置为模态的id
,并在其前面带有#
符号。无论如何,一个可行的例子就是答案。
【参考方案1】:
您可以在 modal 上侦听 show.bs.modal
事件,并将单击的元素作为事件的 relatedTarget
属性获取。检查 Bootstrap modal documentation 以供进一步参考。
这是一个使用 Bootstrap v4 的工作示例。
$('#my-modal').on('show.bs.modal', function (event)
var myVal = $(event.relatedTarget).data('val');
$(this).find(".modal-body").text(myVal);
);
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.2.1/css/bootstrap.min.css" integrity="sha384-GJzZqFGwb1QTTN6wy59ffF1BuGJpLSa9DkKMp0DgiMDm4iYMj70gZWKYbI706tWS" crossorigin="anonymous">
<a href="#" class="my_link" data-val="user1" data-toggle="modal" data-target="#my-modal">Open Modal</a>
<div class="modal fade" id="my-modal" tabindex="-1" role="dialog" aria-labelledby="my-modal" aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">My Modal</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
</div>
</div>
</div>
</div>
<!-- jQuery, Popper and Bootstrap JS -->
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.6/umd/popper.min.js" integrity="sha384-wHAiFfRlMFy6i5SRaxvfOCifBUQy1xHdJ/yoi7FRNXMRBu5WHdZYu1hA6ZOblgut" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.2.1/js/bootstrap.min.js" integrity="sha384-B0UglyR+jN6CkvvICOB2joaf5I4l3gm9GU6Hc1og6Ls7i6U/mkkaduKaBhlAXv9k" crossorigin="anonymous"></script>
【讨论】:
【参考方案2】:你可以只设置模态
<div class="modal fade" id="setTypeModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
然后用
调用它 $('#setTypeModal').modal('show');
然后您可以使用 Jquery 等访问模式中的元素。
最后用点击事件做更多的工作并用
关闭模式 $('#setTypeModal').modal('hide');
【讨论】:
以上是关于将数据属性传递给模式引导程序的主要内容,如果未能解决你的问题,请参考以下文章