我有一个动画功能,我试图修改类的一个“弹出”,代码的画廊部分的网站。当用户加载页面时,正方形图像和背景开始从页面中心的零比例扩展或增长到100视口高度(VH)和100视口宽度(VW)。换句话说,图像从中心页面“弹出”并填充屏幕。我不希望页面以这种方式打开。我希望“大图像”和背景立即显示在100 VH和100 VW没有动画(即。增长效应)。请记住,我仍然希望当用户单击“close-btn”以显示图库中的其余图像时,动画仍然起作用。
const images = [...document.querySelectorAll('.image')];
// popup
const popup = document.querySelector('.popup');
const closeBtn = document.querySelector('.close-btn');
const imageName = document.querySelector('.image-name');
const largeImage = document.querySelector('.large-image');
const imageIndex = document.querySelector('.index');
const leftArrow = document.querySelector('.left-arrow');
const rightArrow = document.querySelector('.right-arrow');
let index = 0; // will track our current image;
images.forEach((item, i) => {
item.addEventListener('click', () => {
updateImage(i);
popup.classList.toggle('active');
})
})
const updateImage = (i) => {
let path = `img/img${i+1}.png`;
largeImage.src = path;
imageName.innerHTML = path;
imageIndex.innerHTML = `0${i+1}`;
index = i;
}
closeBtn.addEventListener('click', () => {
popup.classList.toggle('active');
})
leftArrow.addEventListener('click', () => {
if(index > 0){
updateImage(index - 1);
}
})
rightArrow.addEventListener('click', () => {
if(index < images.length - 1){
updateImage(index + 1);
}
})
const setPopupImage = index => {
popup.classList.toggle('active');
}
setPopupImage(0);
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
*:focus {
outline: none;
}
body {
width: 100vw;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
background: #ff7a2d;
font-family: 'roboto', sans-serif;
}
.gallery {
width: 80%;
height: 90vh;
max-width: 1600px;
max-height: 800px;
display: flex;
flex-wrap: wrap;
justify-content: center;
align-items: center;
}
.gallery-image {
width: 30%;
height: calc(50% - 20px);
min-width: 300px;
min-height: 200px;
margin: 10px;
overflow: hidden;
}
.image {
width: 100%;
height: 100%;
object-fit: cover;
transition: 1s;
}
.popup {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) scale(0);
width: 100vw;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
z-index: 5;
overflow: hidden;
transition: 1s;
opacity: 0;
}
.popup.active {
transform: translate(-50%, -50%) scale(1);
opacity: 1;
}
.popup.active .close-btn,
.popup.active .image-name,
.popup.active .index,
.popup.active .large-image,
.popup.active .arrow-btn {
opacity: 1;
transition: opacity .5s;
transition-delay: 1s;
}
.top-bar {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 10px;
background: turquoise;
color: #fff;
text-align: center;
line-height: 50px;
font-weight: 300;
}
.image-name {
opacity: 0;
}
.close {
position: absolute;
top: 35px;
right: 70px;
cursor: pointer;
}
.arrow-btn {
opacity: 0;
position: absolute;
top: 50%;
transform: translateY(-50%);
padding: 10px;
border-radius: 50%;
border: none;
background: none;
cursor: pointer;
}
.left-arrow {
left: 10px;
}
.right-arrow {
right: 10px;
transform: translateY(-50%) rotate(180deg);
}
.arrow-btn:hover {
background: rgba(0, 0, 0, 0.5);
}
.index {
position: absolute;
bottom: 10px;
right: 10px;
font-size: 80px;
font-weight: 100;
color: rgba(255, 255, 255, 0.4);
opacity: 0;
}
.large-image {
width: 90%;
height: 90%;
object-fit: contain;
opacity: 0;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Image Popup</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="popup">
<div class="top-bar">
<p class="image-name">img1.png</p>
<span class="close-btn">
<img src="Graphics/gallery_icon.svg" width="50px" class="close">
</span>
</div>
<button class="arrow-btn left-arrow"><img src="img/arrow.png" alt=""></button>
<button class="arrow-btn right-arrow"><img src="img/arrow.png" alt=""></button>
<img src="img/img1.png" class="large-image" alt="">
<h1 class="index">01</h1>
</div>
<div class="gallery">
<div class="gallery-image">
<img src="img/img1.png" alt="" class="image">
</div>
<div class="gallery-image">
<img src="img/img2.png" alt="" class="image">
<div class="bk"></div>
</div>
<div class="gallery-image">
<img src="img/img3.png" alt="" class="image">
</div>
<div class="gallery-image">
<img src="img/img4.png" alt="" class="image">
</div>
<div class="gallery-image">
<img src="img/img5.png" alt="" class="image">
</div>
<div class="gallery-image">
<img src="img/img6.png" alt="" class="image">
</div>
</div>
<script src="index.js"></script>
</body>
</html>
1条答案
按热度按时间iyfamqjs1#
尝试注解掉'popup.classList.toggle(' active ');'foreach'循环(Line_13.js)中。这应该会删除不需要的. img弹出窗口。当用户单击关闭按钮(closeBtn)、左箭头按钮(leftArrow)和/或右箭头按钮(rightArrow)时,弹出窗口仍将出现。
我希望这对你有帮助。
PS:这是我做的一个尝试。尝试它,因为它应该像你打算的那样工作:)
//从.js脚本
问候。