前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CSS实现图片悬停文字叠加效果

CSS实现图片悬停文字叠加效果

作者头像
@零一
发布2021-05-19 10:46:02
3.5K0
发布2021-05-19 10:46:02
举报
文章被收录于专栏:前端印象

引言

在这篇文章中,我们将看到如何轻松创建一个漂亮的图像悬停文本覆盖效果。对于本教程,你必须具备充分的 HTMLCSS 基本知识。

编写HTML

我们的 html 代码非常简单,只有几行:

代码语言:javascript
复制
<div class="image">
    <img class="image__img" src="https://cdn.pixabay.com/photo/2017/12/15/13/51/polynesia-3021072__340.jpg"
        alt="Bricks">
    <div class="image__overlay">
        <div class="image__title">Oceandiv>
        <p class="image__description">
            Enjoy the blue color of ocean.
        p>
    div>
div>

在顶部有一个img类的div,它是最大的容器。然后在其内部给要渲染的图像设置类名image__img; 同级还有一个类名为image__overlaydiv,是用于鼠标悬停时显示的,在这里面,我们可以把任何文本相关的东西覆盖在原图之上

编写CSS|创建实际效果

首先我们对 image__img 做一些基本的样式设置

代码语言:javascript
复制
.image__img {
    display: block;
    width: 100%;
    height: 100%;
    background-size: cover;
}

我们再设置父元素的相对定位,以及 image__overlay 的绝对定位属性,然后将 image__overlaytopleft 设为 0,并将宽高设为 100%,即与父容器重叠。同时设置一下黑色背景色以及透明度,做一个隐约的效果。最后设置一下动画过度效果transition,以及一些想要的字体相关的css属性,这里大家可以自行调整

代码语言:javascript
复制
.image {
    position: relative;
    width: 30%;
}

.image__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    font-family: 'Quicksand', sans-serif;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: opacity 0.25s;
}

现在是最重要的部分,如果我们鼠标离开,则看不到;鼠标放上去,则能看到。所以设置默认的透明度为 0hover时,透明度为 1

代码语言:javascript
复制
// at start
.image__overlay{
      opacity: 0;
}

// on hover
.image__overlay:hover {
    opacity: 1;
}

就是这么简单,我们已经完成了图像悬停文本叠加效果。我们也可以修改这个覆盖效果,有模糊的覆盖,也有纯色的覆盖。我们只需要将以下简单的类添加到 css 中,然后将他们添加到类名为 image__overlaydiv 元素中即可

代码语言:javascript
复制
.image__overlay--blur {
    backdrop-filter: blur(5px);
}

.image__overlay--solid {
    background: #c51f5d;
}

就这么简单。我们用这样的代码创建了三个很酷的 CSS Hover 效果。希望这对你有帮助。

强烈推荐

给你们推荐一下我的个人博客,拥有大量优质文章、面试宝典、算法精选,欢迎访问~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/05/18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 引言
  • 编写HTML
  • 编写CSS|创建实际效果
  • 强烈推荐
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档