Metis UI:下一代 React 组件库,重新定义前端开发体验

11 小时 59 分钟前
 Minimx

Metis UI:下一代 React 组件库,重新定义前端开发体验

在快速发展的前端生态中,开发者们一直在寻找既能提高开发效率,又能保证代码质量和用户体验的解决方案。今天,我们很兴奋地向大家介绍 Metis UI —— 一个基于 Tailwind CSS 构建,继承 Ant Design 交互逻辑的现代 React 组件库。

为什么选择 Metis UI ?

在众多组件库中,Metis UI 独树一帜,它不是简单的重复造轮子,而是在继承优秀设计理念的基础上,带来了全新的开发体验:

继承经典,超越传统

Metis UI 基于 Ant Design 久经考验的组件逻辑构建,确保了交互模式的一致性和可靠性。同时,我们抛弃了传统的 CSS-in-JS 方案,全面拥抱 Tailwind CSS ,为开发者带来了前所未有的样式自由度。

极致的开发体验

import { Button, Input, Form } from 'metis-ui';

// 简洁的 API ,强大的功能
<Button 
 type="primary" 
 className="hover:scale-105 transition-transform"
>
  自定义样式,轻而易举
</Button>

无需学习复杂的主题配置,直接使用 Tailwind 类名即可实现个性化定制。

技术亮点

1. 完美的 TypeScript 支持

interface ButtonProps {
 type?: 'primary' | 'default' | 'dashed';
 size?: 'small' | 'middle' | 'large';
 loading?: boolean;
 ...
}

每个组件都提供完整的类型定义,让你的开发过程更加安全和高效。

2. Tailwind CSS 深度集成

<Button className="bg-gradient-to-r from-blue-500 to-purple-600 hover:from-blue-600 hover:to-purple-700">
 渐变按钮
</Button>

利用 Tailwind 的强大功能,轻松实现复杂的样式效果。

3. 文档驱动开发

快速开始

安装

# npm
npm install metis-ui

# pnpm (推荐)
pnpm add metis-ui

# yarn
yarn add metis-ui

配置

向你的入口 CSS 文件添加一个 @plugin 以导入 Metis UI 。

@import 'tailwindcss';

@source './node_modules/metis-ui/es';
@plugin 'metis-ui/plugin';

开始使用

import { Alert } from 'metis-ui';

const App = () => (
  <div className="h-screen w-screen">
    <Alert type="info" banner message="Hello" description="Welcome to metis-ui" />
  </div>
);

export default App;

主题定制

Metis UI 只针对颜色进行主题定制,默认提供了两套主题:lightdark。您还可以创建自己的自定义主题或修改内置主题。

您可以在 CSS 文件中的 @plugin "metis-ui/plugin" 后添加括号来管理主题,详细介绍

Metis Plus - 企业中后台系统模板

我们提供了一套开箱即用的企业中后台系统模板,基于 Reactreact-routerTypeScriptViteTailwindCSSZustandfaker-jsMSW 等技术栈构建。它内置了开箱即用的数据流、国际化、菜单、模拟数据、权限管理、主题切换等功能,助力企业快速搭建高质量的中后台应用。

├── .husky                     # Husky 钩子配置目录
├── public                     # 公共静态资源目录
├── src                        # 源码目录
│   ├── apis                   # 服务端接口请求相关
│   ├── assets                 # 静态资源(图片、SVG 等)
│   ├── components             # 通用组件
│   ├── hooks                  # 自定义 hooks
│   ├── layouts                # 页面布局组件
│   ├── locale                 # 国际化资源
│   ├── mocks                  # Mock 数据与服务
│   ├── pages                  # 页面组件
│   ├── store                  # Zustand 状态管理
│   ├── types                  # TypeScript 类型定义
│   ├── utils                  # 工具函数与工具类
│   ├── loading.tsx            # 全局 Loading 组件
│   ├── main.tsx               # 应用入口文件
│   ├── routes.tsx             # 路由和菜单配置
│   └── vite-env.d.ts          # Vite 环境类型声明
├── .env                       # 环境变量配置文件
├── .lintstagedrc              # lint-staged 配置文件
├── .prettierignore            # Prettier 忽略文件配置
├── .prettierrc                # Prettier 代码格式化配置
├── commitlint.config.js       # 提交规范校验配置
├── eslint.config.js           # ESLint 代码规范配置
├── index.html                 # 项目入口 HTML
├── package.json               # 项目依赖与脚本配置
├── tailwind.css               # TailwindCSS 全局样式入口
├── tsconfig.app.json          # TS 应用配置
├── tsconfig.json              # TS 根配置
├── tsconfig.node.json         # TS Node 配

