javascript - 如何使不同的幻灯片在单个页面上工作?
问题描述
我目前正在用 twig(craftCMS) 编写一个网上商店原型,并希望每个项目都有自己的小幻灯片。当我创建控制按钮时,它们都只引用一个幻灯片,所以它们隐藏了我所有的其他幻灯片。
这就是我所坚持的:
HTML:
{% extends "_kleidunglayout" %}
{% block content %}
{%set KleiderQuery = craft.entries()
.section('shop')
.descendantOf(245)
%}
{% set entries = KleiderQuery.all() %}
{% for entry in entries|batch(3)%}
<div class="row">
{% for entry in entries%}
<div class="col l4 m12 s12">
<h4>{{entry.title}}</h4>
{% set slides = entry.artikelbild.limit(3) %}
{% if slides %}
<ul class="slideshow">
{# Output slides, using the same "slides" variable #}
{% for slide in slides %}
<li class="slide"><img class="news-image mySlides" src="{{ slide.url }}" alt="{{ slide.title }}"></li>
{% endfor %}
</ul>
<div style="text-align:center">
{% for slide in slides %}
<span class="dot" onclick="currentSlide({{loop.index}})"></span>
{% endfor %}
</div>
{% endif %}
<p>{{entry.produktebeschreibung}}</p>
<p>Preis: {{entry.artikelpreis}}</p>
</div>
{%endfor%}
</div>
{% endfor %}
{% endblock %}
CSS:
/* The dots/bullets/indicators */
.dot {
cursor: pointer;
height: 15px;
width: 15px;
margin: 0 2px;
background-color: #bbb;
border-radius: 50%;
display: inline-block;
transition: background-color 0.6s ease;
}
.active, .dot:hover {
background-color: #717171;
}
脚本:
function currentSlide(n) {
showSlides(slideIndex = n);
}
function showSlides(n) {
var i;
var slides = document.getElementsByClassName("mySlides");
var dots = document.getElementsByClassName("dot");
if (n > slides.length) {slideIndex = 1}
if (n < 1) {slideIndex = slides.length}
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
for (i = 0; i < dots.length; i++) {
dots[i].className = dots[i].className.replace(" active", "");
}
slides[slideIndex-1].style.display = "block";
dots[slideIndex-1].className += " active";
}
我还在学习写作,所以感谢您指出我的错误:)
解决方案
推荐阅读
- android - 有没有办法将 alpha 属性设置为子视图以及父视图?
- xml - 通过 XSLT 将 .txt 文件转换为 JSON
- javascript - 我对 html 代码中的 for each 循环有疑问
- jenkins - 将 SonarQube 扫描仪构建步骤转换为詹金斯管道
- c# - PRISM navigationService 在 ViewModel 构造函数中为空
- node.js - 在 nodejs 环境的 aws lambda 模块中发出请求时,为两个特定域返回 403
- java - java - 有没有办法获取给定日期字符串的模式或从 LocalDate
- eclipse - gerrit 配置中 rules.pl 中管理组的绕过规则
- c# - 在 C# 中加入两个条件
- angular - 有没有办法解决 Angular 版本 8 上服务器端渲染中的本地存储问题?