当前位置: 首页 > article >正文

挑战用React封装100个组件【001】

项目地址
https://github.com/hismeyy/react-component-100

组件描述
组件适用于需要展示图文信息的场景,比如产品介绍、用户卡片或任何带有标题、描述和可选图片的内容展示

样式展示
在这里插入图片描述

代码展示

InfoCard.tsx
import './InfoCard.css'

interface InfoCardProps {
    title: string;
    description: string;
    imgSrc: string;
    imgAlt?: string;
}

const InfoCard = ({ 
    title, 
    description, 
    imgSrc, 
    imgAlt = title
}: InfoCardProps) => {
    return (
        <div className='info-card'>
            <div className='img'>
                {imgSrc && <img src={imgSrc} alt={imgAlt} />}
            </div>
            <div className="info">
                <h6>{title}</h6>
                <p>{description}</p>
            </div>
        </div>
    )
}

export default InfoCard
InfoCard.css
.info-card {
    box-sizing: border-box;
    width: 240px;
    height: 80px;
    border-radius: 10px;
    background-color: #F5F5F5;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
    display: flex;
    justify-content: left;
    align-items: center;
    padding: 5px 5px 5px 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    transform-origin: center;
}

.info-card .img {
    width: 60px;
    height: 60px;
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.3s ease;
}

.info-card .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.info-card .info{
    margin-left: 5px;
    height: 60px;
}

.info-card .info h6 {
    all: unset;
    display: block;
    width: 160px;
    font-size: 14px;
    font-weight: bold;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.3s ease;
}

.info-card .info p {
    all: unset;
    display: -webkit-box;
    width: 160px;
    margin-top: 10px;
    font-size: 12px;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-wrap: break-word;
    line-height: 1.3;
    transition: color 0.3s ease;
    line-clamp: 2;
    box-orient: vertical;
}

.info-card:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    background-color: #ffffff;
}

.info-card:hover .img {
    transform: scale(1.05);
}

.info-card:hover .info h6 {
    color: #f08a5d;
}

.info-card:hover .info p {
    color: #666;
}

使用

App.tsx
import './App.css'
import InfoCard from './components/card/infoCard01/InfoCard'

function App() {
  return (
    <>
      <InfoCard
        title="React 18 新特性"
        description="React 18 带来了令人兴奋的新特性,包括自动批处理、Transitions API 和 Suspense 的改进。这些更新显著提升了应用性能和用户体验。"
        imgSrc="https://cdn1.iconfinder.com/data/icons/programing-development-8/24/react_logo-512.png"
      />
    </>
  )
}

export default App

http://www.kler.cn/a/415407.html

相关文章:

  • Java多线程学习二
  • 【AIGC】大模型面试高频考点-数据清洗篇
  • 《Vue 组件化开发:构建可复用的模块》
  • spring知识点复习--针对面试的
  • STM32C011开发(1)----开发板测试
  • Swagger记录一次生成失败
  • 设计模式面试大全:说一下单例模式,及其应用场景?
  • Microsoft Fabric - 尝试一下Delta Table
  • 【VUE3】npm : 无法加载文件 D:\Program\nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本。
  • 设计模式之抽象工厂 C# 范例
  • 力扣637. 二叉树的层平均值
  • 公开整理-中国省级人工智能专利统计数据(2010-2022年)
  • Android Studio安装TalkX AI编程助手
  • 单例模式(Singleton Pattern):深入解析与应用场景
  • ASUS/华硕天选5Pro酷睿版 FX607J 原厂Win11 23H2系统 工厂文件 带ASUS Recovery恢复
  • 使用Apache HttpClient发起一个GET HTTP请求
  • C++(模板)
  • 新增工作台模块,任务中心支持一键重跑,MeterSphere开源持续测试工具v3.5版本发布
  • 线段树讲解
  • 宠物领养技术:SpringBoot框架应用
  • 一个简洁的ajax注册登录找回密码切换的前端页面
  • 原生js上传图片
  • Spring 返回JSON
  • Rust个人认为将抢占C和C++市场,逐渐成为主流的开发语言
  • Hackathon靶机系列Hackathon2
  • 求助:selenium.common.exceptions.SessionNotCreatedException: x x x