百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

阿里开源可跨组件体系的表单配置生成方案,淘宝、天猫都在使用

myzbx 2025-03-05 19:30 15 浏览

FormRender

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




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


Bash
npm i form-render# oryarn add form-render


Bash
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);



PropTypeRequiredDefaultDescription
propsSchemaObject{}表单属性配置 jsonuiSchemaObject{}表单 UI 配置 json(可以合并到 propsSchema)formDataObject{}配置数据onChangeFunction() => {}数据更改回调函数onValidateFunction() => {}表单输入校验回调displayTypeStringcolumn设置表单横向排列或者纵向排序column/rowshowDescIconBooleanfalse描述是否用 tooltip 展示。displayTyperow时建议设为 truereadOnlyBooleanfalse预览模式/可编辑模式labelWidthNumber/String110全局设置 label 长度(默认 110)。数字值单位为 px,也可使用'20%'/'2rem'等widgetsObject{}自定义组件

注 1: 设置表单 displayType 为 row 时候,请设置 showDescIcontrue,隐藏说明,效果会更好注 2: onChange 方法会用于初始化表单 data,如果不写会造成没有初始值的表单元素无法渲染(出现不报错也不显示的情况)注 3: FormRender 默认布局会占满它的父级元素,建议用一个div包裹 FormRender 用于表单布局样式调整



PropTypeusageDefaultDescription
mappingObjectsometimesundefined用于修改默认组件映射表,一般用于让自定义组件作为默认选择(详见自定义组件)columnNumbersometimes1整体布局 1 排 N,局部的 1 排 N 一般使用ui:widthuseLoggerBooleandebugfalse当 useLogger 为 true 时,会在 console 展示所有的 formData 变化 (注 4)nameStringvery rare$form表单的名称showValidateBooleanvery raretrue是否展示校验信息onMountFunctionvery rareundefinedonMount 有值时,首次加载时执行 onMount 而不是默认的 onChange。用于定制首次加载行为

注 4: useLogger={true} 时,每当用户填写表单时,在 console 里的展示类似如下:

自下向上一层层展示用户触发的 formData 变化,便于开发者快速定位问题。


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



详见如何在 TypeScript 项目中使用


  • 安装 webpack 插件npm install webpack-plugin-fr-theme --save-dev
  • 配置 webpack.config.js 文件const WebpackPluginFrTheme = require('webpack-plugin-fr-theme');{ ... plugins: [ new WebpackPluginFrTheme(), ], ...}


FormRender 底层引擎用原生 JS 来实现,通过解析 JSON Schema 配置,并支持渲染原生的 HTML 表单,通过 UiSchema 来配置 Widget 组件,在此基础上处理好上层 Ant Design 或 Fusion 组件 Widget 和 Input Format 的对应关系,最后还可以做到无缝接入其他组件体系的好处



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

相关推荐

如何用Java还原童年回忆?在线教你完成贪吃蛇小游戏

今天我就从零开始来完成这个小游戏,完成的方式也是一步一步的添加功能这样的方式来实现。额,不好意思,放错了,重来第一步完成的功能:写一个界面大家见到的贪吃蛇小游戏,界面肯定是少不了的。因此,第一步就是写...

金士顿Canvas Go!Plus microSD卡评测 4K影像轻松驾驭

【ZOL中关村在线原创评测】如今,视频已经成为社交媒体的主流内容传播形式,全民自媒体时代更是让昔日被视为高端、专业的视频拍摄,走进大众的生活。同时,无人机、运动相机等新世代影像设备也已经支持了4K视频...

国外顶尖教程大师教你设计一个炫酷游戏海报...

今天的教程很实用,我想对于做网页设计的童鞋肯定非常想学会用Photoshop的合成技巧来制作高端的游戏网站我们将用很多素材和照片来合成一个场景和一些页头和导航的制作。过程需要很长时间,素材也很多,我自...

Excel 制作贪吃蛇游戏,让你轻松摸鱼!

