NextJS开发:shadcn/ui中Button组件扩展增加图标

shadcn/ui组件比较灵活,但是功能相比ant之类组件还是缺少太多功能,本文为shadcn/ui为button组件增加图标,加载中动画等效果。

  1. 安装Lucide
bash 复制代码
npm install lucide
  1. Lucide组件
typescript 复制代码
import { cn } from '@/lib/utils';
import { icons } from 'lucide-react';

const LcIcon = ({ name, color, size, className }: { name: string, color?: string, size: number, className?: string}) => {
  const LucideIcon = (icons as any)[name];
  if(LucideIcon == null) {
    return <></>
  }
  if(color != null) {
    return <LucideIcon color={color} size={size} />
  } else {
    return <LucideIcon size={size} className={cn("", className)}/>
  }
};

export default LcIcon;
  1. 创建组件CustomButton
typescript 复制代码
"use client"
import React, { MouseEventHandler } from "react";
import { Button } from "../ui/button";
import LcIcon from "./lc-icon";

/** 
 * Button扩展,增加图标功能 
 * <CustomButton icon="Loader" onClick={handleSubmit}>Button</CustomButton>
 * */
export const CustomButton = (props: {
  className?: string, 
  icon?: string, 
  loading?: boolean
  disabled?: boolean,
  type?: string,
  onClick?: MouseEventHandler<HTMLButtonElement>,
  children?: any
}) => {

  const buildIcon = () => {
    if(props.loading != null && props.loading) {
      return <LcIcon name="Loader" size={16} className="mr-1 animate-spin"/>
    }
    else if(props.icon != null) {
      return <LcIcon name={props.icon} size={16} className="mr-1"/>
    }
    return ""
  }

  return (
    <Button type={props.type ?? 'button' as any} className={props.className} disabled={props.disabled} onClick={props.onClick}>
      { buildIcon() }
      { props.children }
    </Button>
  )
}
  1. 组件使用,

显示加载中

typescript 复制代码
import { CustomButton } from "@/components/app/custom-button";

<CustomButton loading={true} disabled={true} >测试</CustomButton>

显示图标

typescript 复制代码
import { CustomButton } from "@/components/app/custom-button";

<CustomButton icon="Home">测试</CustomButton>
相关推荐
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 小时前
React 怎么区分导入的是组件还是函数,或者是对象
前端·react.js·前端框架
前端无涯2 小时前
React/Vue 代理配置全攻略:Vite 与 Webpack 实战指南
vue.js·react.js
San306 小时前
深度解析 React 组件化开发:从 Props 通信到样式管理的进阶指南
前端·javascript·react.js
AAA阿giao6 小时前
深度解析 React 项目架构:从文件结构到核心 API 的全面拆解
前端·javascript·react.js
昨晚我输给了一辆AE867 小时前
关于 react-hook-form 的 isValid 在有些场景下的值总是 false 问题
前端·react.js
Mintopia10 小时前
🏗️ B端架构中的用户归因与埋点最佳实践
前端·react.js·架构
Blossom.11810 小时前
大模型AI Agent实战:ReAct框架从零实现与金融研报分析系统
人工智能·学习·react.js·stable diffusion·金融·aigc·知识图谱
南山安10 小时前
React 学习:父传子的单项数据流——props
javascript·react.js·前端框架
soda_yo10 小时前
React哲学:保持组件纯粹 哈气就要哈得纯粹
前端·react.js·设计