- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试根据随机生成的 id 显示不同的弹出窗口。我使用的代码如下(这是使用 WordPress 中的工具集类型完成的):
<div class="id-select" id="[random_number]">
<div class="service-container">
<div class="service-image">
[types field="picture"][/types]
</div>
<div class="service-text">
<p><strong>Item:</strong> [wpv-post-title output="sanitize"]</p>
<p><strong>Suitable For:</strong> [wpv-post-taxonomy type="memorial-category" format="name"]</p>
<p><strong>Price:</strong> [types field="price"][/types]</p>
</div>
</div>
</div>
<!-- The Modal -->
<div id="myModal-custom" class="modal-custom">
<!-- Modal content -->
<div class="modal-content-custom">
<span class="close-custom">×</span>
<div class="container-fluid">
<div class="row">
<div class="col-md-6">
<div class="service-image">
[types field="picture"][/types]
</div>
</div>
<div class="col-md-6">
<div class="service-text">
<p><strong>Item:</strong> [wpv-post-title output="sanitize"]</p>
<p><strong>Suitable For:</strong> [wpv-post-taxonomy type="memorial-category" format="name"]</p>
<p><strong>Price:</strong> [types field="price"][/types]</p>
</div>
</div>
</div>
</div>
</div>
</div>
JavaScript 如下:
// Get the modal
var modal = document.getElementById('myModal-custom');
// Get the button that opens the modal
var ids = [];
$('.id-select').each(function(i, el) {
if (el.id == '') {
return;
}
ids.push('#' + el.id);
});
//console.log(ids.join(','));
$(ids.join(',')).on('click', function(e) {
modal.style.display = "block";
})
// Get the <span> element that closes the modal
var span = document.getElementsByClassName("close-custom")[0];
// When the user clicks on <span> (x), close the modal
span.onclick = function() {
modal.style.display = "none";
}
// When the user clicks anywhere outside of the modal, close it
window.onclick = function(event) {
if (event.target == modal) {
modal.style.display = "none";
}
}
我遇到的问题是,我在前端单击的任何项目都会显示相同的模式框。无论如何,我可以让它为特定项目选取正确的模式框吗?
实时网站 - http://79.170.40.172/tc-pinkfin.co.uk/memorials/cemetery/
最佳答案
当你无论如何都不在 getter 中参数化模态时,你会期望模态有何不同?
var modal = document.getElementById('myModal-custom');
你总是要求相同的模态,所以它总是相同的。
您的页面上有更多模态吗?
您是否以某种方式将不同的数据传递给该模式但它没有显示?
在您的页面上,我看到您显示带有图像和一些附加数据的框。猜猜你在一些数组中有这些图像+数据,例如:
const items = [
{ imgSrc: "...", additionalData:{...} },
{ imgSrc: "...", additionalData:{...} },
{ imgSrc: "...", additionalData:{...} },
];
通常您需要做的是将模态与每个item
(来自上面的数组)关联起来
执行此操作的最佳时机是当您创建页面上已有的框并想要单击以显示模式时(您在循环中执行此操作,对吗?)。
可能的解决方案:
点击处理程序
附加到它,指向特定的模式实例。 item
对象,并以某种方式将该 ID 添加到每个项目的正确模态 DOM 元素中。前任。 data-modaluid="$uniqueIDFromItem"
比点击每个项目时,使用该 ID 绑定(bind) click 方法(也可以设置为 data-itemuid=$uniqueIDFromItem 或仅绑定(bind)在点击处理程序中),并通过该 ID 搜索正确的模式 DOM 节点。 有几种方法可以做到这一点,具体取决于您构建页面的方式以及处理数据的方式。
<button>toggle modal 1</button>
<button>toggle modal 2</button>
<button>toggle modal 3</button>
<div class="modal">
modal 1
</div>
<div class="modal">
modal 2
</div>
<div class="modal">
modal 3
</div>
总体思路是通过唯一的 id (uid) 将每个可点击的项目与模型连接起来。
function guid() {
function s4() {
return Math.floor((1 + Math.random()) * 0x10000)
.toString(16)
.substring(1);
}
return s4() + s4() + '-' + s4() + '-' + s4() + '-' + s4() + '-' + s4() + s4() + s4();
}
document.addEventListener("DOMContentLoaded", () => {
const modals = document.querySelectorAll(".modal")
const buttons = document.querySelectorAll("button")
let guids = []
//create unique IDs for modals/buttons
buttons.forEach(button => {
guids.push(guid())
})
//set those IDs for buttons/modals with same order in array. Creating connections 1->1 2->2 3->3
guids.forEach((guid, index) => {
buttons[index].dataset.guid = guid
modals[index].dataset.guid = guid
})
//add onClick event listener for each button
buttons.forEach(button => {
button.addEventListener("click", (e) => {
//find proper div modal with same ID as clicked button
const divModal = document.querySelector(`div[data-guid="${e.target.dataset.guid}"]`)
//change its style when not visible assign "visible", otherwise assign "hidden"
divModal.style.visibility = divModal.style.visibility !== "visible" ? "visible" : "hidden";
})
})
})
代码笔:
https://codepen.io/anon/pen/GXzOJv?editors=1011
GUID 方法来自此处:Create GUID / UUID in JavaScript?
关于JavaScript - 显示弹出窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52424076/
我连续有 11 个图像,如果鼠标悬停在其中一个图像上,我希望弹出一个弹出窗口。所以每 11 个图像都有不同的弹出窗口。我已经有一些代码可以执行此操作,但它仅适用于第一张图像。 代码:index.htm
是否可以从 NSColorWell 制作一个 NSColorPanel“弹出”,几乎像一个弹出菜单? 我不喜欢它作为调色板的实现方式,因为有时它与哪个 NSColorWell 关联并不明显。 谢谢!
我正在考虑一个想法,基本上我想要一个带有 NSPopoverController 的 NSStatusItem 。我读到了人们遇到的所有问题,但我只是想尝试一下。现在有干净的方法吗?我见过的所有版本都
如何获取 JS 打开的弹出窗口的 url。这是我的代码: var _url = 'someurlhere'; var popupwindow = window.open(_url, "Popu
我正在设计一个网页,我希望当用户单击链接时,弹出窗口(新窗口)将打开一个链接网页。我的代码如下所示 function win(add,w,h) { window.open(add,"","widt
我正在寻找 C 中的简单堆栈实现,并找到了类似的东西: void pop(struct stack **top) { struct stack *temp; temp = malloc(s
我正在尝试使用 paypal 实现登录,我有 2 个不同的主机域 1- www.example.com 2- www.example.de 对于 paypal,我需要为此目的选择一个返回 URL,我选
我正在尝试找出如何复制此处显示的“弹出式” View 动画:https://imgur.com/a/irFqdiP .我正在使用当前代码来显示我的 viewController,但目前只有一个淡入淡出
有谁知道在 Windows 2000 或更高版本上以编程方式关闭 CD 托盘的方法?打开 CD 托盘存在,但我似乎无法关闭它,尤其是在 W2k 下。 如果可能的话,我特别想从批处理文件中寻找一种方法来
当您访问http://www.daniweb.com时你得到一个弹出窗口,这叫什么 + 知道怎么做吗? 感谢您的回复,只有模态加载动画的最简单方法是什么,即页面加载时动画显示以及动画何时完成? ASP
我正在为 Unity 引擎中的音频过滤器创建一个 C# 脚本。 我的问题是,在通过我的过滤器运行后,生成的音频具有一致且频繁的“咔哒声”、“砰砰声”或“跳过声”。听起来有点像旧 radio 。 我不确
我必须隐藏浏览器的地址栏。我正在使用这段代码: var winFeature = 'location=no,toolbar=no,menubar=no,scrollbars=yes,r
推荐一个button 弹起pickerview的源码,也可以作为工具类使用。 利用inputview 做键盘弹起动画。该如何做呢? 1.继承uiview 2.重写属性&方法
我在这里有一个问题,我已经工作了几个小时。 我正在导入一个 Excel 文件,并使用此代码来执行此操作: Dim objExcel As Excel.Application Di
我基本上是从 UITableViewController 推送 UIView,它包含的只是 UIWebView。但是,当我删除 UIView 以返回到 UITableView 时,应用程序崩溃了。 -
我有几个由导航 Controller 控制的 View Controller 。 例如,viewController A 和 viewController B 都可以将 viewController
我使用新的Gmail API为用户创建草稿。 API响应提供了新创建的消息ID。 然后,我可以使用URL https://mail.google.com/mail/#drafts?compose=[m
Redis列表实现了哪种内部数据结构以实现这一目的?链表将需要O(n)索引,而数组将需要O(n)左/右推/弹出。 最佳答案 根据official documentation,它们被实现为linked
我正在使用 WPF Popup 控件,它显示背景为黑色。我在其中放置了一个 StackPanel 并设置了 Background="Transparent",但这没有帮助。
我希望页面内的容器在事件时占据页面的整个宽度并覆盖在其他所有内容上。这是我目前所拥有的,但它没有按我想要的方式工作: $(function() { $('.main a').click( fu
我是一名优秀的程序员,十分优秀!