官方资源

tips: 网站匀部属在 Github Pages, 访问可能需要梯子

2193 次点击
所在节点    React
29 条回复
dnslint
11 小时 57 分钟前
前端就是无数个轮子
aladdinding
11 小时 51 分钟前
我要下下一代
icy37785
11 小时 49 分钟前
我现在选型的唯一原则就是 ai 擅不擅长🐶
Cheez
11 小时 45 分钟前
我想问问,这个 UI 具体的好处是什么?
chanderbing
11 小时 36 分钟前
这个 disable 之后的对比度是认真的吗,我都快看不清了
MrYELiex
11 小时 25 分钟前
antd 这种适合后台复杂应用、组件功能多、样式层级多的组件库,并不适合自身使用 tailwind 实现。

在 ant 的适合场景下大部分情况只需要修改颜色(主题)、布局。如果自定义太多样式,会指数级增加维护成本;如果按大部分使用 ant 的场景,不自定义样式,那用 tailwind 也没有太多价值了。

tailwind+react 原子化组件更多还是适合前端落地页以及面向 C 端的后台,或者设计比较好的管理后台:样式和交互优先级高,同时业务组件的复杂度没有那么高。在当前国内大部分 B/C 后台都停留在把数据库按表格展示给客户+使用大表单创建数据这种设计思路下面,其实并不合适。
MrYELiex
11 小时 24 分钟前
#6 指非原子化组件库自身使用 tailwind 实现,使用上通过 tailwind 维护布局配合全局颜色主题还是比较高效的
NewYear
11 小时 15 分钟前
别在 React 里卷啦,太多 UI 库了。

可以看看 VUE 这边啊,这边还很贫瘠,有轮子可以往这个方向造啊。。。。。
red13
11 小时 14 分钟前
我只知道 Material UI ,Metis UI 又是个什么?
importmeta
11 小时 9 分钟前
Tailwind CSS 这种歪门邪道, 我看它哪天亖.
justdoit123
10 小时 27 分钟前
@MrYELiex #6 #7 非常同意你的看法。
mc2tap
10 小时 25 分钟前
和 antd 相比优势在哪儿
zzzzhan
10 小时 19 分钟前
怎么动不动就重新定义啊
azhong123
10 小时 16 分钟前
继续造轮子
TonyG
9 小时 54 分钟前
我的老天爷,你一个人干了整个 arco design 的 UI 麽ლ(′◉❥◉`ლ)

我也在自己做(其实是抄) UI 库,所以我知道有多难,这组件的质感与 arco design 很像,收藏,作为抄袭对象了,谢谢楼主!
googlehub
9 小时 0 分钟前
这种库其实没太大必要继续了,市面上已经有非常标准的库,AI 的时代,后面的组件全部都是 prompt ,一个 prompt 对应一个组件,这种完全是另外一个层面的体验,而且效果还出奇的优秀。比如: https://21st.dev/s/sign-in ,可以参考下。
dufu1991
8 小时 38 分钟前
非常支持,我都已经在计划将 antd 复刻之后按照 Tailwind 写一套,Tailwind 写起来太爽了。后续我有新项目会用你这个,遇到问题和需求也会参与维护。感谢你的付出。
cutchop
8 小时 35 分钟前
claude 收录你了吗
dwu8555
8 小时 35 分钟前
现在都直接用 AI 了
hugozach
8 小时 0 分钟前
这有啥意义 都是拿别人的改一下 我看最早的提交记录里面有 ant-design

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://ex.noerr.eu.org/t/1143726

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX