对不起我糟糕的英语。我有很多事情在我的脑海里,从字面上让我感到困惑。我想将表单提交的值作为@ModelAttribute 处理,这首先让我感到困惑。不使用 @ModelAttribute 我很好,并且一切正常。
我的要求是在 portlet 和 spring mvc 3.0 注释中处理 ajax 表单提交
我有的表格
<portlet:resourceURL var="userURL" id="addUser" escapeXml="false" />
<form id="<portlet:namespace />User>
<table>
<tr><td>First Name: </td>
<td><input type="text" name="fname"></td></tr>
<tr><td>Last Name: </td>
<td><input type="text" name="lname"></td></tr>
<tr><td>Address 1: </td>
<td><input type="text" name="address_1"></td></tr>
<tr><td>Address 2: </td>
<td><input type="text" name="address_2"></td></tr>
<tr><td>Zipcode </td>
<td><input type="text" name="zipcode"></td></tr>
<tr><td> </td>
<td><button id="submit">Submit</td></tr>
</table>
</form>
我使用以下 jQuery 将表单作为 ajax 调用提交
$('#submit').on('click',function() {
var fname = $('#fname').val();
var lname = $('#lname').val();
var address_1 = $('#address_1').val();
var address_2 = $('#address_2').val();
var zipcode = $('#zipcode').val();
$.ajax({
type: "POST"
url: "<c:out value="${userURL}" />"
data: {fname: fname, lname: lname, address_1: address_1, address_2: address_2, zipcode: zipcode }
success: function(data) {
if(data == "success") {
$('#showError').hide();
} else {
$('#showError').show();
}
}
})
});
我有以下控制器来处理 ajax 调用
@Controller
@RequestMapping("VIEW")
public class UserController {
@ResourceMapping("addUser")
public String addUser(ResourceRequest request, ResourceResponse response) {
String fName = request.getParameter("fname");
String lName = request.getParameter("lname");
String address_1 = request.getParameter("address_1");
String address_2 = request.getParameter("address_2");
String zipcode = request.getParameter("zipcode");
// I do the processing of the form and add the user attributes to the database.
}
}
我创建了一个 User 类,我想使用 @ModelAttribute 来设置/获取值。我已经通过许多链接试图弄清楚如何使用它。其中一个示例使用了 taglib 格式。我有 jQuery 将表单作为 ajax 调用提交,我不确定是否将表单更改为这种模式,它会破坏我的代码。
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<form:form method="post" action="addContact.html">
<table>
<tr>
<td><form:label path="firstname">First Name</form:label></td>
<td><form:input path="firstname" /></td>
</tr>
<tr>
<td><form:label path="lastname">Last Name</form:label></td>
<td><form:input path="lastname" /></td>
</tr>
<tr>
<td><form:label path="lastname">Email</form:label></td>
<td><form:input path="email" /></td>
</tr>
<tr>
<td><form:label path="lastname">Telephone</form:label></td>
<td><form:input path="telephone" /></td>
</tr>
<tr>
<td colspan="2">
<input type="submit" value="Add Contact"/>
</td>
</tr>
</table>
</form:form>
谢谢您的帮助!