← 返回
开发者工具

钉钉宜搭开发助手

钉钉宜搭低代码开发助手。用于创建表单和自定义页面、编写 JS 动作面板、使用 JS-API、配置数据源、设计流程自动化。适用于宜搭表单开发、JS 代码调试、API 集成等场景。
钉钉宜搭低代码开发助手。用于创建表单和自定义页面、编写 JS 动作面板、使用 JS-API、配置数据源、设计流程自动化。适用于宜搭表单开发、JS 代码调试、API 集成等场景。
yize yize 来源
开发者工具 clawhub v1.0.1 1 版本 99889.9 Key: 无需
★ 2
Stars
📥 867
下载
💾 225
安装
1
版本
#latest

概述

⚠️ 重要:宜搭开发模式

与传统前端不同,宜搭有独特的开发模式:

  1. 页面不是代码写的 - 页面通过宜搭可视化拖拽创建,不是 JSX/HTML 声明
  2. 不要写组件声明代码 - ❌ 禁止 import Button、❌ 禁止 const Page = () => {...}
  3. 只有 JS 动作面板 - 宜搭的 JS 代码是"动作面板",只能写函数,不能写组件
  4. 组件通过 fieldId 引用 - 使用 this.$('textField_xxx') 操作已存在的组件

组件 fieldId 命名规范

宜搭组件的 fieldId 格式为:组件类型_随机后缀

组件类型fieldId 示例
----------------------
单行文本textField_m2iqeyip
多行文本/文本域textareaField_lu7rqky5
单选radioField_m2l8tqxr
流水号serialNumberField_lr76bpi4
数字numberField_mbhl6h58
下拉选择selectField_mbhjt4zb
日期dateField_ll0bcdf1
附件attachmentField_mbhjt4zd
图片imageField_mbhjt4zl
人员选择employeeField_mbhjt4zr
人员多选employeeField_xxx + multiple: true
部门选择departmentSelectField_lu7qx4i5
子表单/明细表tableField_mbhjt4zy
地址addressField_mbhjt508
关联表单associationFormField_mbhjt50s
区块pageSection_m2vthls5
按钮button_invoiceAdd
发票组件ccInvoiceFieldComponentView_m2vv4aux
多列布局columnsLayout_m2k6t8hx
标签页tabsLayout_lkcfmpjv

常见开发模式

条件显示

  • 组件属性 → 高级 → 是否渲染 → 绑定变量 state.sta
  • 或 JS 设置:this.$('fieldId').setBehavior('HIDDEN')

事件函数命名

  • export function onChange({ value }) { } - 值变化事件
  • export function didMount() { } - 页面加载完成

setTimeout 延迟

宜搭组件 onChange 事件中修改状态需要延迟:

export function onChange({ value }) {
  setTimeout(() => {
    this.setState({ sta: value === '价款合同' })
  }, 200)
}

隐藏字段

组件属性中设置 behavior: "HIDDEN" 可隐藏字段(可用于数据传递)

只读字段

组件属性中设置 behavior: "READONLY" 可设为只读

公式字段

在组件属性中设置 valueType: "formula" + formula: "#{textField_xxx}"

{
  "valueType": "formula",
  "formula": "CONCATENATE(\"XMBH\",TEXT(TODAY(),\"yyMMdd\"),MID(TEXT(TIMESTAMP(NOW())),9,5))"
}

TableField 事件

新增行时获取行数:

export function onAddClick(newGroupId) {
  const count = this.$('tableField_xxx').getValue().length
  this.$('textField_count').setValue(count + '条')
}

TableField onChange 计算不重复值

遍历子表单行,计算某列的不重复值数量:

export function onChange({ value, extra }) {
  const subFormInst = this.$('tableField_xxx')
  const items = subFormInst.getItems()
  let distinctNum = []
  items.forEach(item => {
    const rowData = subFormInst.getItemValue(item)
    if (rowData['textField_col'] && !distinctNum.includes(rowData['textField_col'])) {
      distinctNum.push(rowData['textField_col'])
    }
  })
  this.$('numberField_count').setValue(distinctNum.length)
}

