我有一张桌子,上面有带th:fields的行,一切正常。
我需要添加新行,因此我使用javascript做到了,但是当我提交表单时,这些新行都没有提交。我需要特殊的魔法吗?
th:field="*{configuredProperties[__${iterator.index}__].propertyType}"
谢谢!
编辑:
我创建这样的行:
function addProperty() {
var rows = $('#propertiesTable tbody tr');
var row = rows[0];
var clone = row.cloneNode(true);
clone.getElementsByTagName('input')[0].value = null;
clone.getElementsByTagName('input')[1].value = null;
clone.getElementsByTagName('input')[2].value = null;
var lastRow = rows[rows.length - 1];
var newId = parseInt(lastRow.getAttribute("id")) + 1;
clone.id = newId;
var link = $(clone).find('#removeProperty')[0];
link.setAttribute('onclick', 'removeProperty(' + newId + ')');
var propertyType = $(clone).find('#propertyType')[0];
propertyType.setAttribute('name', '*{configuredProperties[' + newId + '].propertyType');
var propertyName = $(clone).find('#propertyName')[0];
propertyName.setAttribute('name', '*{configuredProperties[' + newId + '].propertyName');
var defaultValue = $(clone).find('#defaultValue')[0];
defaultValue.setAttribute('name', '*{configuredProperties[' + newId + '].defaultValue');
var tbody = $('#propertiesTable tbody')[0];
tbody.appendChild(clone);
}
最佳答案
在此块中,您需要提供bean字段的名称
var propertyType = $(clone).find('#propertyType')[0];
propertyType.setAttribute('name', '*{configuredProperties[' + newId + '].propertyType');
var propertyName = $(clone).find('#propertyName')[0];
propertyName.setAttribute('name', '*{configuredProperties[' + newId + '].propertyName');
var defaultValue = $(clone).find('#defaultValue')[0];
defaultValue.setAttribute('name', '*{configuredProperties[' + newId + '].defaultValue');
通过像这样构建领域
var propertyType = $(clone).find('#propertyType')[0];
propertyType.setAttribute('name', 'configuredProperties[' + newId + '].propertyType');
var propertyName = $(clone).find('#propertyName')[0];
propertyName.setAttribute('name', 'configuredProperties[' + newId + '].propertyName');
var defaultValue = $(clone).find('#defaultValue')[0];
defaultValue.setAttribute('name', 'configuredProperties[' + newId + '].defaultValue');