SoFunction
Updated on 2025-04-03

js dynamically add and delete, and get data in the background (sample code)

Environment description: Just like you usually post articles on the forum, it may contain attachments, and the number of attachments is manually added and deleted! !
/************************************************************************
*** Add an approval form template
************************************************************************/
// Growing index
var itemIndex = 1000;
// quantity
var counter = 0;
// Template
var itemTemplate = '';
itemTemplate += '<div style="width: 100%;">';
itemTemplate += '   <span style="width: 80px">form field</span>';
itemTemplate += '   <input type="text" name="flowFormFieldCfgElement(#itemIndex#).name" style="width: 205px;"/>';
itemTemplate += '   Value type <select name="flowFormFieldCfgElement(#itemIndex#).valueType">';
itemTemplate += '       <option value="" selected>String</option>';
itemTemplate += '       <option value="">number (integer)</option>';
itemTemplate += '       <option value="">Date (yyyy-MM-dd)</option>';
itemTemplate += '   </select>';
itemTemplate += '   <input type="button" class="btnDelItem" onclick="delItem(#itemIndex#)" value="Delete">';
itemTemplate += '</div>';

// Add to
function addItem() {
var s = (/#itemIndex#/g, itemIndex);
$("#divFormFields").append(s);
itemIndex ++;
counter ++;
}

// delete
function delItem(index) {
$("#item_" + index).remove();
counter = counter - 1;
}

 


public class FlowFormConfigActionForm extends ActionForm {
private int id;
private String name;
private String processName;

private String formFillTemplatePath;
private String formShowTemplatePath;
private Map<String, FlowformFieldConfig> flowFormFieldCfgMap = new TreeMap<String, FlowformFieldConfig>();

/** Form complex properties */
public FlowformFieldConfig getFlowFormFieldCfgElement(String key){
if(!(key)){
(key, new FlowformFieldConfig());
}
return (key);
}

*U*****

 

public class FlowformFieldConfig {
private int id;
private String name;
private Class<?> valueType;

 

The main principle is: when struts1.* is displayed in jsp, the property value will be first taken out from the formbean through the get*** method! !


flowFormFieldCfgElement(#itemIndex#).name This is the core. If flowFormFieldCfgElement(#itemIndex#) is empty, an error will occur, so in /** form complex properties */
public FlowformFieldConfig getFlowFormFieldCfgElement(String key){
if(!(key)){
(key, new FlowformFieldConfig());
}
return (key);
}
Make a judgment! !
If there are still people who don’t understand, please leave me a message! !