基于react hooks+ts且支持事件处理、状态管理及动态渲染 JSX 的自定义表单工具发布啦

注释:此文章转自于 https://juejin.cn/post/7065122173026828302/

去年本人发布一个基于 Vue 3.0 + TS 的自定义表单插件(原文链接)。得到了不少掘友的肯定。当然也提出了不少的问题、优化与新的需求。以及也有很多小伙伴问有没有 React 的版本,我就基于 React + TS 做了一版 React 版的自定义表单插件,当然这次做的 React 版本里带来了很多全新的功能以及特性,目前刚做好初版,先做个简单介绍,对于有这方面需求的小伙伴可以在线 demo 体验一下。

react-from-create

基于 React + TS 的自定义表单生成器。主要用于动态页面渲染、页面个性化、动态表单等功能。 支持 npm 与 cdn 引入的方式。

特性

  • 丰富的组件(包含 antd 绝大部分组件)
  • 灵活布局
  • 远端数据获取
  • 自定义样式
  • 自定义 Class
  • 状态管理
  • 事件处理
  • 生命周期管理
  • 表单控制
  • 动态渲染 JSX

示例地址(Github)

https://fuchengwei.github.io/react-form-create-base/src/example/index.html

示例地址(Gitee)

http://fuchengwei.gitee.io/react-form-create-base

Github

https://github.com/fuchengwei/react-form-create-base

npm

https://www.npmjs.com/package/react-form-create

特性演示

  • 自定义样式
  • 自定义 Class

自定义样式&自定义Class

  • 状态管理
  • 事件处理

状态管理&事件管理

  • 动态渲染 JSX

动态渲染JSX

  • 表单控制

表单控制

安装

使用 npm 或 yarn 安装

我们推荐使用 npm 或 yarn 的方式进行开发,不仅可在开发环境轻松调试,也可放心地在生产环境打包部署使用,享受整个生态圈和工具链带来的诸多好处。

$ npm install react-form-create --save
$ yarn add react-form-create --save

浏览器引入

在浏览器中使用 script 标签直接引入文件,并使用全局变量 formCreate

我们在 npm 发布包内的 react-form-create/dist提供了 react-form-create.es.js react-form-create.umd.js style.css。你也可以通过 jsdelivrUNPKG 进行下载。

<script src="https://unpkg.com/react-form-create/dist/react-form-create.umd.js"></script>

注意

  1. 无论 npm 或者 cdn 引入都需要在全局以 CDN 的方式引入 monaco-editor

    <script src="https://unpkg.com/monaco-editor/min/vs/loader.js"></script>
    <script>
       require.config({ paths: { vs: 'https://unpkg.com/monaco-editor/min/vs' } })
       window.MonacoEnvironment = {
         getWorkerUrl: function (workerId, label) {
           return `data:text/javascript;charset=utf-8,${encodeURIComponent(`
             self.MonacoEnvironment = {
               baseUrl: 'https://unpkg.com/monaco-editor/min/'
             };
             importScripts('https://unpkg.com/monaco-editor/min/vs/base/worker/workerMain.js');`)}`
         }
       }
       require(['vs/editor/editor.main'], function () {})
     </script>
    
  2. cdn 引入 ant-design 需要自行引入 moment 以及 babel-standalone

  3. 动态 Props 中的属性同 antd 组件的所有属性一致,有更灵活的属性配置可以使用动态 Props。

  4. 动态 Props、FormItemProps 和动作设置中都可以全局访问到 formInstance(表单实例属性)、state(全局 state 对象)、dispatch(更新 state 的方法)以及 antd(包括 antd 所有的组件以及全局方法(message、notification 等))

示例

npm 引入

import React from 'react'
import ReactDOM from 'react-dom'
import { DesignForm } from 'react-form-create'
import 'antd/dist/antd.css'
import 'react-form-create/dist/style.css'

ReactDOM.render(
  <React.StrictMode>
    <DesignForm />
  </React.StrictMode>,
  document.getElementById('root')
)

