- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我实现了一个弹出窗口,当用户点击按钮时显示产品的详细信息,因此弹出窗口应该针对不同的产品显示不同的详细信息。
但是无论点击哪个按钮,弹出窗口总是显示最后一个产品的详细信息。为什么会这样?
CSS:
.cards {
overflow: auto;
white-space: nowrap;
margin-top: 10px;
}
.options a {
margin-left: 10px;
text-decoration: none;
}
.card {
display: inline-block;
margin: 5px;
height: 200px;
}
.bgimg {
height: 410px;
}
.scm a {
text-decoration: none;
}
.fb:hover {
color: #4267B2
}
.insta:hover {
color: #FD1D1D;
}
.gm:hover {
color: #B23121;
}
.centring {
margin: auto;
display: flex;
justify-content: center;
align-items: center;
}
.popup-hide {
position: fixed;
padding: 5px;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
transition: 100ms ease-in-out;
border: 1px solid black;
border-radius: 10px;
z-index: 10;
background-color: white;
width: 800px;
max-width: 80%;
display: none;
}
.popup-show {
position: fixed;
padding: 5px;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
transition: 100ms ease-in-out;
border: 1px solid black;
border-radius: 10px;
z-index: 10;
background-color: white;
width: 800px;
max-width: 80%;
display: block;
}
JS:
function showpopup(params) {
var card = document.getElementsByClassName('card');
var popup;
for (let j = 0; j < card.length; j++) {
popup = document.getElementsByClassName('popup')[j];
popup.style.display = 'block';
}
}
function hidepopup(params) {
var card = document.getElementsByClassName('card');
var popup;
for (let i = 0; i < card.length; i++) {
popup = document.getElementsByClassName('popup')[i];
popup.style.display = 'none';
}
}
HTML:
<div class="container-full" id="container">
<div class="product-cards">
<div class="card" style="width:250px;height: 200px;">
<img class="card-img-top" src="1.jpg" alt="Card image">
<div class="card-body">
<button class="btn btn-primary" id="showpopup" onclick="showpopup()">Open</button>
</div>
</div>
<div class="card" style="width:250px;height: 200px;">
<img class="card-img-top" src="2.jpg" alt="Card image">
<div class="card-body">
<button class="btn btn-primary" id="showpopup" onclick="showpopup()">Open</button>
</div>
</div>
</div>
<div class="product-popups">
<div class="popup-hide popup" id="popup">
<button class="btn btn-primary" id="hidepopup" onclick="hidepopup()">×</button>
<hr>
<div class="row">
<div class="col-sm-4">
<img style="width: 200px;max-width: 90%;" src="1.jpg" alt="">
</div>
<div class="col-sm-8">
price:200DA <br>
<br><br>
</div>
</div>
</div>
<div class="popup-hide popup" id="popup">
<button class="btn btn-primary" id="hidepopup" onclick="hidepopup()">×</button>
<hr>
<div class="row">
<div class="col-sm-4">
<img style="width: 200px;max-width: 90%;" src="2.jpg" alt="">
</div>
<div class="col-sm-8">
price:300DA <br>
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Deleniti, molestiae totam aliquam
quas optio praesentium! Soluta id ea est maxime laudantium, iure voluptatibus voluptatum et nemo
modi reprehenderit bea
tae. Dolorum?
<br><br>
</div>
</div>
</div>
</div>
</div>
</div>
有什么解决问题的建议吗?
最佳答案
你的代码有一些错误:
首先:您将“params”定义为函数的参数,但您没有使用它。
其次:您的 html 代码中有一些标签具有相同的 id,我们对多个标签使用相同的 id 不是有效的“html”
第三:只显示最后一个弹出窗口的原因是您在函数中使用了“for-loop”,这意味着通过单击每个“按钮”,代码循环抛出该类的所有标签,最后显示最后一个。你不需要“for-loop”。您可以使用函数的“params”参数并为弹出窗口提供 id,就像我将发布的代码一样:
function showpopup(params) {
var card= document.getElementsByClassName('card');
var popup;
// for (let j = 0; j < card.length; j++) {
popup=document.getElementById(params);
popup.style.display='block';
// }
}
function hidepopup(params) {
var card= document.getElementsByClassName('card');
var popup;
popup=document.getElementById(params);
popup.style.display= 'none';
}
.cards {overflow: auto;white-space: nowrap;margin-top: 10px;}
.options a {margin-left: 10px;text-decoration: none;}
.card {display: inline-block;margin: 5px; height: 200px ;}
.bgimg {height:410px;}
.scm a {text-decoration: none;}
.fb:hover {color:#4267B2}
.insta:hover {color: #FD1D1D;}
.gm:hover {color: #B23121;}
.centring {margin: auto; display: flex;justify-content: center; align-items: center;}
.popup-hide { position: fixed;
padding: 5px;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) ;
transition: 100ms ease-in-out;
border: 1px solid black;
border-radius: 10px;
z-index: 10;
background-color: white;
width: 800px;
max-width: 80%;
display: none;}
.popup-show { position: fixed;
padding: 5px;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) ;
transition: 100ms ease-in-out;
border: 1px solid black;
border-radius: 10px;
z-index: 10;
background-color:white;
width: 800px;
max-width: 80%;
display: block;}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>pop-up</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="container-full" id="container">
<div class="product-cards">
<div class="card" style="width:250px;height: 200px;">
<img class="card-img-top" src="1.jpg" alt="Card image">
<div class="card-body">
<button class="btn btn-primary" id="showpopup" onclick="showpopup('pop1')">Open</button>
</div>
</div>
<div class="card" style="width:250px;height: 200px;">
<img class="card-img-top" src="2.jpg" alt="Card image">
<div class="card-body">
<button class="btn btn-primary" id="showpopup" onclick="showpopup('pop2')">Open</button>
</div>
</div>
</div>
<div class="product-popups">
<div class="popup-hide" id="pop1">
<button class="btn btn-primary" id="hidepopup" onclick="hidepopup('pop1')">×</button>
<hr>
<div class="row">
<div class="col-sm-4">
<img style="width: 200px;max-width: 90%;" src="1.jpg" alt="">
</div>
<div class="col-sm-8">
price:200DA <br>
<br><br>
</div>
</div>
</div>
<div class="popup-hide" id="pop2">
<button class="btn btn-primary" id="hidepopup" onclick="hidepopup('pop2')">×</button>
<hr>
<div class="row">
<div class="col-sm-4">
<img style="width: 200px;max-width: 90%;" src="2.jpg" alt="">
</div>
<div class="col-sm-8">
price:300DA <br>
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Deleniti, molestiae totam aliquam
quas optio praesentium! Soluta id ea est maxime laudantium, iure voluptatibus voluptatum et nemo modi reprehenderit bea
tae. Dolorum?
<br><br>
</div>
</div>
</div>
</div>
</div>
<script src="javascript.js"></script>
</body>
</html>
关于javascript - 弹出窗口始终显示相同的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65026668/
当我使用路径文件上的快捷方式在文件之间移动时,似乎我不仅仅是在文件之间移动。 我使用>转到一个文件,在该文件中我更改光标的位置并执行某些操作,然后按 gf noremap 关于vim 通过快捷方式直
我正在尝试使用 Pong P. Chu 的书来学习 Verilog。我有一个关于如何评估和实现始终 block 的问题。作者代码中的风格让我感到困惑。 在此示例中,他编写了一个具有两个输出寄存器“y1
我正在尝试制作一个聊天应用程序,因此我需要它始终接收服务器信息。因此,当请求完成时,在: http.onreadystatechange=function(){ 我再次调用该函数,因此: reques
当您在 always block 敏感度列表中使用通配符 @* 时,我对什么被视为输入有点困惑。例如,在下面的示例中,哪些信号被解释为导致 always block 被重新评估的输入? 据我了解,cl
我有一个充当调试器的程序。我为线程设置了一个 hw bp,将 dr0 设置为我希望 bp 所在的地址,将 dr7 设置为 1,因为我希望 bp 在每次执行该地址时生成一个事件。 它有效,但现在的问题是
如何每次都以管理员身份在 Windows 上运行 git bash。 操作系统 - Windows 10 家庭版 64 位 最佳答案 我在 Google 上找到了这个结果: 将 Git Bash 设置
使用 accept() 时或 getpeername() , sockaddr_storage总是有 ss_family=AF_INET6 : struct sockaddr_storage addr
我在 Cordova 方面还有另一个问题。我想在 Cordova 7.1.0 中使用插件“cordova.custom.plugins.exitapp”和“cordova-plugins-printe
我试图让模块通过 ISE 12.4 中的语法检查,但它给了我一个我不明白的错误。首先是代码片段: parameter ROWBITS = 4; reg [ROWBITS-1:0] temp; genv
我正在使用Cordova开发适用于iOS的应用程序,其中包括地理位置功能(我使用官方插件https://github.com/apache/cordova-plugin-geolocation)。我在
我想知道是否有可能只在敏感列表中的多个信号一起变化时才执行 always block 。 例如,假设我有一个信号“in”和另一个“posedge clk”。我希望在两个信号都发生变化时执行 alway
我需要实现一种算法来访问数据库来检查最后一个元素,以便计算新的元素。当然,第一次这是不可能的,因为数据库是空的,我得到 IndexOutOfBoundsException) index 0 reque
我正在利用我在网上找到的画廊系统,根据鼠标图像的接近程度,它会按比例增长。 链接:Gallery 好吧,我调整了代码以响应(如您所见正在 build 中)并且没有明显的问题。我的问题在更改分辨率时开始
我正在创建一个 kiosk 应用程序,我想确保它无论如何始终位于其他 Windows 应用程序和 Windows 任务栏之上。 我已经阻止了 Windows 键盘命令(alt-tab 等),但仍有可能
我即将开始一个新的 React 项目,并尝试利用我以前的知识来创建一些关于我如何构建应用程序的规则。 有些事情我认为是真的: Redux 保存整个应用程序的“主要”数据 如果需要跨应用程序共享,Red
当你打开 VS Code 时,终端默认是在底部打开的。您可以单击该图标将其向右移动。我想知道是否有办法将右侧打开设置为默认值。 谢谢。 最佳答案 是的 - 在 v1.20 中引入了设置 workb
我有一个Events表,其中包含各种类型的事件。我只关心其中一种类型。因此,我编写的每个查询都以开头 Events.objects.filter(event_type="the_type").\
我在单例中创建了一个Timer,并且我一直在努力解决为什么Timer没有触发。我查看了这里的帖子,但没有找到我认为可以直接回答我的问题的帖子。 class ConnectionStateMonitor
我在 TableViewController 中显示了一组项目。它们在 TVC 中正确显示。下面的代码会继续,但它只会继续到我的 MKMapItem 数组的 indexPath 0,而不是被单击的单元
我的 VC 是这样的: var coins = 50 // coins override func viewDidLoad() { super.viewDidLoad() if(SKP
我是一名优秀的程序员,十分优秀!