EmployeeField onChange

人员选择变化时获取人员信息:

export function onChange({ value }) {
  // value 是人员对象 { name, userId, ... }
  this.$('textField_name').setValue(value.name)
}

PageSection 区块

用于分组显示,有标题头:

{
  "componentName": "PageSection",
  "props": {
    "title": { "zh_CN": "基本信息" },
    "behavior": "NORMAL",  // 或 "HIDDEN" 隐藏整个区块
    "showHeader": true
  }
}

关联表单数据填充

选择关联表单时自动填充其他字段:

{
  "dataFillingRules": [
    { "sourceType": "SelectField", "targetType": "TextField", "source": "selectField_src", "target": "textField_target" }
  ]
}

联动字段

设置 valueType: "linkage" + linkage 属性从其他表单获取数据

SUM 汇总公式

汇总子表单某列:

{
  "valueType": "formula",
  "formula": "SUM(#{numberField_column})"
}

RadioField 联动

单选切换时显示/隐藏字段(配置选项的联动规则)

onBlur 事件

失焦时执行校验(如手机号验证):

export function onBlur() {
  let phone = this.$('textField_xxx').getValue()
  if (!phone) return
  if (!this.isPhoneNumber(phone)) {
    this.utils.toast({ title: '请输入正确的手机号', type: 'warning' })
    this.$('textField_xxx').setValue('')
  }
}

export function isPhoneNumber(input) {
  return /^1\d{10}$/.test(input.replace(/\D/g, ''))
}

NumberField 校验

设置 minValue 最小值:

{ "validation": [{ "type": "minValue", "param": "0" }] }

组件属性参考

SelectField 下拉选择

属性说明类型默认值
-----------------------
dataSource选项数据DataSource[][]
onChange值变化事件(value: string) => void-
showSearch展开后能搜索booleantrue
filterLocal本地过滤boolean-
modesingle/multistringsingle
hasClear清除按钮booleantrue
autoWidth菜单对齐booleantrue

TableField 明细表

属性说明类型默认值
-----------------------
onChange值变化事件({value, extra}) => void-
onAddClick新增行事件(newGroupId) => void-
onDelClick删除行事件(groupId, item) => void-
maxItems最大条数number50
addButtonPosition新增位置'top' \'bottom'bottom
layoutSetting.layout排列方式'TILED' \'TABLE'TABLE
layoutSetting.theme主题'zebra' \'split' \'border'split
showIndex显示序号booleantrue

TableField JS 操作

const table = this.$('tableField_xxx')
table.getValue()           // 获取所有行数据
table.getItems()           // 获取行实例数组
table.getItemValue(item)   // 获取某行数据
table.addItem()            // 新增一行
table.removeItem(item)    // 删除一行

NumberField

属性说明类型默认值
-----------------------
precision小数位数 (0-20)number0
thousandsSeparators千分位booleanfalse
innerAfter单位string-
innerBefore前缀string-

RadioField

属性说明类型默认值
-----------------------
dataSource选项DataSource[][]
onChange值变化(value) => void-
shape形状'default' \'button'default
itemDirection排列'hoz' \'ver'hoz
supportInverse反选booleanfalse

ColumnsLayout 多列布局

属性说明类型默认值
-----------------------
layout分栏配置string'6:6'
columnGap列间距number0
rowGap行间距number0
display手机排列'VERTICAL' \'HORIZONTAL'VERTICAL

布局格式: 2:2:2:2:4 (总和=12), 多行: 4:4:4\|6:6

Button 按钮

属性说明类型默认值
-----------------------
type按钮类型'primary'\'normal'\'secondary'primary
content按钮文案string按钮
size尺寸'small'\'medium'\'large'medium
behavior显示状态'NORMAL'\'DISABLED'\'HIDDEN'NORMAL
loading加载状态booleanfalse

Icon 图标

属性说明类型默认值
-----------------------
baseType基础图标stringsmile
size尺寸'xxs'\'xs'\'small'\'medium'\'large'medium
useType使用自定义booleanfalse

