CSS学习碎碎念之卡片展示

效果展示:

代码展示

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>图片展示</title>
</head>

<body>
    <div class="menu-container">
        <div class="col-sm-3 menu-card" onclick="window.open('${site.url}', '_blank')">
            <img src="25.jpg">
            <div class="menu-content">
                <h2>标题</h2>
                <p>描述</p>
            </div>
        </div>
        <div class="col-sm-3 menu-card" onclick="window.open('${site.url}', '_blank')">
            <img src="25.jpg">
            <div class="menu-content">
                <h2>标题</h2>
                <p>描述</p>
            </div>
        </div>
        <div class="col-sm-3 menu-card" onclick="window.open('${site.url}', '_blank')">
            <img src="25.jpg">
            <div class="menu-content">
                <h2>标题</h2>
                <p>描述</p>
            </div>
        </div>
    </div>
   
</body>

</html>

<style>
    .menu-card {
        /* 鼠标放到卡片上去后会出现小手 */
        cursor: pointer;
        /* 设置开票宽度 */
        width: 300px;
        /* 设置卡片高度 */
        height: 130px;
        /* 设置卡片外边框直接的距离 */
        margin: 20px;
        /* 设置背景色 */
        background-color: #fff;
        /* 设置圆角 */
        border-radius: 10px;
        /* 设置边框阴影 */
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
        /* 超出之后覆盖 */
        overflow: hidden;
        /* 移动效果 设置时间 */
        transition: transform 0.3s;
        /* 布局方式自适应 */
        display: flex;
        /* 中间放置 */
        align-items: center;
    }

    .menu-container {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 20px;
        /* 内边框 */
        padding: 20px;
    }

    .menu-card:hover {
        /* 设置悬停效果为向上移动 */
        transform: translateY(-5px);
    }

    .menu-card img {
        width: 80px;
        height: 80px;
        margin-left: 10px;
        object-fit: cover;
        border-radius: 10px;
    }

    .menu-content {
        padding: 20px;
    }

    .menu-content h2 {
        font-size: 16px;
        margin-left: 10px;
        margin-bottom: 10px;
        color: #e27d60;
    }

    .menu-content p {
        font-size: 14px;
        margin-left: 10px;
        color: #7f7f7f;
        margin-bottom: 20px;
    }

    .menu-content div a {
        display: inline-block;
        padding: 8px 16px;
        background-color: #e27d60;
        color: #fff;
        text-decoration: none;
        border-radius: 4px;
        transition: background-color 0.3s;
    }

    .menu-content a:hover {
        background-color: #bf6043;
    }
</style>

碎碎念

  • cursor: pointer; 可以把鼠标变为小手
  • width: 300px; 设置容器的宽度
  • height: 130px; 设置容器的高度
  • margin: 20px; 设置相邻容器之间的距离(外边框距离),margin可以单独对上下左右进行设置。如margin-left margin-right ...
  • padding: 20px; 设置内边框距离
  • background-color: #fff; 设置背景色
  • border-radius: 10px; 设置边框圆角
  • box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); 设置边框阴影部分
  • overflow: hidden; 超出部分被隐藏
  • transition: transform 0.3s; 设置移动时间
  • transform: translateY(-5px); 设置移动距离
  • display: flex; 设置布局类型
  • align-items: center; 中间防止
  • justify-content: center; 内容放在中间
    类的选择 还可以通过.menu-content div a方式按照层级选择标签
    div标签提供容器功能,一般标签之间以纵向排列,如果需要横排需要改变display布局方式
相关推荐
biubiubiu_LYQ8 小时前
萌新小白基础篇之CSS定位布局(干货满满)!
css
晓梦林8 小时前
homelab2靶场学习笔记
笔记·学习
AI绘画哇哒哒8 小时前
Agent三种思考模式深度解析:CoT/ReAct/Plan-and-Execute,小白程序员必看,助你轻松掌握大模型精髓(收藏版)
人工智能·学习·ai·程序员·大模型·产品经理·转行
LN花开富贵9 小时前
Ubuntu aarch64 架构安装 NoMachine 远程控制 避坑与实战
linux·运维·笔记·学习·ubuntu·嵌入式
-To be number.wan9 小时前
数据库单表查询全攻略
数据库·学习
ゆづき9 小时前
Java 初学者入门指南:常见问题 + 核心知识点 + 进阶 20 道练习题
java·开发语言·学习·算法·水题
叶~小兮10 小时前
ELK技术栈全套学习笔记(Elasticsearch+Logstash+Filebeat)
笔记·学习·elk
暗冰ཏོ10 小时前
CSS 超详细讲解(从基础到高级实战)
前端·css·css3·sass·scss
婷婷_17211 小时前
【PCIe 验证每日学习・Day36】PCIe 存储器寻址空间与 BAR 底层原理
网络·学习·程序人生·芯片·pcie