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布局方式
相关推荐
昨天;明天。今天。5 分钟前
案例-任务清单
前端·javascript·css
yunhuibin16 分钟前
ffmpeg面向对象——拉流协议匹配机制探索
学习·ffmpeg
hengzhepa26 分钟前
ElasticSearch备考 -- Search across cluster
学习·elasticsearch·搜索引擎·全文检索·es
蜡笔小新星1 小时前
Python Kivy库学习路线
开发语言·网络·经验分享·python·学习
攸攸太上1 小时前
JMeter学习
java·后端·学习·jmeter·微服务
惜.己2 小时前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
Ljubim.te2 小时前
Linux基于CentOS学习【进程状态】【进程优先级】【调度与切换】【进程挂起】【进程饥饿】
linux·学习·centos
yngsqq2 小时前
031集——文本文件按空格分行——C#学习笔记
笔记·学习·c#
秋殇与星河3 小时前
CSS总结
前端·css
zengy53 小时前
Effective C++中文版学习记录(三)
数据结构·c++·学习·stl