EmployeeField 人员选择

属性说明类型默认值
-----------------------
multiple多选booleanfalse
showEmplId显示工号booleanfalse
showAvater显示头像booleantrue
closeOnSelect选中后关闭booleanfalse
onChange值变化({value}) => void-

DateField 日期选择

属性说明类型默认值
-----------------------
format日期格式stringYYYY-MM-DD
type限制范围'none'\'beforeToday'\'afterToday'none
hasClear清除按钮booleantrue
returnType返回类型'timestamp'\'string'\'moment'timestamp
onChange值变化({value}) => void-

TextField 单行输入

属性说明类型默认值
-----------------------
validationType格式'text'\'mobile'\'email'\'chineseID'text
maxLength字数上限number200
hasClear清除按钮booleantrue
hasLimitHint计数器booleanfalse
trim去空格booleanfalse
onChange值变化({value}) => void-

TextareaField 多行输入

属性说明类型默认值
-----------------------
rows行数number4
autoHeight自动高度booleanfalse
maxLength字数上限number-

USER() 公式

人员字段自动填充当前登录人:

{ "valueType": "formula", "formula": "USER()" }

关联表单数据过滤

设置 dataFilterRules 过滤可选数据

页面级校验器

在页面属性 → 数据校验 中配置,检测重复数据:

{
  "displayRule": "EXIST(角色名称)",
  "rule": "EXIST(#{formUuid}, \"textField_lenz6y7q\", #{textField_lenz6y7q})",
  "message": "角色名称不能重复"
}

## 核心概念

### 全局变量 (State)
类似 React state,用于页面全局状态管理:
- 创建:在数据源面板 → 添加变量
- 读取:`this.state.name` 或 `state.name`(变量绑定时)
- 更改:`this.setState({ name: 'Jack' })`
- 特殊变量:`urlParams` - 获取 URL 参数

⚠️ 注意:setState 后可立即获取新值(不同于 React),但无回调函数

### 远程数据源
配置远程 API 进行异步请求:

// 手动加载

this.dataSourceMap.apiName.load({ params }).then(res => {})

// 重新加载所有自动加载的数据源

this.reloadDataSource()


数据处理函数:
- `willFetch` - 请求发送前修改参数
- `fit` - 响应数据适配
- `didFetch` - 请求成功后的数据处理
- `onError` - 错误处理

### 生命周期

export function didMount() { } // 页面加载完成

export function willUnmount() { } // 页面卸载前


### 事件处理
给组件绑定动作事件,在动作面板实现处理逻辑:

export function onClick() {

const { name, age } = this.params // 获取绑定时设置的参数

}


### 表单校验
内置规则 + 自定义校验函数:

function validateRule(value) {

if (/^杭州/.test(value)) return true

return false

}


手动触发校验:

this.$('textField_xxx').validate((errors, values) => {})


常用校验示例:
- 银行卡号(Luhn算法):16或19位数字
- 身份证号:18位,末尾校验码

### 循环渲染
循环数据要求是数组,绑定变量获取循环数据:
- `this.item` - 获取当前行数据
- `this.index` - 获取当前行索引

容器组件绑定循环数据后可遍历渲染,内部组件通过变量绑定访问数据。

### 条件渲染
组件高级属性 → 是否渲染 → 绑定变量控制显隐

// 绑定 state.xxx 控制显示

state.urlParams.showName // 根据URL参数控制


### 自定义样式
两种方式:
1. 基础样式配置 - 可视化配置布局、文字、背景等
2. 手工编码模式 - CSS 选择器、伪类等

## 名词解释

| 术语 | 说明 |
|------|------|
| 全局变量 | 类似 React state,页面状态管理 |
| 远程 API | HTTP 接口配置,包含请求地址、参数、数据处理函数 |
| Schema | 低代码协议,描述页面/组件结构,类似 HTML |
| 组件唯一标识 | 组件的 fieldId,宜搭全局唯一标识 |
| 页面 | 独立展示界面(表单、报表、自定义页面) |
| 物料 | 可沉淀的前端能力(组件、区块、模板) |
| 业务组件 | 基于基础组件的业务领域组件 |
| 低代码业务组件 | 通过低代码编辑器搭建的业务组件 |
| 区块 | 组合多个组件/布局,可复制复用 |
| 模板 | 垂直业务领域的页面模板 |

