![](/img/trans.png)
[英]How to convert JSP request attribute to a string and assign it to an object in JavaScript
[英]Array of object's index from request attribute in jsp and javascript
是否有可能:
1個
當我做:
$('#NContrato' ).val('${personList[0].NContrato}');
有用。 但是如果我這樣做
$('#NContrato' ).val('${personList[' + ind + '].NContrato}');
$('#NContrato' ).val('${personList[ind].NContrato}');
$('#NContrato' ).val('${personList[${ind}].NContrato}');
它不是,這是控制器中的request.setAttribute(personList,...)(我正在使用spring MVC)
$('#NContrato' + ind) // JQuery $() ...It works but
${'${personList[' + ind ...} //Request ${} doesn't work concatenating string's
${personList[0].NContrato} // Works
有辦法嗎?
2
我想將newPerson更改為$ {personList [0]}的副本
我嘗試了這個...
<script type="text/javascript">
function setNewPerson(ind) {
${newPerson=personList[0]};
}
</script>
但是..它給出了這個錯誤:
org.apache.jasper.JasperException:/WEB-INF/pages/t4imovelZMAguaEdpGass.jsp(153,3)PWC6038:“ $ {newPerson = personList [0]}”包含無效的表達式:javax.el.ELException:錯誤解析:“ $ {newPerson = personList [0]}”
編輯:
JSP
<c:forEach items="${personList}" var="item" varStatus="status">
.....
<button type="button" onclick="change(${item.id},${status.count})"></button>
.....
</c:forEach>
.....
<form:form action="save()" method="post" modelAttribute="newPerson" id="personId" >
....
<form:input path="NContrato" id="NContrato" />
....
</form>
<script type="text/javascript">
function change(id, ind) {
$('#NContrato' ).val('${personList[0].NContrato}'); //Works
var ind=0;
$('#NContrato' ).val("${'personList[' + ind + '].NContrato'}"); // <- 1 Question
....
${newPerson=personList[0]}; // <- 2 Question
}
</script>
控制器(Servlet)
@RequestMapping(value="/saves*", method = RequestMethod.POST )
public @ResponseBody ModelAndView save(@ModelAttribute("newPerson") Person person,
BindingResult errors, HttpServletRequest request) throws Exception {
...
request.setAttribute("newPerson", subForm);
...
request.setAttribute("personList", personManager.getPersonList())
....
return new ModelAndView( "personJSP");
}
如果開始使用EL編寫JSP而不先學習基礎知識(原始的舊做事方式),那么您將永遠感到困惑。 EL的$ {}看起來類似於jquery的$()運算符,但事實並非如此。
EL表達
${personList[0].NContrato}
相當於
<%= personList[0].NContrato %>
要么
<% out.print( personList[0].NContrato ); %>
它在服務器端運行,並將personList [0] .NContrato的值打印到您正在構建的HTML源代碼中。
表達方式
${personList[' + ind + '].NContrato}
什么也沒做。 為什么? 因為$ {}在服務器上運行,並且僅顯示變量。 沒有名為“ personList ['+ ind +'] .NContrato”的變量。 確切的文本“ $ {personList ['+ ind +'] .NContrato}”將被打印到您的HTML源代碼中。 因此,進行故障排除時,在瀏覽器中查看源代碼的重要性。
至於
${newPerson=personList[0]};
您不能像EL那樣做作業。 問自己,以下內容是否有意義?
<% out.print( newPerson=personList[0] ); %>
在打印命令中進行分配沒有任何意義。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.