React
基于 Farm
创建一个 React
项目。
Farm
提供两种方案来支持创建 React
项目:
- 使用
create-farm
脚手架创建脚手架项目 - 你可以根据当前文档手动创建一个
React
项目
创建 React 项目
npm create farm@latest
在 Select Framework
中选择 React
模版
Farm
需要通过注册 @farmfe/plugin-react
插件来对 React
项目进行支持。
farm.config.ts
import { defineConfig } from '@farmfe/core';
export default defineConfig({
plugins: ['@farmfe/plugin-react'],
});
@farmfe/plugin-react
插件由 Rust
编写, 因此你不需要显式引入, 通过传递一个字符串包名即可注册。
集成 emotion
你可以通过注册 @swc/plugin-emotion
插件来对 emotion
进行支持。
farm.config.ts
import { defineConfig } from '@farmfe/core';
export default defineConfig({
compilation: {
script: {
plugins: [
{
name: '@swc/plugin-emotion',
options: {},
filters: {
moduleTypes: ['tsx'],
},
},
],
},
},
plugins: [['@farmfe/plugin-react', { "runtime": "automatic", "importSource": "@emotion/react" }]],
});
src/index.tsx
import { css } from '@emotion/react';
const color = 'white';
export function Main() {
return (
<div
onClick={() => setCount((c) => c + 1)}
css={css`
padding: 32px;
background-color: hotpink;
font-size: 24px;
border-radius: 4px;
&:hover {
color: ${color};
}
`}
>
{a}: {count}
</div>
);
}
集成 svgr
SVGR 是一个用于将 SVG 转换为 React 组件的工具,Farm 提供了 Js 插件来支持 SVGR。
farm.config.ts
import { defineConfig } from '@farmfe/core';
import farmJsPluginSvgr from '@farmfe/js-plugin-svgr';
export default defineConfig(async (env) => {
return {
plugins: [
[
'@farmfe/plugin-react',
{
refresh: process.env.NODE_ENV === 'development',
development: process.env.NODE_ENV === 'development'
}
],
farmJsPluginSvgr()
]
};
});
开发环境时运行
<PackageManagerTabs command="npm run dev" />
在生产环境下进行打包
<PackageManagerTabs command="npm run build" />
预览生产环境打包之后构建的产物
<PackageManagerTabs command="npm run preview" />
如若想查看示例详情: [React 示例](https://github.com/farm-fe/farm/tree/main/examples/react)