## 集成自动化(连接器)

触发类型:
- 表单事件触发 - 提交/流程状态更新
- 定时触发 - 周期循环
- 应用事件触发 - 钉钉生态事件
- Webhook 触发

节点类型:
- 触发器
- 一方连接器(钉钉消息、待办等)
- 自定义连接器
- 数据节点(新增/更新/获取/删除)
- 分支节点(条件分支/并行分支)
- 发起审批
- 消息节点
- 开发者节点(Groovy 脚本)

## 自定义组件

⚠️ 仅限专属版

### 概念
- 普通组件 - 展示型,无数据存储
- 表单组件 - 可提交数据(暂未开放)

### 开发流程
1. 创建组件 - 应用设置 → 组件管理 → 新增组件
2. 开发调试 - 定义属性 + 搭建视图 + 编写逻辑
3. 发布版本 - 开发版(0.1.0) / 正式版(1.x.x)
4. 安装使用 - 选择页面类型安装

### 组件属性 (propTypes)
- 属性类型:文本、布尔、数字、对象、数组、函数、元素
- 设置器:TextSetter、BoolSetter、NumberSetter、JsonSetter、OptionsSetter、ActionSetter、SlotSetter 等

### 组件生命周期

export function componentDidMount() { } // 渲染完成

export function componentDidUpdate() { } // 更新完成

export function componentDidCatch() { } // 错误捕获

export function componentWillUnmount() { } // 销毁前


### 组件内获取属性

this.props.xxx // 获取传入的属性


### 页面中操作自定义组件

this.$('fieldId').get('propName') // 获取属性

this.$('fieldId').set('propName', value) // 设置属性


### 组件联动
添加 function 类型属性作为事件回调,在组件内通过 `this.props.xxx()` 触发

### 注意事项
- fieldId 不能随意修改,会影响公式和存储
- 线上应用请安装正式版本 (1.x.x)
- 不支持删除/卸载组件

## 调试方法

- `debugger` 断点调试
- 浏览器控制台 `cmd/ctrl + p` → `page.js` 添加断点
- URL 加 `?__showDevtools` 打开调试面板
- URL 加 `?__debug` 查看/编辑 Schema
- 移动端调试:引入 vConsole

const vConsole = 'https://g.alicdn.com/code/lib/vConsole/3.11.2/vconsole.min.js';

const js = document.createElement('script');

js.src = vConsole;

document.body.append(js);

js.onload = function() { window.vConsole = new window.VConsole(); };


## API 体系

### 宜搭 JS-API
前端页面调用,包括:
- 全局变量:`this.state.xxx` / `this.setState()`
- 远程数据:`this.dataSourceMap.xxx.load()` / `this.reloadDataSource()`
- 组件操作:`this.$(fieldId).getValue()` / `this.$(fieldId).setValue()`
- 工具类:`this.utils.toast()` / `this.utils.dialog()` / `this.utils.router.push()`
- 校验:`this.$(fieldId).validate()` / `this.$(fieldId).setValidation()`

### 跨应用数据源 API (OpenAPI)
远程数据源配置中调用,用于表单数据操作:
- 新建:`POST /v1/form/saveFormData.json`
- 更新:`POST /v1/form/updateFormData.json`
- 删除:`POST /v1/form/deleteFormData.json`
- 查询:`GET /v1/form/searchFormDatas.json`
- 流程发起:`POST /v1/process/startInstance.json`

### 钉钉 JS-API
需手动加载:`https://g.alicdn.com/dingding/dingtalk-jsapi/2.10.3/dingtalk.open.js`
- 弹框:device.notification.alert/confirm/prompt
- 扫码:biz.util.scan
- 地图:biz.map.locate/view
- 通讯录:biz.contact.choose/complexPicker

