将JavaScript对象数据传递给Bootstrap模式

时间:2018-04-28 04:01:45

标签: javascript jquery html loops modal-dialog

我已遍历每个对象并将每个对象的数据传递给它自己的div以及每个div中的一个按钮,该按钮在单击时打开一个模态窗口并仅显示该特定对象的数据。

然而,我的问题是,当我测试每个按钮以查看它是否显示数据时,我会看到最后一个对象的数据显示在所有对象的模态窗口中。有任何想法吗?

<!DOCTYPE html>

<html lang="en-US">

<head>


<title>Help</title>
<link rel="stylesheet" 
href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" 
integrity="sha384- 
Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" 
crossorigin="anonymous">



<script src="https://code.jquery.com/jquery-3.3.1.js" integrity="sha256-    
2Kok7MbOyxpgUVvAk/HJ2jigOSYS2auK4Pfzbm7uH60=" crossorigin="anonymous"> 
</script>
<script 


<script 
src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js" 
integrity="sha384- 
JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl" 
crossorigin="anonymous"></script>

<style>

.box{
    width:400px;
    height:800px;
    background-color:grey;
}
.box2{
    width:400px;
    height:100px;
    background-color:white;
}


</style>
</head>

<body>
<div id="box" class="box"></div>


<script>


var radio = [
    {
        name:"106 power",
        address:"1620 sw 11th st",
        phone:"305-892-9927"
    },
    {
        name:"99 jamz",
        address:"1900 sw 19th st",
        phone:"305-892-9900"
    }



]

for (i = 0; i < radio.length; i++){
    var qb = radio[i].name;
    document.getElementById('box').innerHTML += "<div class='box2'>" + radio[i].name + "<br>" + radio[i].address + "<br> <button type='button' id='button' data-toggle='modal' data-target='#myModal'>" + "Click me!" + "</button></div>";

    $(document).ready(function(){
    $("#button").click(function(){
    $("#main-content").html(qb);
});
});



};


</script>




<!-- Modal -->
<div id="myModal" class="modal fade" role="dialog">
<div class="modal-dialog">

<!-- Modal content-->
<div class="modal-content">
<div class="modal-header">
    <button type="button" class="close" data-dismiss="modal">&times;            
</button>
    <h4 class="modal-title">Modal Header</h4>
  </div>
  <div class="modal-body " id="main-content">
    <p>Some text in the modal.</p>
  </div>
  <div class="modal-footer">
    <button type="button" class="btn btn-default" data- dismiss="modal">Close
</button>
  </div>
</div>

</div>
</div>
</body>







</html>

1 个答案:

答案 0 :(得分:1)

  

ID和类之间的区别在于可以使用ID   识别一个元素,而一个类可用于识别更多元素   而不是一个。

所以你应该用class

更改id

这是你的代码:

<button type='button' id='button' data-toggle='modal' data-target='#myModal'>" + "Click me!" + "</button>

以下是修改后的代码:

<button type='button' class='button' data-toggle='modal' data-target='#myModal'>" + "Click me!" + "</button>

你也有循环,试图在 #button 点击附加事件,在#button上附加几个事件,当你点击按钮时它会激活很多时间,所以如果你想避免这么多时间火,你应该从循环外面附加事件。

for (i = 0; i < radio.length; i++){
    var qb = radio[i].name;
    document.getElementById('box').innerHTML += "<div class='box2'>" + radio[i].name + "<br>" + radio[i].address + "<br> <button type='button' id='button' data-toggle='modal' data-target='#myModal'>" + "Click me!" + "</button></div>";
}

$(document).ready(function(){
   $("#button").click(function(){
       $("#main-content").html(qb);
   });
});

此外,如果您想在单击按钮时在内容中显示radio.name,您应该使用data-属性,这是我的建议。用这个改变你的代码:

for (i = 0; i < radio.length; i++){
    var qb = radio[i].name;
    document.getElementById('box').innerHTML += "<div class='box2'>" + radio[i].name + "<br>" + radio[i].address + "<br> <button type='button' class='button' data-toggle='modal' data-target='#myModal' data-radio-name='" + qb + "'>" + "Click me!" + "</button></div>";
}

$(document).ready(function(){
   $(".button").click(function(){
       $("#main-content").html($(this).data('radio-name'));
   });
});
  

存储与匹配元素关联的任意数据或返回   指定数据存储区中第一个元素的值   匹配的元素。

https://api.jquery.com/data/