步骤1:准备工作表1.创建游戏区域:o在单元格区域(如B2:AK30)设置一个矩形区域,调整行高和列宽为正方形(如行高20像素,列宽3字符)。o设置背景色为深色(如黑色),作为游戏画布。2.初...

成长的画布,绘满童趣色彩

在万家丽热闹的脉动中,特步童装是一方柔软的画布,等待孩子们用欢笑与奔跑泼洒斑斓色彩。这里没有生硬的商业气息,每一件衣物都像会呼吸的精灵,悄悄诉说着关于童年的奇妙物语。漫步其中,仿佛踏入一座流动的童话森...

【教育高质量发展】施甸县示范小学:地面为画布 游戏“绘”出精彩童年

近日,施甸县示范小学积极践行“健康第一”教育理念,在寒假前夕,学校美术组教师联合部分师生完成了校园地面游戏彩绘工作。教师们以地面为画布,绘制跳格子、转盘、迷宫等游戏图案,为下学期师生15分钟课间做好了...

《国王的画布》Steam试玩发布 手绘风地图制作工具

HannesBreuer工作室制作并发行,一款手绘风地图制作工具游戏《国王的画布》Steam试玩发布,本作暂不支持中文。《国王的画布》游戏中玩家可以自定义交互式路径生成随机元素,易于调整改动。无需...

怪物收集RPG冒险游戏《妖之乡》7月16日正式发售

今日(6月18日),怪物收集RPG冒险游戏《妖之乡》更新发售日消息,该作将于7月16日发售,游戏试玩Demo现已正式上线,感兴趣的玩家可以进入商店页面。游戏介绍:《妖之乡》是一款东方奇幻的怪物收集R...

208元起,育碧第一人称动作冒险游戏《阿凡达:潘多拉边境》发售

IT之家6月18日消息,育碧旗下第一人称动作冒险游戏《阿凡达:潘多拉边境(Avatar:FrontiersofPandora)》已于今天登陆Steam平台(点此访问),目前本作正在平台...

甜蜜下潜藏的疯狂?和病娇美少女《米塔》在一起的冒险解谜游戏今日发售

由Aihasto开发制作,IndieArk发行的冒险解谜游戏《米塔》在今日上架Steam平台进行发售。售价人民币52元,首发-10%的折扣持续14天,折扣后仅需46.8元。该作同步支持日语和俄语配音...

十大必玩的合作单机游戏排行

合作模式一直是单机游戏中的重要元素,玩家可以和朋友一起组队、配合,共同完成游戏任务。在众多的合作单机游戏中,哪些才是最值得一试的呢?本文将为大家介绍十大必玩的合作单机游戏排行。这些游戏不仅拥有精彩刺激...

原版20周年献礼:《战争机器:重装上阵》游戏8月26日发行

IT之家5月6日消息,微软官方XboxWire博客昨日(5月5日)发布博文,官宣《战争机器:重装上阵》(GearsofWar:Reloaded)游戏,将于2025年8...

十款免费的战斗单机游戏推荐之网络版

这篇文章主要介绍了十款免费的战斗单机游戏,并对它们进行了排行。这些游戏涵盖了不同类型和风格,包括角色扮演、射击、策略等。每款游戏都有详细的介绍和评价,读者可以根据自己的喜好选择适合自己的游戏。对于喜欢...

十大必玩的合作单机游戏:打造完美团队

合作模式一直是单机游戏中的重要元素,玩家可以通过合作来共同完成游戏任务,增加游戏的趣味性和挑战性。在本文中,我们将为您介绍十大必玩的合作单机游戏。这些游戏不仅拥有精彩刺激的剧情和画面,还提供了多种合作...

十款好玩的战斗单机游戏:哪个更好玩

战斗单机游戏一直是玩家们的最爱,而好玩的战斗单机游戏更是备受期待。在众多的战斗单机游戏中,哪些更好玩呢?本文将为您介绍十款备受好评的战斗单机游戏,并进行详细比较分析。无论您是喜欢动作还是策略,都能在这...