### 服务端 OpenAPI
需通过钉钉开放平台调用,需要鉴权:
- 创建钉钉应用 → 添加权限 → 获取 access_token
- 调用服务端接口

## 2026 年新功能

### 2026.02.03 集成自动化升级
- 异常日志支持批量重试
- 日志实例ID交互优化
- 数据节点过滤条件增加"父级条件"
- 新增 AI 节点

### 2026.01.20 新功能
- 宜搭表单新增「钉钉文档」选择组件
- 富文本支持钉钉文档链接自动识别
- 附件/图片支持批量下载
- 关联表单/关联列表支持自定义显示字段

### 2026.01.05 新功能
- 贴一贴:附件上传快捷黏贴(Ctrl+V)
- 实例标题支持变量动态更新
- 数据管理文本筛选动态匹配
- 关联表单数据搜索升级(大小写自动匹配)

## 快速参考

### 组件操作

// ✅ 正确:操作已存在的组件(通过 fieldId)

this.$('textField_m2iqeyip').getValue()

this.$('textField_m2iqeyip').setValue('hello')

// ❌ 错误:不要声明/导入组件

// const MyButton = () => {...} // 禁止!


### 状态管理

this.setState({ key: 'value' })

const value = this.state.key

// URL 参数(默认全局变量)

const param = this.state.urlParams.xxx


### 生命周期

export function didMount() { } // 页面加载完成

export function willUnmount() { } // 页面卸载前


### 远程数据源

this.dataSourceMap.api.load(params).then(res => { })

this.reloadDataSource()


### 常用工具

this.utils.toast({ title: '成功', type: 'success' })

this.utils.router.push('/pageId')

this.utils.getLoginUserId()


## 详细文档

- [JS-API 完整参考](references/js-api.md) - 组件操作、校验、弹窗、路由等
- [故障排查指南](references/troubleshooting.md) - 调试方法、常见问题
- [TodoMVC 入门教程](references/todomvc.md) - 新人入门完整示例

## 调试方法

- URL 加 `?__showDevtools` 打开调试面板
- URL 加 `?__debug` 查看 Schema
- 代码加 `debugger` 断点
- 使用 `console.log` 输出调试信息

## 参考资源

| 资源 | 地址 |
|------|------|
| 帮助中心 | https://docs.aliwork.com/ |
| 开发者中心(前端) | https://developers.aliwork.com/ |
| 开放平台(服务端) | https://open.dingtalk.com/ |
| 示例中心 | https://www.aliwork.com/o/coc |
| 更新日志 | https://docs.aliwork.com/docs/yida_updates |
| OpenAPI | https://developers.aliwork.com/docs/api/openAPI |

## 服务端 OpenAPI (open.dingtalk.com)

需通过钉钉开放平台调用,需要创建应用并获取授权。

### 流程 API
| 接口 | 路径 | 说明 |
|------|------|------|
| 发起审批 | `POST /yida/v1/process/startInstance.json` | processCode, formUuid, formDataJson |
| 删除流程 | `POST /yida/v1/process/delete.json` | processInstanceId |
| 终止流程 | `POST /yida/v1/process/terminate.json` | processInstanceId |
| 查询实例 | `GET /yida/v1/process/getById.json` | processInstanceId |
| 查询实例列表 | `GET /yida/v1/process/getInstanceIds.json` | formUuid, instanceStatus |

### 表单 API (V2)
| 接口 | 路径 | 说明 |
|------|------|------|
| 保存数据 | `POST /yida/v1/forms/saveData.json` | formUuid, formDataJson |
| 更新数据 | `POST /yida/v1/forms/updateData.json` | formInstId, formDataJson |
| 查询数据 | `GET /yida/v1/forms/listData.json` | formUuid, searchFieldJson |
| 获取子表数据 | `GET /yida/v1/forms/listSubTableData.json` | formUuid, formInstId, tableFieldId |

### 请求示例

// 发起流程

