README.md

    FormRender

    npm GitHub last commit NPM downloads NPM all downloads GitHub closed issues PRs Welcome

    通过 JSON Schema 生成标准 Form,常用于自定义搭建配置界面生成

    了解

    效果

    优势

    • 如上图,使用 Schema 编辑器 快速生成可实现低上手成本、快速搭建
    • 支持 Ant Design 和 Fusion Design 主流的视觉主题
    • 使用 JSON Schema 标准协议描述表单配置,并搭配丰富类型且可扩展的组件
    • 支持 1 排 N、横纵排、支持对象无限嵌套、自定义正则校验、自定义样式组件、列表拖拽等特性
    • 已在阿里云、淘宝、天猫、飞猪、亚博科技、安全智能、新零售行业工作台、人工智能实验室、安全智能部门等多 BU 多场景使用,简单使用同时支持复杂场景使用
    • 使用上有详细文档,维护上有专人支持

    安装

    npm i form-render
    # or
    yarn add form-render

    快速使用

    import React, { useState } from 'react';
    import ReactDOM from 'react-dom';
    // 使用 Ant Design 体系
    import FormRender from 'form-render/lib/antd';
    // 使用 Fusion Design 体系
    // import FormRender from "form-render/lib/fusion";
    
    const schema = {
      type: 'object',
      properties: {
        string: {
          title: '字符串',
          type: 'string',
          'ui:disabled': true,
        },
        select: {
          title: '单选',
          type: 'string',
          enum: ['a', 'b', 'c'],
          enumNames: ['', '', ''],
          'ui:width': '50%', // uiSchema 合并到 schema 中(推荐写法,书写便捷)
        },
      },
    };
    
    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 (
        <div style={{ maxWidth: 600 }}>
          <FormRender
            schema={schema}
            formData={formData}
            onChange={setData}
            onValidate={setValid}
            displayType="row" // 详细配置见下
          />
          <button onClick={onSubmit}>提交</button>
        </div>
      );
    }
    
    export default Demo;

    API

    Prop Type Required Default Description
    schema Object {} 详见 schema 配置
    uiSchema Object {} 详见 uiSchema 配置一般建议合并到 schema
    formData Object {} 配置表单数据
    onChange Function () => {} 数据更改回调函数
    onValidate Function () => {} 表单输入校验回调
    displayType String column 设置表单横向排列或者纵向排序column/row
    showDescIcon Boolean false 描述是否用 tooltip 展示。displayTyperow时建议设为 true
    readOnly Boolean false 预览模式/可编辑模式
    labelWidth Number / String 110 全局设置 label 长度(默认 110)。数字值单位为 px,也可使用'20%'/'2rem'等
    widgets Object {} 自定义组件

    注 1: 设置表单 displayType 为 row 时候,请设置 showDescIcontrue,隐藏说明,效果会更好

    注 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 变化
    name String very rare $form 表单的名称
    showValidate Boolean very rare true 是否展示校验信息
    onMount Function very rare undefined onMount 有值时,首次加载时执行 onMount 而不是默认的 onChange。用于定制首次加载行为

    详见“不常用 props”

    更多使用

    • vscode 插件:快速准确书写 schema 一直是使用者的痛点,为此我们准备了 schema 书写利器: form-render snippets(vscode 插件),在 vscode 商店输入 ‘formrender’

    • 支持 TypeScript:详见如何在 TypeScript 项目中使用

    • 支持 Ant Design 自定义主题不被覆盖

      • 安装 webpack 插件

        npm install webpack-plugin-fr-theme  --save-dev
      • 配置 webpack.config.js 文件

        const WebpackPluginFrTheme = require('webpack-plugin-fr-theme');
        
        {
            ...
            plugins: [
              new WebpackPluginFrTheme(),
            ],
            ...
        }

    调试

    > git clone https://github.com/alibaba/form-render.git
    > npm i
    > npm start

    支持

    • 在公司或个人项目中使用 FormRender,关注 Changelog

    • 如果你觉得 FormRender 还不错,可以通过 Star 来表示你的喜欢

    • 加入钉钉聊天群帮忙解答使用问题

    贡献

    想贡献代码、解 BUG 或者提高文档可读性?非常欢迎一起参与进来,在提交 MR 前阅读一下 Contributing Guide

    感谢给 FormRender 贡献代码的你们,以及 JetBrains 提供 Free 使用!

    协议

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

    项目简介

    🚀 Github 镜像仓库 🚀

    源项目地址

    https://github.com/alibaba/form-render

    发行版本

    当前项目没有发行版本

    贡献者 40

    全部贡献者

    开发语言

    • JavaScript 76.7 %
    • TypeScript 11.5 %
    • Less 8.7 %
    • CSS 3.1 %
    • Shell 0.0 %