CSS学习 01 利用鼠标悬停制造文本隐藏效果

效果:
  • 在正常状态下,剧透内容的背景色和文本颜色都是黑色,导致剧透内容看起来是隐藏的(黑色文本在黑色背景上不可见)。
  • 当鼠标悬停在剧透内容上时,背景色和文本颜色恢复为初始值,使得剧透内容可见。


如何实现以上展示的效果呢?

以下HTML代码包含三个帖子,每个帖子都有一个剧透部分。

html 复制代码
<!doctype html>
<html>
    <head>
        <title></title>
        <link rel="stylesheet" href="index.css">
    </head>
    <body>
        <div class="post">
            <p>In the 1968 film Planet of the Apes, they find  
                <span class="spoiler">the ruins 
                    of the Statue of Liberty. The Plant of the
                    Apes is Earth!</span>
            </p>
        </div>
        <div class="post">
            <p>Soylent Green  
                <span class="spoiler">is made of people!</span>
            </p>
        </div>
        <div class="post">
            <p>OMG I can't believe that Darth Vadar is 
                <span class="spoiler">Luke Skywalker's father!</span>
            </p>
        </div>
    </body>
</html>

这些剧透部分被包含在 <span class="spoiler"> 标签中。

css 复制代码
:root {
    --spoiler-color: #000;
}

p {
    line-height: 1.5em;
} 

.post {
    background: #e8eaed;
    padding: 1em;
    border-radius: 1em;
    margin-bottom: 1em;
}

.spoiler {
    background: var(--spoiler-color);
    color: var(--spoiler-color);
    transition: all .5s ease-in;
}

.spoiler:hover {
    background: initial;
    color: initial;
}
  1. 全局变量定义:

:root:表示文档的根元素。定义了一个CSS变量--spoiler-color,值为#000(黑色)。

  1. 段落样式:

p:针对所有<p>标签。
line-height: 1.5em;:设置行高为1.5倍的字高。

  1. 剧透内容样式:

.spoiler:针对所有类名为spoiler的元素。
background: var(--spoiler-color);:背景色使用定义的变量--spoiler-color(黑色)。
color: var(--spoiler-color);:文本颜色使用同一个变量--spoiler-color(黑色),导致文本不可见。
transition: all .5s ease-in;:所有样式变化在0.5秒内以ease-in的效果过渡。

  1. 剧透内容的悬停效果:

.spoiler:hover:当鼠标悬停在类名为spoiler的元素上时。
background: initial;:背景色恢复为初始值(无背景色)。
color: initial;:文本颜色恢复为初始值(通常是默认颜色)。

相关推荐
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.1 小时前
HAProxy 自定义错误页面配置指南
运维·负载均衡·web
RFCEO2 小时前
前端编程 课程十、:CSS 系统学习学前知识/准备
前端·css·层叠样式表·动效设计·前端页面布局6大通用法则·黄金分割比例法则·设计美观的前端
吉吉安2 小时前
双层文字扫光效果
前端·javascript·css
沙丁鱼意大利面2 小时前
五子棋(javascript)
javascript·css·css3
曲幽3 小时前
FastAPI日志实战:从踩坑到优雅配置,让你的应用会“说话”
python·logging·fastapi·web·error·log·info
_OP_CHEN3 小时前
【前端开发之CSS】(六)CSS 弹性布局(Flex)完全指南:从入门到精通,搞定所有布局需求
前端·css·html·flex布局·弹性布局·界面美化·页面开发
萧曵 丶3 小时前
CSS3 业务开发高频样式
前端·css·css3
魔都吴所谓3 小时前
【html】倒计时器实现demo
javascript·css·html
暴富的Tdy13 小时前
【前端开发-循序渐进转向全栈开发】
vue2·web·全栈
混迹在开发队伍里的伪开发16 小时前
css的var用法,定义属性,全局使用
前端·css