const params = {

processCode: "TPROC--CFYJ5HYUN89NJ1JW3IXBI7A95RXM3652O9MKK3",

formUuid: "FORM-CFYJ5HYUN89NJ1JW3IXBI7A95RXM3552O9MKK2",

formDataJson: JSON.stringify({ textField_kkm9o5cd: "123" })

};

this.dataSourceMap.myDatasource.load(params);


### 更多 API
- 批量操作、子表数据、审批记录等详见开放平台文档

## 场景案例专题

### 表单专题
常见表单开发场景:
- 数据权限:只允许查看自己的数据(表单权限设置)
- 子表单:获取子表单值赋值给主表、子表单序号生成、子表单批量导入
- 数据联动:数据源获取主表数据在子表展示、下拉框赋值、关联表单填充
- 校验:子表单重复校验、组件实时校验唯一性、自定义校验
- 高级:图片裁剪上传、扫码识别、地址组件动态类型、公历转农历

### 自定义页面专题
- 页面搭建、组件使用、事件处理

### 连接器专题
- 集成自动化、钉钉消息、待办通知

### 实用工具专题
- 常用工具组件使用

### 报表专题
- 数据可视化、图表配置

### 公式专题
- 公式函数使用、计算逻辑

### 方案专题
- 行业解决方案、业务场景案例

## Schema 生成

宜搭页面使用 JSON Schema 定义,可以直接粘贴到设计器中。

### 基础结构

{

"type": "nodeSchema",

"componentsMap": {},

"componentsTree": [

{

"componentName": "PageSection",

"props": { ... },

"children": [ ... ]

}

]

}


### 常用组件 Schema

#### TextField (单行文本)

{

"componentName": "TextField",

"props": {

"fieldId": "textField_xxxxx",

"label": { "type": "i18n", "zh_CN": "字段名称", "en_US": "字段名称" },

"behavior": "NORMAL",

"valueType": "custom",

"validation": [{ "type": "required" }],

"placeholder": { "type": "i18n", "zh_CN": "请输入", "en_US": "请输入" },

"maxLength": 200,

"visibility": ["PC", "MOBILE"]

}

}


#### NumberField (数字)

{

"componentName": "NumberField",

"props": {

"fieldId": "numberField_xxxxx",

"label": { "type": "i18n", "zh_CN": "金额", "en_US": "金额" },

"precision": 2,

"step": 1,

"behavior": "NORMAL",

"valueType": "custom",

"validation": [

{ "type": "required" },

{ "type": "minValue", "param": 0 },

{ "type": "maxLength", "param": 25 }

]

}

}


#### DateField (日期)

{

"componentName": "DateField",

"props": {

"fieldId": "dateField_xxxxx",

"label": { "type": "i18n", "zh_CN": "日期", "en_US": "日期" },

"format": "YYYY-MM-DD",

"behavior": "NORMAL",

"valueType": "custom",

"validation": [{ "type": "required" }]

}

}


#### SelectField (下拉选择)

{

"componentName": "SelectField",

"props": {

"fieldId": "selectField_xxxxx",

"label": { "type": "i18n", "zh_CN": "选项", "en_US": "选项" },

"mode": "single",

"showSearch": true,

"behavior": "NORMAL",

"valueType": "custom",

"defaultDataSource": {

"customStashOptions": [

{ "text": { "zh_CN": "选项一", "en_US": "选项一" }, "value": "选项一", "sid": "serial_xxx" }

]

}

}

}


#### RadioField (单选)

{

"componentName": "RadioField",

"props": {

"fieldId": "radioField_xxxxx",

"label": { "type": "i18n", "zh_CN": "类型", "en_US": "类型" },

"itemDirection": "hoz",

"behavior": "NORMAL",

"valueType": "custom",

"dataSource": [

{ "text": { "zh_CN": "选项A", "en_US": "选项A" }, "value": "A", "sid": "serial_a" },

{ "text": { "zh_CN": "选项B", "en_US": "选项B" }, "value": "B", "sid": "serial_b" }

]

}

}


#### EmployeeField (人员选择)

