mirror of
https://gitee.com/baidu/amis.git
synced 2024-12-15 09:21:13 +08:00
347 lines
7.7 KiB
JavaScript
347 lines
7.7 KiB
JavaScript
export default {
|
||
type: 'page',
|
||
title: 'form组件支持动作示例',
|
||
regions: ['body', 'toolbar', 'header'],
|
||
body: [
|
||
{
|
||
type: 'action',
|
||
label: '清空表单',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
componentId: 'form-action-receiver',
|
||
actionType: 'clear'
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'action',
|
||
label: '重置表单',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
actionType: 'reset',
|
||
componentId: 'form-action-receiver'
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'action',
|
||
label: '校验表单',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
actionType: 'validate',
|
||
componentId: 'form-action-receiver'
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'action',
|
||
label: '重新加载表单组件',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
actionType: 'reload',
|
||
componentId: 'form-action-receiver'
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'action',
|
||
label: '提交表单',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
actionType: 'submit',
|
||
componentId: 'form-action-receiver'
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'action',
|
||
label: '将第一个表单中的姓名赋值给下面的输入框(我的名称)',
|
||
level: 'primary',
|
||
className: 'mr-3 mb-3',
|
||
onEvent: {
|
||
click: {
|
||
actions: [
|
||
{
|
||
actionType: 'setValue',
|
||
componentId: 'u:text_001',
|
||
args: {
|
||
value: '${GETRENDERERDATA("form-action-receiver", "name")}'
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'input-text',
|
||
name: 'name',
|
||
label: '我的姓名',
|
||
className: 'mt-3',
|
||
mode: 'horizontal',
|
||
id: 'u:text_001'
|
||
},
|
||
{
|
||
name: 'form-action-receiver',
|
||
id: 'form-action-receiver',
|
||
title: '表单:用于接收上面按钮的动作,派发form本身的事件',
|
||
type: 'form',
|
||
debug: true,
|
||
api: '/api/mock2/form/saveForm',
|
||
data: {
|
||
data1: '初始化数据1',
|
||
data2: '初始化数据2'
|
||
},
|
||
initApi:
|
||
'https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/form/initData',
|
||
body: [
|
||
{
|
||
type: 'input-text',
|
||
name: 'name',
|
||
label: '姓名',
|
||
required: true,
|
||
validateOnChange: true
|
||
},
|
||
{
|
||
type: 'input-text',
|
||
name: 'email',
|
||
label: '邮箱',
|
||
required: true,
|
||
validateOnChange: true,
|
||
validations: {
|
||
isEmail: true
|
||
}
|
||
}
|
||
],
|
||
onEvent: {
|
||
change: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单值变化:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
inited: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单初始化完成:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
formItemValidateSucc: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单项校验成功:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
formItemValidateError: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单项校验失败:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
validateSucc: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单校验成功:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
validateError: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单校验失败:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
submitSucc: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '提交失败:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'form',
|
||
debug: true,
|
||
api: '/api/mock2/form/saveForm',
|
||
title: '表单:派发formItem的校验事件',
|
||
data: {
|
||
data1: '初始化数据1',
|
||
data2: '初始化数据2'
|
||
},
|
||
initApi:
|
||
'https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/form/initData',
|
||
body: [
|
||
{
|
||
type: 'input-text',
|
||
name: 'name',
|
||
label: '姓名',
|
||
required: true,
|
||
validateOnChange: true
|
||
},
|
||
{
|
||
type: 'input-text',
|
||
name: 'email',
|
||
label: '邮箱',
|
||
required: true,
|
||
validateOnChange: true,
|
||
validations: {
|
||
isEmail: true
|
||
}
|
||
}
|
||
],
|
||
onEvent: {
|
||
formItemValidateSucc: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单项校验成功:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
},
|
||
formItemValidateError: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '表单项校验失败:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'form',
|
||
debug: true,
|
||
title: '表单:提交表单无target,无api,只触发提交成功事件',
|
||
body: [
|
||
{
|
||
type: 'input-text',
|
||
name: 'name',
|
||
label: '姓名',
|
||
required: true,
|
||
validateOnChange: true
|
||
},
|
||
{
|
||
type: 'input-text',
|
||
name: 'email',
|
||
label: '邮箱',
|
||
required: true,
|
||
validateOnChange: true,
|
||
validations: {
|
||
isEmail: true
|
||
}
|
||
}
|
||
],
|
||
onEvent: {
|
||
submitSucc: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '提交成功:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
},
|
||
{
|
||
type: 'form',
|
||
debug: true,
|
||
api: '/api/mock2/form/saveForm',
|
||
title:
|
||
'表单:配置submit事件后,点击提交按钮或者触发表单提交动作时将不会触发表单校验、提交到api或者target等行为,所有行为需要自己配置',
|
||
body: [
|
||
{
|
||
type: 'input-text',
|
||
name: 'name',
|
||
label: '姓名',
|
||
required: true,
|
||
validateOnChange: true
|
||
},
|
||
{
|
||
type: 'input-text',
|
||
name: 'email',
|
||
label: '邮箱',
|
||
required: true,
|
||
validateOnChange: true,
|
||
validations: {
|
||
isEmail: true
|
||
}
|
||
}
|
||
],
|
||
onEvent: {
|
||
submit: {
|
||
actions: [
|
||
{
|
||
actionType: 'toast',
|
||
args: {
|
||
msg: '提交成功:${event.data|json}'
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
}
|
||
]
|
||
};
|