[英]Multiple Scripts on same HTML page for rotating banner
尝试为页脚中的内容制作一种自动旋转横幅。 问题在于,当他们更新幻灯片时,前两个在更改一次后停止,第三个更新比应该更快。 每个部分都有唯一的类名,我似乎无法找到问题所在。 我认为问题出在HTML或JS脚本中,但这是我第一次在一个页面上使用多个脚本。 (这是一个项目)HTML
<footer>
<div class = "grid-container" id = "footer-grid">
<div class = "grid-100 mobile-grid-100 grid-parent" id = "slideshow">
<div class = "Slide1 grid-33 mobile-grid-33">
<h1>Slide 1</h1>
</div>
<div class = "Slide1 grid-33 mobile-grid-33">
<h1>Slide 2</h1>
</div>
<div class = "Slide1 grid-33 mobile-grid-33">
<h1>Slide 3</h1>
</div>
<div class = "Slide1 grid-33 mobile-grid-33">
<h1>Slide 4</h1>
</div>
<div class = "Slide1 grid-33 mobile-grid-33">
<h1>Slide 5</h1>
</div>
<div class = "Slide grid-33 mobile-grid-33">
<h1>Slide 1</h1>
</div>
<div class = "Slide grid-33 mobile-grid-33">
<h1>Slide 2</h1>
</div>
<div class = "Slide grid-33 mobile-grid-33">
<h1>Slide 3</h1>
</div>
<div class = "Slide grid-33 mobile-grid-33">
<h1>Slide 4</h1>
</div>
<div class = "Slide grid-33 mobile-grid-33">
<h1>Slide 5</h1>
</div>
<div class = "mySlides3 grid-33 mobile-grid-33">
<h1>Slide 1</h1>
</div>
<div class = "mySlides3 grid-33 mobile-grid-33">
<h1>Slide 2</h1>
</div>
<div class = "mySlides3 grid-33 mobile-grid-33">
<h1>Slide 3</h1>
</div>
<div class = "mySlides3 grid-33 mobile-grid-33">
<h1>Slide 4</h1>
</div>
<div class = "mySlides3 grid-33 mobile-grid-33">
<h1>Slide 5</h1>
</div>
</div>
<div class = "clear"></div>
<div class = "clear"></div>
<div class = "grid-100" id = "footer-info">
<p>some stuff might go here</p>
</div>
</div>
</footer>
<!-- SCRIPTS -->
<script>
var slideIndex = 0;
carousel();
function carousel() {
var i;
var x = document.getElementsByClassName("Slide1");
for (i = 0; i < x.length; i++) {
x[i].style.display = "none";
}
slideIndex++;
if (slideIndex > x.length) {slideIndex = 1}
x[slideIndex-1].style.display = "block";
setTimeout(carousel, 1000); // Change image every 2 seconds
}
</script>
<script>
var slideIndex = 0;
carousel();
function carousel() {
var i;
var x = document.getElementsByClassName("Slide");
for (i = 0; i < x.length; i++) {
x[i].style.display = "none";
}
slideIndex++;
if (slideIndex > x.length) {slideIndex = 1}
x[slideIndex-1].style.display = "block";
setTimeout(carousel, 1000); // Change image every 2 seconds
}
</script>
<script>
var slideIndex = 0;
carousel();
function carousel() {
var i;
var x = document.getElementsByClassName("mySlides3");
for (i = 0; i < x.length; i++) {
x[i].style.display = "none";
}
slideIndex++;
if (slideIndex > x.length) {slideIndex = 1}
x[slideIndex-1].style.display = "block";
setTimeout(carousel, 1000); // Change image every 2 seconds
}
</script>
CSS
Slide1, .Slide, .mySlides3 {
display: none;
border: 1px solid black;
text-align: center;
padding-top:10px;
margin-bottom:10px;
}
任何帮助表示赞赏,这是我此时使用javascript的唯一真正问题。 我似乎无法找到为什么会发生这种情况,我尝试将类名更改为更加清晰。
在全局范围内创建新函数时,基本上执行以下操作:
window.carousel = function () { ... }
你有3个脚本部分。 首次执行时,它会旋转第一个元素。 但在那之后,它被第二个脚本块覆盖了。 所以你的代码目前是这样的:
window.carousel = function () { /* logic for elm 1 */ }
window.carousel()
window.carousel = function () { /* logic for elm 2 */ }
window.carousel()
window.carousel = function () { /* logic for elm 3 */ }
window.carousel()
简而言之,3个脚本标签共享一个范围,因此您的问题。 解决方案可能是创建一个轮播函数,它将id作为参数。 无论如何,这是更好的编码实践
您现在可以合并您的JavaScript,让自己更轻松。 您只需要1个轮播功能即可完成所有通话。 每个轮播函数调用之间唯一的变化是类名。 因此,将其添加为轮播功能的参数。
<!-- SCRIPTS -->
<script>
var slideIndex = 0;
carousel("Slide1");
carousel("Slide");
carousel("mySlides3");
function carousel(slideName) {
var i;
var x = document.getElementsByClassName(slideName);
for (i = 0; i < x.length; i++) {
x[i].style.display = "none";
}
slideIndex++;
if (slideIndex > x.length) {
slideIndex = 1
}
x[slideIndex - 1].style.display = "block";
setTimeout(function() { carousel(slideName) }, 1000); // Change image every 2 seconds
}
</script>
PS ...你错过了一个“。” 在你的CSS中的Slide1上。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.