浏览器引入

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <link rel="stylesheet" href="https://unpkg.com/antd/dist/antd.min.css" />
    <link rel="stylesheet" href="https://unpkg.com/react-form-create/dist/style.css" />
    <script src="https://unpkg.com/react/umd/react.production.min.js"></script>
    <script src="https://unpkg.com/react-dom/umd/react-dom.production.min.js"></script>
    <script src="https://unpkg.com/moment/moment.js"></script>
    <script src="https://unpkg.com/antd/dist/antd.min.js"></script>
    <script src="https://unpkg.com/babel-standalone"></script>
    <script src="https://unpkg.com/react-form-create/dist/react-form-create.umd.js"></script>
    <script src="https://unpkg.com/monaco-editor/min/vs/loader.js"></script>
    <script>
      require.config({
        paths: { vs: 'https://unpkg.com/monaco-editor/min/vs' }
      })
      window.MonacoEnvironment = {
        getWorkerUrl: function (workerId, label) {
          return `data:text/javascript;charset=utf-8,${encodeURIComponent(`
            self.MonacoEnvironment = {
              baseUrl: 'https://unpkg.com/monaco-editor/min/'
            };
            importScripts('https://unpkg.com/monaco-editor/min/vs/base/worker/workerMain.js');`)}`
        }
      }
      require(['vs/editor/editor.main'], function () {})
    </script>
  </head>
  <body>
    <div id="root"></div>
    <script type="text/babel">
      ReactDOM.render(<DesignForm />, document.getElementById('root'))
    </script>
  </body>
</html>

组件说明

表单设计器(DesignForm)

示例
import React, { useRef } from 'react'
import { DesignForm, DesignFormRef } from 'react-form-create'
import 'antd/dist/antd.css'
import 'react-form-create/dist/style.css'

export default () => {
  const ref = useRef<DesignFormRef>(null)

  return <DesignForm ref={ref} />
}
API
Props
参数说明类型默认值
preview设计器预览操作按钮booleantrue
generateCode设计器生成代码按钮booleantrue
generateJson设计器生成 Json 按钮booleantrue
uploadJson设计器导入 JSON 按钮booleantrue
clearable设计器清空按钮booleantrue
方法

通过 ref 可以获取到实例并调用实例方法

方法名说明参数
getJson()获取设计器配置的 JSON 数据-
setJson(value)设置设计器的配置信息通过 getJson 获取的数据
clear()清空设计器
getTemplate(type)获取设计器生成的可以直接使用的代码type 的类型为 ‘component’ 或 ‘html’

表单生成器(GenerateForm)

示例
import React, { useRef } from 'react'
import { GenerateForm, GenerateFormRef } from 'react-form-create'
import 'antd/dist/antd.css'
import 'react-form-create/dist/style.css'

export default () => {
  const ref = useRef<GenerateFormRef>(null)

  return <GenerateForm widgetInfoJson="表单设计器生成的 JSON" ref={ref} />
}
API
Props
参数说明类型默认值
widgetInfoJson表单 json 配置数据(从表单设计器获取的 json)string-
formValue表单数据(从表单生成器获取的 value)object-
方法

通过 ref 可以获取到实例并调用实例方法

方法名说明参数
getData()获取表单数据(返回 Promise)-
reset()重置表单数据-

功能说明

远端数据

单选框,多选框,下拉选择框、级联选择器等选择项需要通过数据生成,这时可以配置远端数据。

设置远端方法地址与返回值。

远端数据

文件上传

填写服务器上传地址、参数名等配置信息。

文件上传

页面生命周期管理

React 页面渲染生命周期函数

生命周期

全局使用 antd 中 Message、Notification、Modal 方法

在组件事件、生命周期、动态 Props 中都可以使用 antd.xxx 来调用 antd 的方法或者组件

全局antd

后续规划

对于使用 vue-form-create 的小伙伴不用着急,后续一两个月我会优先把现有的功能全部移植到 vue 的版本中。当然也会加入富文本、图表等更多常用功能。

目前是第一版 详细的文档还需要时间来编写 如果你有更好的建议、需求或者使用中有任何问题可以提 issues 或者加微信沟通 fuchengwei325795

最后如果大家觉得还不错的话,麻烦给个 Star 。

(PS:)目前免费开源的是基础版本,有高级版或高级源码版需要的可加微信 fuchengwei325795

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值