1、安装 Semi
# 使用 npm npm i @douyinfe/semi-ui # 使用 yarn yarn add @douyinfe/semi-ui # 使用 pnpm pnpm add @douyinfe/semi-ui
2、使用组件
在 Webpack、create-react-app 或 Vite 项目中使用时,无需进行任何编译项配置,直接使用即可。构建时所有相关资源均会按需打包。
import React, { Component } from 'react'; import { Button, Toast } from '@douyinfe/semi-ui'; class Demo extends React.Component { constructor() { super(); } render() { return <Button onClick={() => Toast.warning({ content: 'welcome' })}>Hello Semi</Button>; } }
推荐在项目中引入 reset.css,它可以重置浏览器自带的默认样式,避免不同UA之间的样式差异。
3、在 NextJs 中使用
如果仅使用默认主题, 在
transpilePackages
追加 Semi 相关的 package即可 (Next.js 版本要求 >= v13.1 )
// next.config.js const nextConfig = { + transpilePackages: ['@douyinfe/semi-ui', '@douyinfe/semi-icons', '@douyinfe/semi-illustrations'], }; module.exports = nextConfig;
如果需要使用定制主题包或 Next.js版本低于 v13.1,则需要配合 Semi 提供的编译插件
@douyinfe/semi-next
插件使用首先安装插件
npm i @douyinfe/semi-next
(如果你使用 yarn 或 pnpm,请自行更换为对等命令)在 next.config.js 中进行配置,插件会将组件默认的import CSS 语句移除。更多配置可查阅
@douyinfe/semi-next
详细文档在
global.css
中引入全量的 semi css(目前在 Next.js 中不支持按需引入)
// next.config.js const semi = require('@douyinfe/semi-next').default({ /* the extension options */ }); module.exports = semi({ // your custom Next.js configuration });
/* styles/globals.css */ @import '~@douyinfe/semi-ui/dist/css/semi.min.css';
如何在 Next.js 中使用主题包
你需要更换 globals.css 中 import 语句的路径,将默认主题 CSS 产物更换为你定制的主题包中的 CSS 产物,例如当希望应用抖音创作服务平台的主题包
你需要更换 globals.css 中 import 语句的路径,将默认主题 CSS 产物更换为你定制的主题包中的 CSS 产物,例如当希望应用抖音创作服务平台的主题包
@semi-bot/semi-theme-doucreator
时/* styles/globals.css */ @import '~@semi-bot/semi-theme-doucreator/semi.min.css';
4、在 Remix 中使用
- @remix相关包版本要求 > 1.11.0,并安装
@remix-run/css-bundle
- 配置
remix.config.js
,参考 Remix Css Side-Effect Imports。打开unstable_cssSideEffectImports
开关,并将 Semi 相关包配置在serverDependenciesToBundle
中。
// remix.config.js module.exports = { future: { + unstable_cssSideEffectImports: true, }, serverDependenciesToBundle: [ + /^@douyinfe\/semi-ui/, + /^@douyinfe\/semi-icons/, + /^@douyinfe\/semi-illustrations/, ], };
在
root.tsx
中进行配置,参考Remix CSS Bundling。引入cssBundleHref
,并配置links
// root.tsx + import { cssBundleHref } from "@remix-run/css-bundle"; export const links = () => { return [ + ...(cssBundleHref ? [{ rel: "stylesheet", href: cssBundleHref }] : []), ]; };
完成配置,可以正常使用 Semi 相关组件
如何在 Remix 中使用主题包
可以直接将 cssBundleHref 这一步替换为引入主题包中已构建好的全量css 产物,代替默认主题css),例如当希望应用抖音创作服务平台的主题包
可以直接将 cssBundleHref 这一步替换为引入主题包中已构建好的全量css 产物,代替默认主题css),例如当希望应用抖音创作服务平台的主题包
@semi-bot/semi-theme-doucreator
时// root.tsx + import ThemeStyle from "@semi-bot/semi-theme-doucreator/semi.min.css"; export const links = () => { return [ - ...(cssBundleHref ? [{ rel: "stylesheet", href: cssBundleHref }] : []), + { rel: "stylesheet", href: ThemeStyle }, ]; };
5、UMD 方式使用组件
我们并不推荐直接使用已构建文件,这样会全量引入所有组件,无法实现按需加载。但如果确实有非构建场景的需求,可以通过以下方式引用
在浏览器中使用 script 和 link 标签直接引入文件,并使用全局变量
SemiUI
、SemiIcons
、SemiIllustrations
1、 请确保你已提前引入 react 以及 react-dom
2、 引入 JS 文件,以下示例 URL 中 2.27.0 为 version 标识,希望使用不同版本 Semi 时,将 version 中对应的值替换即可
2、 引入 JS 文件,以下示例 URL 中 2.27.0 为 version 标识,希望使用不同版本 Semi 时,将 version 中对应的值替换即可
资源 | URL |
---|---|
semi-ui (min) | https://unpkg.com/@douyinfe/semi-ui@2.27.0/dist/umd/semi-ui.min.js |
semi-icons (min) | https://unpkg.com/@douyinfe/semi-icons@latest/dist/umd/semi-icons.min.js |
semi-illustrations (min) | https://unpkg.com/@douyinfe/semi-illustrations@latest/dist/umd/semi-illustrations.min.js |
semi-ui (normal) | https://unpkg.com/@douyinfe/semi-ui@2.27.0/dist/umd/semi-ui.js |
semi-icons (normal) | https://unpkg.com/@douyinfe/semi-icons@latest/dist/umd/semi-icons.js |
semi-illustrations (normal) | https://unpkg.com/@douyinfe/semi-illustrations@latest/dist/umd/semi-illustrations.js |
3、 引入 Semi 默认主题的 CSS 样式文件
资源 | URL |
---|---|
semi.css | https://unpkg.com/@douyinfe/semi-ui@2.27.0/dist/css/semi.css |
semi-icons.css | https://unpkg.com/@douyinfe/semi-icons@latest/dist/css/semi-icons.css |
<!DOCTYPE html> <html lang="zh-cn"> <head> <script src=" + <script crossorigin src=" + <script crossorigin src=" + <script src=" + <link rel="stylesheet" href=" + <script src=" + <link rel="stylesheet" href=" + <script src="https://unpkg.com/@douyinfe/semi-illustrations@latest/dist/umd/semi-illustrations.min.js"></script> </head> <body> <div id="root"></div> </body> </html>
<script type="text/babel"> const { Input, Button, Toast, Icon, Form } = SemiUI; const { IconHome } = SemiIcons; const { IllustrationConstruction } = SemiIllustrations; ReactDOM.render( <div> <Button onClick={() => Toast.warning({ duration: 0, content: 'Semi Design' })}>test</Button> <Input defaultValue="semi" onChange={value => Toast.info('hello semi')}></Input> <IconHome size="large" /> <IllustrationConstruction style={{ width: 150, height: 150 }} /> </div>, document.getElementById('root') ); </script>;