CSS 过渡到多个图像
CSS Transition Over More Than One Image
我正在尝试创建一个在图像顶部移动白色 div 的过渡。我目前可以用一张图片做到这一点,但是,我希望能够用两张或更多图片做到这一点……
我认为这个问题与这里的 position
属性 有关,但我不确定实际的解决方案是什么。
这是一个代码笔:https://codepen.io/jon424/pen/XWzGNLe
当你点击“toggle”时,你会看到第一张图片发生了转换,但我希望同样的事情同时发生在第二张图片上。知道怎么做吗?
HTML
<button>Toggle</button>
<div class="parent">
<img class="child1" src="https://picsum.photos/200/300">
<div class="child1 covering"></div></div>
<div class="parent">
<img class="child2" src="https://picsum.photos/200/302">
<div class="child2 covering"></div></div>
CSS
.parent {
position: relative;
width: 300px;
height: 300px;
margin: 10px;
}
.child1 {
position: absolute;
width: 100%;
height: 100%;
bottom: 0;
left: 0;
}
.child2 {
/* position: absolute; */
width: 100%;
height: 100%;
bottom: 0;
left: 0;
}
.covering {
z-index: 1;
background: #ffffff;
transition: max-height 1s ease-in-out;
max-height:100%;
}
.covered {
max-height: 0px;
}
.hidden {
display: none;
}
JS
const firstTarget = document.querySelector(".firstTarget");
const covering = document.querySelector(".covering");
document.querySelector('.covering').classList.add('covered');
document.querySelector('button').addEventListener('click', () => { document.querySelector('.covering').classList.toggle('covered');});
要定位相同 class 的多个元素,请使用 querySelectorAll() and than use NodeList.forEach()
// DOM utility functions:
const ELS = (sel, par) => (par || document).querySelectorAll(sel);
const EL = (sel, par) => (par || document).querySelector(sel);
// Task:
const ELS_covering = ELS(".covering"); // Get them all!
EL('button').addEventListener('click', () => {
ELS_covering.forEach(el => el.classList.toggle('covered'));
});
.parent {
position: relative;
overflow: hidden;
display: inline-flex;
width: 200px;
height: 200px;
margin: 10px;
}
.child {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
}
img.child {
object-fit: cover;
}
.covering {
z-index: 1;
background: #eee;
transition: transform 1s ease-in-out;
transform: translateY(-100%);
display: flex; justify-content: center; align-items: center;
}
.covered {
transform: translateY(0%);
}
<button>Toggle</button>
<br>
<div class="parent">
<img class="child" src="https://picsum.photos/200/300">
<div class="child covering covered">Some text here</div>
</div>
<div class="parent">
<img class="child" src="https://picsum.photos/300/302">
<div class="child covering covered">Lorem Ipsum</div>
</div>
我正在尝试创建一个在图像顶部移动白色 div 的过渡。我目前可以用一张图片做到这一点,但是,我希望能够用两张或更多图片做到这一点……
我认为这个问题与这里的 position
属性 有关,但我不确定实际的解决方案是什么。
这是一个代码笔:https://codepen.io/jon424/pen/XWzGNLe 当你点击“toggle”时,你会看到第一张图片发生了转换,但我希望同样的事情同时发生在第二张图片上。知道怎么做吗?
HTML
<button>Toggle</button>
<div class="parent">
<img class="child1" src="https://picsum.photos/200/300">
<div class="child1 covering"></div></div>
<div class="parent">
<img class="child2" src="https://picsum.photos/200/302">
<div class="child2 covering"></div></div>
CSS
.parent {
position: relative;
width: 300px;
height: 300px;
margin: 10px;
}
.child1 {
position: absolute;
width: 100%;
height: 100%;
bottom: 0;
left: 0;
}
.child2 {
/* position: absolute; */
width: 100%;
height: 100%;
bottom: 0;
left: 0;
}
.covering {
z-index: 1;
background: #ffffff;
transition: max-height 1s ease-in-out;
max-height:100%;
}
.covered {
max-height: 0px;
}
.hidden {
display: none;
}
JS
const firstTarget = document.querySelector(".firstTarget");
const covering = document.querySelector(".covering");
document.querySelector('.covering').classList.add('covered');
document.querySelector('button').addEventListener('click', () => { document.querySelector('.covering').classList.toggle('covered');});
要定位相同 class 的多个元素,请使用 querySelectorAll() and than use NodeList.forEach()
// DOM utility functions:
const ELS = (sel, par) => (par || document).querySelectorAll(sel);
const EL = (sel, par) => (par || document).querySelector(sel);
// Task:
const ELS_covering = ELS(".covering"); // Get them all!
EL('button').addEventListener('click', () => {
ELS_covering.forEach(el => el.classList.toggle('covered'));
});
.parent {
position: relative;
overflow: hidden;
display: inline-flex;
width: 200px;
height: 200px;
margin: 10px;
}
.child {
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
}
img.child {
object-fit: cover;
}
.covering {
z-index: 1;
background: #eee;
transition: transform 1s ease-in-out;
transform: translateY(-100%);
display: flex; justify-content: center; align-items: center;
}
.covered {
transform: translateY(0%);
}
<button>Toggle</button>
<br>
<div class="parent">
<img class="child" src="https://picsum.photos/200/300">
<div class="child covering covered">Some text here</div>
</div>
<div class="parent">
<img class="child" src="https://picsum.photos/300/302">
<div class="child covering covered">Lorem Ipsum</div>
</div>