# form-render
**Repository Path**: vincentjava/form-render
## Basic Information
- **Project Name**: form-render
- **Description**: 🚴♀️ 易用的跨组件体系的表单渲染引擎 - 通过 JSON Schema 快速生成自定义表单配置界面
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 7
- **Forks**: 4
- **Created**: 2020-06-28
- **Last Updated**: 2024-07-19
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# FormRender
[](https://www.npmjs.com/package/form-render?_blank)
[](https://github.com/alibaba/form-render/commits/dev)
[](https://npmjs.org/package/form-render)
[](https://npmjs.org/package/form-render)
[](https://github.com/alibaba/form-render/issues?utf8=%E2%9C%93&q=)

> 通过 JSON Schema 生成标准 Form,常用于自定义搭建配置界面生成
## 了解
- 文档官网
- schema 编辑器
- Playground / Code Sandbox
- 常见场景
- Proptypes to Json Schema
- 更新日志
- 后期规划
## 效果
## 优势
 |  |
- 如上图,使用 [Schema 编辑器](https://form-render.github.io/schema-generator/) 快速生成可实现低上手成本、快速搭建
- 支持 Ant Design 和 Fusion Design 主流的视觉主题
- 使用 JSON Schema 标准协议描述表单配置,并搭配丰富类型且可扩展的组件
- 支持 1 排 N、横纵排、支持对象无限嵌套、自定义正则校验、自定义样式组件、列表拖拽等特性
- 已在阿里云、淘宝、天猫、飞猪、亚博科技、安全智能、新零售行业工作台、人工智能实验室、安全智能部门等多 BU 多场景使用,简单使用同时支持复杂场景使用
- 使用上有详细文档,维护上有专人支持
## 安装
```sh
npm i form-render
# or
yarn add form-render
```
## 快速使用
```js
import React, { useState } from 'react';
import ReactDOM from 'react-dom';
// 使用 Ant Design 体系
import FormRender from 'form-render/lib/antd';
// 使用 Fusion Design 体系
// import "@alifd/next/dist/next.min.css";
// import FormRender from "form-render/lib/fusion";
const propsSchema = {
type: 'object',
properties: {
string: {
title: '字符串',
type: 'string',
'ui:width': '50%', // uiSchema 可以合并到 propsSchema 中(推荐写法,书写便捷)
},
select: {
title: '单选',
type: 'string',
enum: ['a', 'b', 'c'],
},
},
};
// 也可以选择单独使用 uiSchema 字段分开定义所有的 ui 属性,适用于遵循 json schema 的团队无缝接入
const uiSchema = {
select: {
'ui:disabled': true,
},
};
function Demo() {
const [formData, setData] = useState({});
const [valid, setValid] = useState([]);
const onSubmit = () => {
// valid 是校验判断的数组,valid 长度为 0 代表校验全部通过
if (valid.length > 0) {
alert(`校验未通过字段:${valid.toString()}`);
} else {
alert(JSON.stringify(formData, null, 2));
}
};
return (
);
}
const rootElement = document.getElementById('root');
ReactDOM.render(, rootElement);
```
### API
| Prop | Type | Required | Default | Description |
| ---------------- | :-----------: | :------: | :------: | :--------------------------------------------------------------------: |
| **propsSchema** | Object | ✓ | {} | 表单属性配置 json |
| **uiSchema** | Object | | {} | 表单 UI 配置 json(可以合并到 propsSchema) |
| **formData** | Object | | {} | 配置数据 |
| **onChange** | Function | ✓ | () => {} | 数据更改回调函数 |
| **onValidate** | Function | | () => {} | 表单输入校验回调 |
| **displayType** | String | | column | 设置表单横向排列或者纵向排序`column`/`row` |
| **showDescIcon** | Boolean | | false | 描述是否用 tooltip 展示。`displayType`为 `row`时建议设为 `true` |
| **readOnly** | Boolean | | false | 预览模式/可编辑模式 |
| **labelWidth** | Number/String | | 110 | 全局设置 label 长度(默认 110)。数字值单位为 px,也可使用'20%'/'2rem'等 |
| **widgets** | Object | | {} | 自定义组件 |
**注 1:** 设置表单 `displayType` 为 row 时候,请设置 `showDescIcon` 为 `true`,隐藏说明,效果会更好
**注 2:** **onChange** 方法会用于初始化表单 data,如果不写会造成没有初始值的表单元素无法渲染(出现不报错也不显示的情况)
**注 3:** FormRender 默认布局会占满它的父级元素,建议用一个`div`包裹 FormRender 用于表单布局样式调整
### 不常用 API
| Prop | Type | usage | Default | Description |
| ------------------ | :-------: | :-------: | :-------: | :--------------------------------------------------------------------------------: |
| **`mapping`** | `Object` | sometimes | undefined | 用于修改默认组件映射表,一般用于让自定义组件作为默认选择(详见自定义组件) |
| **`column`** | `Number` | sometimes | 1 | **整体**布局 1 排 N,局部的 1 排 N 一般使用`ui:width` |
| **`useLogger`** | `Boolean` | debug | false | 当 useLogger 为 true 时,会在 console 展示所有的 formData 变化 (注 4) |
| **`name`** | `String` | very rare | \$form | 表单的名称 |
| **`showValidate`** | `Boolean` | very rare | true | 是否展示校验信息 |
| **onMount** | Function | very rare | undefined | onMount 有值时,首次加载时执行 onMount 而不是默认的 onChange。用于定制首次加载行为 |
**注 4:** `useLogger={true}` 时,每当用户填写表单时,在 console 里的展示类似如下:
自下向上一层层展示用户触发的 formData 变化,便于开发者快速定位问题。
## 更多使用
- vscode 插件:快速准确书写 schema 一直是使用者的痛点,为此我们准备了 schema 书写利器: `form-render snippets`(vscode 插件),在 vscode 商店输入 ‘formrender’
- 支持 TypeScript:详见[如何在 TypeScript 项目中使用](docs/typescript)
- **支持 Ant Design 自定义主题不被覆盖**
- 安装 webpack 插件
```bash
npm install webpack-plugin-fr-theme --save-dev
```
- 配置 webpack.config.js 文件
```js
const WebpackPluginFrTheme = require('webpack-plugin-fr-theme');
{
...
plugins: [
new WebpackPluginFrTheme(),
],
...
}
```
## 调试
```shell
> git clone https://github.com/alibaba/form-render.git
> npm i
> npm start
```
## 支持
- 在公司或个人项目中使用 FormRender,关注 Changelog
- 如果你觉得 FormRender 还不错,可以通过 Star 来表示你的喜欢
- 加入钉钉聊天群帮忙解答使用问题
## 贡献
想贡献代码、解 BUG 或者提高文档可读性?非常欢迎一起参与进来,在提交 MR 前阅读一下 [Contributing Guide](https://github.com/alibaba/form-render/blob/master/CONTRIBUTING.md)
感谢给 FormRender 贡献代码的你们,以及 JetBrains 提供 Free 使用!

## 协议
- 遵循 MIT 协议
- 请自由地享受和参与开源