gpt4 book ai didi

java - Spring 动态(可扩展)列表形式

转载 作者:搜寻专家 更新时间:2023-10-31 20:30:34 24 4
gpt4 key购买 nike

我在 spring 中遇到动态表单问题。在我们的表单中,我们要指定一个标题,并添加一些问题。我们有一个“添加”按钮来添加问题输入表单使用jquery.

我们的表格在被请求时有一个问题字段。每次都会添加额外的字段“添加”按钮被按下。提交时似乎没有额外的字段已提交(第一个由 Controller 接收)。为什么没有发送额外的字段 received

我的代码大致基于 this dynamic binding list example .

我的模型由一个类“Report”组成,它有一个“标题”和“研究问题”列表。
下面是两个模型类的简短版本。 Roo 负责所有的 getters 和 setter

@Entity
@RooJavaBean
@RooEntity
public class Report{
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private Long id;

@NotEmpty
private String title;

@OneToMany(mappedBy="report")
private List<Researchquestion> researchquestions;
}



@Entity
@RooJavaBean
@RooEntity
public class Researchquestion {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private Long id;
@NotEmpty
private String question;
}

这里是表单的jspx

<div xmlns:c="http://java.sun.com/jsp/jstl/core"
xmlns:form="http://www.springframework.org/tags/form"
xmlns:jsp="http://java.sun.com/JSP/Page"
xmlns:fn="http://java.sun.com/jsp/jstl/functions"
xmlns:spring="http://www.springframework.org/tags"
version="2.0">
<jsp:output omit-xml-declaration="yes"/>

<spring:url value="/admin/report/appendquestion" var="insert_url"/>

<script type="text/javascript">
$(document).ready(function() {
var questionPosition = 0;
$("#addQuestionButton").click(function() {
questionPosition++;

$.get("${insert_url}", { fieldId: questionPosition},
function(data){
$("#insertAbove").before($(data));
});
});
});
</script>

<div class="list_overview_box span-19">
<spring:url value="/admin/report/" var="form_url"/>
<div class="list_overview_content">
<table>
<form:form action="${form_url}" method="post" modelAttribute="report">
<tr>
<th class="span-3">Veld</th>
<th>Waarde</th>
<th class="span-5">Errors</th>
</tr>

<!-- Title -->
<tr class="row">
<td class="vmiddle aleft">Title</td>
<td><form:input path="title" /></td>
<td></td>
</tr>

<!-- the "add" button -->
<tr class="row">
<td class="vmiddle aleft">Researchquestions</td>
<td colspan="2"><input type="button" id="addQuestionButton" value="Add question" /></td>
</tr>
<!-- First Researchquestion -->
<spring:bind path="researchquestions[0].question">
<tr class="row">
<td class="vmiddle aleft">Question 1</td>
<td><form:input path="${status.expression}" /></td>
<td></td>
</tr>
</spring:bind>

<!-- Save button, extra question's are added here -->
<tr id="insertAbove" class="row">
<spring:message code="button.save" var="form_submit"/>
<td colspan="3"><input id="proceed" type="submit" value="${form_submit}" /></td>
</tr>
</form:form>
</table>
</div>
</div>
</div>

下面是 Controller 在jquery.get请求后返回的页面我的想法是我需要使用 <spring:bind>就像上面的表格一样。但是,当我这样做时,出现错误:

java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name 'researchquestions[1]' available as request attribute

附加问题.jspx

<jsp:root version="2.0"
xmlns:jsp="http://java.sun.com/JSP/Page"
xmlns:c="http://java.sun.com/jsp/jstl/core"
xmlns:tiles="http://tiles.apache.org/tags-tiles"
xmlns:form="http://www.springframework.org/tags/form"
xmlns:spring="http://www.springframework.org/tags"
xmlns:roo="urn:jsptagdir:/WEB-INF/tags" >

<tr class="row">
<jsp:directive.page contentType="text/html;charset=UTF-8" />

<td class="vmiddle aleft">Question ${questionNumber +1}</td>
<td>
<form:input path="report.researchquestions[${questionNumber}].question" size="40" />
</td>
<td></td>
</tr>

</jsp:root>

