介绍
列表添加自定义按钮,点击按钮弹出自定义页面,页面中输入数据,确定之后把数据保存到数据库中并刷新列表
详细步骤
1.按钮配置中添加自定义按钮;
2.添加按钮的点击(click)事件;
3. 编写JS,实现业务逻辑:弹出自定义页面,并将输入的数据保存到数据库中;
4. 页面效果;
相关代码
const {Modal,Form,Input} = JE.useUi();
const {h,createVNode,ref,reactive}= JE.useVue();
const {ajax,encode, decode} = JE.useUtils();
const {$func} = EventOptions;
const funcGrid=$func.getFuncGrid();
const records = funcGrid.getSelectedRecords();
const ids=new Array();
debugger;
if(records && records.length>0){
const errors=[];
records.forEach((record)=>{
const xmName=record.JDAL_XMMC;
const fwName=record.JDAL_XMZT_NAME;
const fwId=record.JE_DEMO_JDAL_ID;
if(record.JDAL_XMZT_CODE != 'ZXZ' ){
errors.push("项目["+xmName+"],处于["+fwName+"]状态,无法终止!");
}
ids.push(fwId);
})
if(errors.length>0){
Modal.alert(errors.join("<br/>"), "error");
return false;
}
}else{
Modal.alert("请选择需要终止的项目", "error");
return false;
}
const formRef = ref('');
let formState = reactive({
text: ''
});
const sqlVnodeArr = [{
id: 'ddyy',
text: '原因',
placeholder: '填写原因',
required: true,
requiredText: '该输入项为必填项!',
}];
const labelCol1 = { style: 'width:100px;' };
const Vnode = sqlVnodeArr.map((item)=>{
return h(Form.Item, {label: item.text,name: item.id,rules:[{ required: item.required, message: item.requiredText }]}, createVNode(Input.TextArea,{placeholder:item.placeholder, value: formState[item.id], height: 200,allowClear: true,
'onUpdate:value': function (val) {
formState[item.id] = val;
}}))
})
//表单弹出
const renderContent = ()=> {return h(Form,{ref:formRef,name: 'form', size: 'small',autocomplete:"off",model: formState,labelCol: labelCol1,
},Vnode)};
Modal.alert({
title: '终止项目',
height: 'auto',
width: '600px',
content:renderContent,
buttonAlign: 'center',
cancelButton: true,
okButton: {
closable: false,
handler: ({$modal})=>{
formRef.value.validate().then(()=>{
debugger;
const ddyy=formState.ddyy;
const strDatasReal=new Array();
ids.forEach((id)=>{
debugger;
var mapData = {JDAL_ZFYY:ddyy,JE_DEMO_JDAL_ID:id,JDAL_XMZT_CODE:'YZZ',JDAL_XMZT_NAME:'已终止'}
strDatasReal.push(mapData);
})
ajax({
url:"/je/common/doUpdateList",
params:{
funcCode: "JE_DEMO_JDAL_TWO"
,tableCode: "JE_DEMO_JDAL"
,strData: JSON.stringify(strDatasReal)
},
headers:{pd:"demo"}
}).then((resObj)=>{
debugger;
if(resObj.success){
Modal.notice("操作成功", "success");
funcGrid.setAllCheckboxRow(false);
funcGrid.triggerSelectChange({records:[]});
funcGrid.store.reload();
$modal.close();
}else{
Modal.alert(resObj.obj, "error");
}
})
}).catch((error) => {
console.error(error);
});
},
}
});
最后编辑: 肖海杰 文档更新时间: 2025-01-15 16:00 作者:肖海杰