{

"componentName": "EmployeeField",

"props": {

"fieldId": "employeeField_xxxxx",

"label": { "type": "i18n", "zh_CN": "申请人", "en_US": "申请人" },

"multiple": false,

"behavior": "NORMAL",

"valueType": "custom",

"userRangeType": "ALL",

"validation": [{ "type": "required" }]

}

}


#### AssociationFormField (关联表单)

{

"componentName": "AssociationFormField",

"props": {

"fieldId": "associationFormField_xxxxx",

"label": { "type": "i18n", "zh_CN": "关联数据", "en_US": "关联数据" },

"behavior": "NORMAL",

"multiple": false,

"associationForm": {

"formUuid": "FORM-XXXXXXXX",

"appType": "APP_XXXXXXXX"

},

"validation": [{ "type": "required" }]

}

}


#### Image (图片)

{

"componentName": "Image",

"props": {

"fieldId": "image_xxxxx",

"src": "https://example.com/image.jpg",

"width": 100,

"height": 100,

"fit": "cover"

}

}


#### Text (文本)

{

"componentName": "Text",

"props": {

"fieldId": "text_xxxxx",

"content": { "type": "i18n", "zh_CN": "文本内容", "en_US": "文本内容" },

"__style__": ":root { font-size: 16px; font-weight: 600; }"

}

}


#### LinkBlock (链接块)

{

"componentName": "LinkBlock",

"props": {

"fieldId": "linkBlock_xxxxx",

"link": { "type": "url", "url": "https://example.com", "isBlank": true },

"__style__": ":root { margin: 10px; }"

}

}


#### Div (容器)

{

"componentName": "Div",

"props": {

"fieldId": "div_xxxxx",

"__style__": ":root { padding: 20px; background: #fff; }"

}

}


### 布局组件

#### PageSection (区块)

{

"componentName": "PageSection",

"props": {

"fieldId": "pageSection_xxxxx",

"title": { "type": "i18n", "zh_CN": "基本信息", "en_US": "基本信息" },

"showHeader": true,

"behavior": "NORMAL"

}

}


#### ColumnsLayout + Column (多列布局)

{

"componentName": "ColumnsLayout",

"props": {

"fieldId": "columnsLayout_xxxxx",

"layout": "4:4:4"

},

"children": [

{ "componentName": "Column", "props": { "fieldId": "column_1" } },

{ "componentName": "Column", "props": { "fieldId": "column_2" } },

{ "componentName": "Column", "props": { "fieldId": "column_3" } }

]

}


### 常用属性

| 属性 | 说明 | 值 |
|------|------|-----|
| behavior | 组件状态 | NORMAL, READONLY, HIDDEN, DISABLED |
| valueType | 值类型 | custom, formula, linkage |
| validation | 校验规则 | required, minValue, maxLength, customValidate |
| formula | 公式 | CONCATENATE, TODAY, TIMESTAMP, USER, SUM 等 |
| format | 日期格式 | YYYY-MM-DD, YYYY-MM-DD HH:mm:ss |

### 生成字段 ID
字段 ID 格式:`组件类型_随机后缀`,例如:
- `textField_abc123`
- `numberField_def456`
- `selectField_ghi789`

### 示例 App ID
当前应用:`APP_F22M8EK6I2HZTBIYV3U5`

版本历史

共 1 个版本

  • v1.0.1 当前
    2026-03-29 20:46 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

dev-programming

CodeConductor.ai

larsonreever
AI驱动平台,提供快速全栈开发、智能体、工作流自动化及低代码AI集成的可扩展产品创建。
★ 72 📥 181,441
dev-programming

Github

steipete
使用 `gh` CLI 与 GitHub 交互,通过 `gh issue`、`gh pr`、`gh run` 和 `gh api` 管理议题、PR、CI 运行及高级查询。
★ 677 📥 325,834
dev-programming

Mcporter

steipete
使用 mcporter CLI 直接列出、配置、认证及调用 MCP 服务器/工具(支持 HTTP 或 stdio),涵盖临时服务器、配置编辑及 CLI/类型生成功能。
★ 195 📥 67,418