视频演示地址:mp.weixin.qq.com/s/t4lFX5ImG…
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link href="./style.css" rel="stylesheet">
<title>CSS 视频字幕悬停效果</title>
<link>
</head>
<body>
<!-- 关注公众号《CSS特效世界》定期分享CSS特效 -->
<div class="container">
<div class="box">
<div class="videoBx">
<video src="bg1.mp4" muted autoplay loop></video>
</div>
<div class="contentBx">
<div class="content">
<h2>视频标题一</h2>
<p>
炊烟起了,我在门口等你。夕阳下了,我在山边等你。叶子黄了,我在树下等你。
月儿弯了,我在十五等你。细雨来了,我在伞下等你。
流水冻了,我在河畔等你。生命累了,我在天堂等你。我们老了,我在来生等你。
</p>
</div>
</div>
</div>
<div class="box">
<div class="videoBx">
<video src="bg2.mp4" muted autoplay loop></video>
</div>
<div class="contentBx">
<div class="content">
<h2>视频标题二</h2>
<p>
炊烟起了,我在门口等你。夕阳下了,我在山边等你。叶子黄了,我在树下等你。
月儿弯了,我在十五等你。细雨来了,我在伞下等你。
流水冻了,我在河畔等你。生命累了,我在天堂等你。我们老了,我在来生等你。
</p>
</div>
</div>
</div>
</div>
</body>
</html>
style.css
*{
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: '微软雅黑', sans-serif;
}
body{
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
}
.container{
position: relative;
display: flex;
justify-content: space-between;
align-items: center;
width: 1000px;
}
.container .box{
position: relative;
width: 450px;
height: 320px;
background: #000;
}
.container .box .videoBx{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.container .box .videoBx video{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: cover;
}
.container .box .contentBx{
position: absolute;
top:40px;
bottom: 40px;
right: 40px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
background: rgba(0,0,0,0.95);
transition: transform 0.5s;
transform-origin: right;
transform:scaleX(0)
}
.container .box:hover .contentBx{
transition: transform 0.5s;
transform-origin: left;
transform:scaleX(1)
}
.container .box .contentBx .content{
position: relative;
padding: 20px 60px;
opacity: 0;
}
.container .box:hover .contentBx .content{
opacity: 1;
transition: 0.5s;
transition-delay: 0.5s;
}
.container .box .contentBx .content h2{
color: #fff;
font-weight: 500;
margin-bottom: 10px;
}
.container .box .contentBx .content p{
color: #fff;
font-weight: 300;
}