- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 <ul>
中有两个列表每个都包含一个主图像以及一个容器,该容器包含其他较小的预览图像,单击后这些图像将取代主图像。除了一件事,它几乎完美地工作:
因为我有两个主要列表 <li>
在 <UL>
内, 一个列表中的图像替换了第二个列表中的图像 <li>
.
为什么会这样?
function exp(el){
el.classList.toggle('on');
}
var mainImage = $(".mainimg");
$(".preview img").click(function(){
var src = $(this).attr("src");
$(".mainimg").attr("src",src);
});
/*Main list*/
#list ul{width:100%; height:100%; border-radius:0px; list-style-type:none; margin:5% 0% 0% 0%; overflow:hidden; padding:0% 0% 4% 0%; }
#list li{border-radius:10px; border:1px solid black; color:black; background:white; width:100%; height:auto; display:block; text-decoration:none; font-weight:bold; font-size:0.9vw; margin:0% 0% 5% 0%; overflow:hidden; word-wrap:break-all; word-break:break-word; padding:0% 0% 0% 0%; float:left; text-align:center; line-height:1.2; }
/* main image */
#list .mainimg{width:20vw; height:auto; border:2px solid black; float:left; margin:1% 0% 0% 1%; overflow:hidden; border-radius:10px; background:rgba(0,0,0,0.1); padding:0%; transition:0.2s ease-in-out;}
#list .open.on ~ .mainimg{width:70vw; height:auto; float:left; margin:1% 0% 0% 0%; overflow:hidden; border-radius:0px; background:rgba(30,30,30,1); padding:2% 15% 2% 15%;; transition:0.3s ease-in-out;}
/*images expanded */
#list .imgxp{
width:100%; height:0px; background:rgba(0,0,0,1); margin:0% 0% 0% 0%; float:left; overflow:auto; }
#list .xp.on ~ .imgxp{
width:100%; height:auto; margin:0% 0% 0% 0%; float:left; padding:0% 0% 3% 0%;}
/*image expander button*/
#list button{background:rgba(0,0,0,1); color:white; width:20%; height:auto; padding:0.5% 1% 0.5% 1%; margin:0% 60% 0% 1.2%; float:left; border-radius:10px; overflow:hidden; }
/*Preview gallery*/
#list .preview{width:7vw; height:5.5vw; float:left; margin:3% 3.5% 4% 3.2%; }
#list .preview img{width:10vw; height:8.5vw; float:left; opacity:0.7; transition:0.2s; border-radius:10px; border:1px solid rgba(0,0,0,0.5);}
#list video{width:60vw; height:40vw; float:left; border-radius:10px; position:relative; top:5vw; left:20vw; background:rgba(0,0,0,0.5); margin:5% 20% 5% 0%;}
#list .preview img:hover{opacity:1; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id = "list">
<li>
<img class='mainimg' src="https://cdn.pixabay.com/photo/2018/08/06/16/30/mushroom-3587888_960_720.jpg" /> <button class="xp" onclick="exp(this)">See more</button>
<div class="imgxp">
<div class="preview"><img src="https://cdn.pixabay.com/photo/2018/08/06/16/30/mushroom-3587888_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/04/03/12/05/tree-99852_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/11/28/10/36/road-220058_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/03/26/09/47/sky-690293_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2012/03/01/00/21/bridge-19513_960_720.jpg"/></div>
</div>
</li>
<li>
<img class='mainimg' src="https://cdn.pixabay.com/photo/2013/11/28/10/03/autumn-219972_960_720.jpg" /> <button class="xp" onclick="exp(this)"> See more</button>
<div class="imgxp">
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/11/28/10/03/autumn-219972_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/12/01/20/28/road-1072823_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/12/01/20/28/green-1072828_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/02/24/15/41/dog-647528_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2016/01/19/17/39/starry-night-1149815_960_720.jpg"/></div>
</div>
</li>
</div>
最佳答案
因为有两个列表具有相同的类,即。 mainimg,你必须指定目标div的src。使用 jquery,您可以遍历 onclick 事件的 div
$(this).parent().parent().parent().children(':first-child').attr("src",src);
function exp(el){
el.classList.toggle('on');
}
var mainImage = $(".mainimg");
$(".preview img").click(function(){
var src = $(this).attr("src");
$(this).parent().parent().parent().children(':first-child').attr("src",src);
});
/*Main list*/
#list ul{width:100%; height:100%; border-radius:0px; list-style-type:none; margin:5% 0% 0% 0%; overflow:hidden; padding:0% 0% 4% 0%; }
#list li{border-radius:10px; border:1px solid black; color:black; background:white; width:100%; height:auto; display:block; text-decoration:none; font-weight:bold; font-size:0.9vw; margin:0% 0% 5% 0%; overflow:hidden; word-wrap:break-all; word-break:break-word; padding:0% 0% 0% 0%; float:left; text-align:center; line-height:1.2; }
/* main image */
#list .mainimg{width:20vw; height:auto; border:2px solid black; float:left; margin:1% 0% 0% 1%; overflow:hidden; border-radius:10px; background:rgba(0,0,0,0.1); padding:0%; transition:0.2s ease-in-out;}
#list .open.on ~ .mainimg{width:70vw; height:auto; float:left; margin:1% 0% 0% 0%; overflow:hidden; border-radius:0px; background:rgba(30,30,30,1); padding:2% 15% 2% 15%;; transition:0.3s ease-in-out;}
/*images expanded */
#list .imgxp{
width:100%; height:0px; background:rgba(0,0,0,1); margin:0% 0% 0% 0%; float:left; overflow:auto; }
#list .xp.on ~ .imgxp{
width:100%; height:auto; margin:0% 0% 0% 0%; float:left; padding:0% 0% 3% 0%;}
/*image expander button*/
#list button{background:rgba(0,0,0,1); color:white; width:20%; height:auto; padding:0.5% 1% 0.5% 1%; margin:0% 60% 0% 1.2%; float:left; border-radius:10px; overflow:hidden; }
/*Preview gallery*/
#list .preview{width:7vw; height:5.5vw; float:left; margin:3% 3.5% 4% 3.2%; }
#list .preview img{width:10vw; height:8.5vw; float:left; opacity:0.7; transition:0.2s; border-radius:10px; border:1px solid rgba(0,0,0,0.5);}
#list video{width:60vw; height:40vw; float:left; border-radius:10px; position:relative; top:5vw; left:20vw; background:rgba(0,0,0,0.5); margin:5% 20% 5% 0%;}
#list .preview img:hover{opacity:1; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id = "list">
<li>
<img class='mainimg' src="https://cdn.pixabay.com/photo/2018/08/06/16/30/mushroom-3587888_960_720.jpg" /> <button class="xp" onclick="exp(this)">See more</button>
<div class="imgxp">
<div class="preview"><img src="https://cdn.pixabay.com/photo/2018/08/06/16/30/mushroom-3587888_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/04/03/12/05/tree-99852_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/11/28/10/36/road-220058_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/03/26/09/47/sky-690293_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2012/03/01/00/21/bridge-19513_960_720.jpg"/></div>
</div>
</li>
<li>
<img class='mainimg' src="https://cdn.pixabay.com/photo/2013/11/28/10/03/autumn-219972_960_720.jpg" /> <button class="xp" onclick="exp(this)"> See more</button>
<div class="imgxp">
<div class="preview"><img src="https://cdn.pixabay.com/photo/2013/11/28/10/03/autumn-219972_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/12/01/20/28/road-1072823_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/12/01/20/28/green-1072828_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2015/02/24/15/41/dog-647528_960_720.jpg"/></div>
<div class="preview"><img src="https://cdn.pixabay.com/photo/2016/01/19/17/39/starry-night-1149815_960_720.jpg"/></div>
</div>
</li>
</div>
关于javascript - 预览图像替换位于其他列表中的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54097215/
我正在使用 javascript 并有以下类: const Product = require('../models').Product class ProductService { cons
我正在开发一个简单的应用程序,宠物用户可以在其中创建关于他们宠物的板并在板上显示图片。 我正在尝试创建一个功能,用户可以点击他们的图板,将他们重定向到他们的图板,该图板将显示他们所有的宠物图片。 当我
我有这样的事情:循环遍历 ids,并对每个 ids 向服务器(同一域)发出 ajax 请求 (async:true) 并将接收到的数据附加到 DOM 元素。这不是一项艰巨的任务,它确实有效。示例代码:
我正在尝试使用 Pillow 在我的网络应用程序中添加用户可上传的图像。我创建了一个 Django Upload 模型并将其注册到 Admin 中。当我使用管理控制台添加照片后,我收到以下错误。最初该
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
说到 UINavigationBar 时我有点困惑。我以编程方式设置它,它的作用是将我的 viewController 向下推(因此在启动应用程序后看不到 Storyboard中看到的 View 底部
我有以下查询,它可以满足我的要求,并显示从出生日期转换而来的人们的年龄。但我现在想通过说大于或小于这些年龄来缩小结果范围,但我不知道该怎么做。 SELECT u.`id` as `user_id`
我有一个 ListView (不是 recyclerView),其中每一行都有一个按钮、几个 TextView 和一个 EditText。单击特定按钮(“editTremp”)后,我希望 EditTe
我的 cellAtIndexPath 中有一个查询。正如常见的那样,此查询从单元格行索引处的数组中获取对象。我想知道每次加载 tableView 时是否只有一个查询,还是将其算作每个 indexPat
我目前正在探索 http://www.ecovivo.be/rubriek/food 上使用的模板中的错误. 问题:访问该链接时,您会注意到右侧有一个带有内容的大型 float 图像。现在一切正常。但
我在 ViewController 之间通过引用传递特定模型的数组。 如果我更改数组中特定元素的任何值,它会在所有 ViewController 中很好地反射(reflect),但是当我从该数组中删除
svg 包含更多元素,其中之一是下拉选择器。我遇到的问题是选择器只能在其顶部边缘被点击,而不能在选择器的其他任何地方被点击。 选择器称为 yp-date-range-selector。在下一张图片中,
我的元素使用 20 行 20 列的 css 网格布局(每个单元格占屏幕的 5%)。其中一个页面有一个按钮。最初该页面包含在网格第 5-8 列和网格第 6-9 行中,按钮本身没有问题,但我需要将其居中放
我想使用 CSS Trick 使图像居中.但是如果图像大小是随机的(不固定的)怎么办。令人惊讶的是,我不想保持图像响应,我想在不改变其宽度或高度(实际像素)的情况下将图像置于中心。 下面是我的代码:
我正在尝试在网址之间进行路由。产品是一个类: from django.db import models from django.urls import reverse # Create your mo
我正在通过查看 Django 教程来制作网站。我收到一个错误: NoReverseMatch at /polls/ Reverse for 'index' with no arguments not
我一直在试用 Django 教程 Django Tutorial Page 3并遇到了这个错误 "TemplateDoesNotExist at /polls/ " . 我假设问题出在我的代码指向模板
我有一个应用程序,其中大部分图像资源都存储在单独的资源包中(这样做是有正当理由的)。这个资源包与主应用程序包一起添加到项目中,当我在 Interface Builder 中设计我的 NIB 时,所有这
我使用 Xcode 6.3.2 开发了一个 iPad 应用程序。我将我的应用程序提交到 App Store 进行审核,但由于崩溃而被拒绝。以下是来自 iTunes 的崩溃报告。 Incident Id
我正在使用以下内容来显示水平滚动条: CSS: div { width: 300px; overflow-x: scroll; } div::-webkit-scrollbar {
我是一名优秀的程序员,十分优秀!