javascript - 一页中有多个模式,其中一些模式是轮播

标签 javascript jquery html carousel simplemodal

我有一个包含多个按钮的页面,当单击每个按钮时,会弹出一个不同的模式。一些模式是轮播,我的代码可以工作,但只有一个轮播,当我有多个轮播时,我会在所有轮播上获得额外的空幻灯片。所以我猜我的代码正在计算所有轮播中的所有幻灯片。我试图在它说的地方写一些东西,如果单击此模态,则仅从单击的模态获取幻灯片,但我为此苦苦挣扎。

这些是相关代码的位:

<button class="button" data-modal="#modalOne"><img id="myImg" src=""></button>
<button class="button" data-modal="#modalB"><img id="myImg" src=""></button>
<button class="button" data-modal="#modalC"><img id="myImg" src=""></button>
	
<!-- The Modal -->
 <div id="modalA" class="modal">
<!-- Modal content -->
  <div class="modal-content">
	<span class="close">×</span>
	
	<div class= "mySlides">
	  <img class="gif" src="" width="100" height="100"  >
	  
	  <h4>Title</h4>
      <p> content </p>
	</div>
	
	<div class="mySlides">
	  <h4 Title</h4>
	  <p> content </p>
	  
	</div>
		
    <div class="w3-left w3-hover-text-khaki" onclick="plusDivs(-1)">❮</div>
    <div class="w3-right w3-hover-text-khaki" onclick="plusDivs(1)">❯</div>
  </div>
</div>

<!-- The Modal B -->
 <div id="modalB" class="modal">
<!-- Modal content -->
  <div class="modal-content">
	<span class="close">×</span>
	
	<div class="mySlides">
	  <img class="gif" src="" width="100" height="100"  >
	  <h4></h4>
      <p></p>
	</div>
  </div>
</div> 

<!-- The Modal C -->
 <div id="modalC" class="modal">
<!-- Modal content -->
  <div class="modal-content">
	<span class="close">×</span>
	<div class="mySlides">
	  <img class="gif" src="" width="100" height="100"  >
	  
	  <h4></h4>
      <p></p>
	 
	
	<div class="mySlides">
	 
	  <h4></h4>
	  <p></p>
	</div>
	<div class="w3-left w3-hover-text-khaki" onclick="plusDivs(-1)">❮</div>
    <div class="w3-right w3-hover-text-khaki" onclick="plusDivs(1)">❯</div>
  </div>
</div>

 <script>
//Carousel
	
var slideIndex = 1;
showDivs(slideIndex);

function plusDivs(n) {
 showDivs(slideIndex += n); 
}

function currentDiv(n) {
  showDivs(slideIndex = n);
}

function showDivs(n) {
  var i;
  var x = document.getElementsByClassName("mySlides");
  var dots = document.getElementsByClassName("demo");
  if (n > x.length) {slideIndex = 1}    
  if (n < 1) {slideIndex = x.length}
  for (i = 0; i < x.length; i++) {
    x[i].style.display = "none";  
	   }
 for (i = 0; i < dots.length; i++) {
     /*dots[i].className = dots[i].className.replace(" w3-white", "");*/
  }
  x[slideIndex-1].style.display = "block";  
  /*dots[slideIndex-1].className += " w3-white";*/
}

  </script>

	
<script>
//Display corresponding modal of letter that is clicked 
	
$(".button").on("click", function() {
   var modal = $(this).data("modal");
   $(modal).show();
   document.body.classList.add("modal-open");  
 
});
  

  
//Close modal when "x" is clicked or when area outside modal is clicked
$(".modal").on("click", function(e) {
   var className = e.target.className;
   if(className === "modal" || className === "close"){
   $(this).closest(".modal").hide();
   document.body.classList.remove("modal-open");
  }
});
  

  
  
</script>

最佳答案

看起来您没有为按钮上的结束标记使用正确的“<”。

关于javascript - 一页中有多个模式,其中一些模式是轮播,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46668090/

相关文章:

javascript - 如何找到图像元素的xpath

javascript - selectnav 列表项里面有一个跨度

javascript - 单击 anchor 时滚动 div 30px

jQuery .append 不适用于断开连接的 DOM 节点数组?

javascript - 展开没有分配类的文本跨度

jquery - 错误 : Jquery form validate plug is appending duplicate error messages per field in firefox

html - 隐藏在 Bootstrap 中输入后面滚动的文本

javascript - 固定位置不适用于 ios 设备

jquery - 从一个链接显示具有相同 ID 的两个 div 的内容

javascript - 如何使用 node.js 服务器处理大量负载?