个性开发
自己写前端JS 进行页面布局
基础配置
自定义列表
/*
// JE:公共类库,提供了常用的类库
const vue = JE.useVue(); // Vue库
const ui = JE.useUi(); // UI库
const utils = JE.useUtils(); // 工具库
const system = JE.useSystem(); // 系统类库
*/
const {Modal,Form,Input,Grid} = JE.useUi();
const {h,createVNode,ref,reactive}= JE.useVue();
//列表列
const gridColumn = [{
field:'no',
title:'序号',
width:'90',
editType:Input
},{
field:'name',
title:'姓名',
width:'200',
editType:Input
},{
field:'sex',
title:'姓别',
width:'200',
editType:Input
},{
field:'age',
title:'年龄',
width:'200',
editType:Input
}];
//列表数据
const gridData = [
{no:1,name:'张三',sex:'男',age:'18'},
{no:2,name:'王五',sex:'男',age:'18'},
{no:3,name:'小红',sex:'女',age:'18'},
{no:4,name:'小花',sex:'男',age:'18'}
];
const Vnode = gridColumn.map((item,index)=>{
return h(Grid.Column, {
field:item.field,
title:item.title,
minWidth:item.width,
editRender:{autofocus: '.ant-input'}},{
edit: ({row}) =>h(item.editType,{value:row[item.field]})
}
);
})
return h(Grid,{
data:gridData,
align:'center',
editConfig:{
trigger: 'click',
mode: 'cell',
showStatus: true,
}
},Vnode)
自定义表单
// 工具库
const {Form,Input,Radio,Button} = JE.useUi();
const {h,createVNode,reactive,ref} = JE.useVue();
const formRef = ref('');
let formState = reactive({
YSAL_XM: '',
YSAL_NL:'',
YSAL_SEX_CODE:'',
YSAL_SEX_NAME:''
});
const sqlVnodeArr = [{
name: 'YSAL_XM',
text: '姓名',
type:Input,
required: true,
requiredText: '该输入项为必填项!',
},{
name: 'YSAL_NL',
text: '年龄',
type:Input,
required: false,
requiredText: '',
},{
name: 'YSAL_SEX_CODE',
text: '性别',
required: true,
type:Radio.Group,
configInfo:'JE_RBAC_SEX,YSAL_SEX_NAME~YSAL_SEX_CODE,text~code,S',
requiredText: '该输入项为必填项!',
}];
const labelCol1 = { style: 'width:100px;' };
const Vnode = sqlVnodeArr.map((item)=>{
return h(Form.Item, {
label:item.text,
name:item.name,
rules:[{
required: item.required,
message: item.requiredText
}]},createVNode(item.type,{
value: formState[item.name],
allowClear: true,
configInfo:item?.configInfo,
'onUpdate:value': function (val) {
formState[item.name] = val;
}}
))
})
// const VButtonOK = h(Button,{bgColor:"#00B42A",fontColor: "#f9f9f9",type:'primary'},'确定');
// const VButton = h(Button,{bgColor:"#00B42A",fontColor: "#f9f9f9",type:'primary'},'取消');
//定义按钮
const VDiv = h('div',{},[
h(Button,{
fontColor: "#f9f9f9",
type:'primary',
style:{margin:'0 5px'},
//注册确定按钮点击事件
onclick:function(){
alert(1);
}
},'确定'),
h(Button,{fontColor: "#f9f9f9",type:'danger'},'取消')
])
return h(Form,{
// ref:formRef,
layout:'vertical',
name: 'form',
size: 'small',
autocomplete:"off",
model: formState,
labelCol: labelCol1,
},[Vnode,VDiv]);
效果图
最后编辑: 呼丽华 文档更新时间: 2025-01-15 16:00 作者:呼丽华