我想将JSP变量值设置为struts标记<s:set var="" value="">
,
在以下代码中,我必须在carbo
中设置<s:set name="c" value=" "/>
变量的值,而不是常量值。
我该怎么做?
<%! String carbo=""; %>
<%
String dish_name=(String)session.getAttribute("d");
String calories_qty=(String)session.getAttribute("a");
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/medical","root","root");
//Connection conn=dbConn.getConnection();
Statement stmt = conn.createStatement();
System.out.println("jsp dish_name="+dish_name);
System.out.println("jsp dish_name="+calories_qty);
ResultSet rs = stmt.executeQuery("Select * from calories c,dishdetail d where c.dishdetail_Id=d.id and d.dishName='"+dish_name+"' AND d.size='"+calories_qty+"' ");
while(rs.next()){
carbo=rs.getString("carbo");
//carbo=Float.parseFloat(rs.getString("carbo"));
}
System.out.println("jsp carbo:"+carbo);
}
catch(Exception e){
System.out.println("error:"+e);
}
%>
<s:set name="c" value="45" />
<p> carbo: <s:property value="#c" /></p>
<sj:progressbar cssStyle="width:20%; height:10px;" value="%{c}" onCompleteTopics="reloadfifthlist" onChangeTopics="mychangetopic"/>
答案 0 :(得分:1)
我希望我能理解你想要达到的目标,但我会选择
<s:set name="c" value="<%= carbo %>"/>
答案 1 :(得分:0)
最简单的方法
<s:set var="c"><%=carbo%></s:set>
<s:property value="#c" />
但是,您不应在scriptlet中编写应用程序逻辑,而应在操作中执行此操作,您可以将这些变量放在操作类中。该操作可以将调度结果返回给JSP。然后在将getter和setter压缩到属性之后,您可以使用OGNL表达式来引用操作属性。例如
@Action(value="name", results={
@Result(location = "/path/to/page.jsp")
})
class MyAction extends ActionSupport {
private String carbo;
//getters and setters here
public String execute(){
//your logic here
return SUCCESS;
}
}
然后你只需要引用这个动作属性
<s:property value="%{carbo}" />