这里是我们 Controller 中相关的@ModelAttribute 和@requestmapping 方法@ModelAttribute 方法确保 List 在一个实例中AutoPopulatingList,不过我不太确定这是否是必需的。
如果我添加 @RequestParam Map formdatacreate() (POST) 方法然后 formdata 做包含 researchquestions[0].question但不是 researchquestions\[1\].question或任何其他问题字段按下“添加”按钮后添加的内容

@ModelAttribute("report")
public Report getReport(Long id) {
Report result;
if(id != null){
result = Report.findReport(id);
} else{
result = new Report();
}

//Make sure the List in result is an AutoPopulatingList
List<Researchquestion> vragen = result.getResearchquestions();
if(vragen == null){
result.setResearchquestions(new AutoPopulatingList<Researchquestion>(Researchquestion.class));
} else if(!(vragen instanceof AutoPopulatingList)){
result.setResearchquestions(new AutoPopulatingList<Researchquestion>(
vragen, Researchquestion.class));
}

return result;
}

/**
* Aanmaken Report
* @param report
* @param result
* @param modelMap
* @return
*/
@RequestMapping(method = RequestMethod.POST)
public String create(@Valid @ModelAttribute("report") Report report,
BindingResult result, ModelMap modelMap) {

if (report == null) throw new InvalidBeanException("A report is required");

if (result.hasErrors()) {
modelMap.addAttribute("report", report);
return "admin/report/create";
}

report.persist();

//create questions
for(Researchquestion question : report.getResearchquestions()){
question.setProfielwerkstuk(report);
question.persist();
}

report.merge();
return "redirect:/admin/report";
}

@RequestMapping(value = "/appendquestion", method = RequestMethod.GET)
public String appendResearchquestionField(@RequestParam Integer fieldId, ModelMap modelMap){
modelMap.addAttribute("questionNumber", fieldId);
return "admin/report/appendquestion";
}

附加信息(根据拉尔夫的要求)

在Spring生成的HTML下面,默认是researchquestions[0].question的形式,researchquestions[1].question是按“添加”按钮后添加的

 <tr class="row">
<td class="vmiddle aleft">Question 1</td>
<td>
<input id="researchquestions0.question" type="text" value=""
name="researchquestions[0].question">
</td>

<td></td>
</tr>

<tr class="row">
<td class="vmiddle aleft">Question 2</td>
<td>
<input id="researchquestions1.question" type="text" size="40" value="" name="researchquestions[1].question">
</td>
<td></td>
</tr>

下面是Live HTTP Headers的相关信息
我在“标题”字段中输入“这是标题”,在“问题 1”字段中输入“这是第一个问题”,在“问题 2”字段中输入“这是第二个问题”(已添加通过按“添加”按钮。

明明researchquestions[0].question正在提交,但是POST请求中researchquestions[1].question根本没有提交。

Content-Type: application/x-www-form-urlencoded
Content-Length: 73
title=This+is+the+title&researchquestions%5B0%5D.question=This+is+the+first+question

我的怀疑第一个问题(默认是表单)和后面的问题的区别是第一个问题使用<spring:bind>。而随后的则没有。当我删除 <spring:bind>第一个问题的标签,researchquestions[0]也没有提交。

正如我上面所解释的,我在添加 <spring:bind> 时得到一个 IllegalStateException到 appendquestion.jspx。似乎 spring 搜索对象 researchquestions[1]而不是 report.researchquestions[1]

java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name 'researchquestions[1]' available as request attribute

最佳答案

我找到了表单未正确提交的原因。我在 Firebug 中注意到以下 HTML:

<form id="researchquestion" method="post" action="/site/admin/researchquestion/"></form>

form标签立即关闭,所以spring生成的HTML不正确。看来这是因为表格在表格内切换 <table><form:form>标签解决了这个问题。

原始代码

<table>
<form:form action="${form_url}" method="post" modelAttribute="report">
<!-- Code here -->
</form:form>
</table>

工作版本

<form:form action="${form_url}" method="post" modelAttribute="report">
<table>
<!-- Code here -->
</table>
</form:form>

<table> 中只允许使用与表格相关的标签,例如 <tr> <th><td> .这可能就是 Spring 立即关闭 <form> 的原因。标签。

关于java - Spring 动态(可扩展)列表形式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6845450/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com