怎样在不通过servlet的情况下只在jsp页面编写代码实现表单回显
本质上jsp就是一个servlet,如果你要在数据库中获取数据来回填表单,直接在jsp写jdbc连接就可以了,但是不建议这么做
JSTL标签库,然后使用对应的属性,或者使用其他框架技术
在不使用servlet的情况下,您可以尝试使用以下方式实现在JSP页面上的表单回显:
在表单中使用EL表达式来展示用户先前输入的值,如下所示:
<input type="text" name="name" value="${param.name}" />
在上面的示例中,${param.name}将在用户提交表单时获取name参数的值,并将其设置为文本框的默认值。
如果您需要对特定值应用逻辑,则可以使用JSTL标签库的条件标签来处理表单回显。例如,对于下拉列表框,您可以尝试以下代码片段:
<select name="gender">
<option value="">Select gender</option>
<c:if test="${param.gender eq 'male'}">
<option value="male" selected>Male</option>
</c:if>
<c:if test="${param.gender eq 'female'}">
<option value="female" selected>Female</option>
</c:if>
</select>
在上面的示例中,如果用户先前选择了male,则<option value="male" selected>将被选中,否则将不会有选中的选项。
请注意,这些示例假定您已经正确设置并启用了EL表达式和JSTL标签库。
(1)index.jsp:
<html>
<body>
<h2>
<%
out.println("Hello Tomcat");
%>
</h2>
</body>
</html>
(2)index.jsp在首次被访问时,WEB容器将jsp转化为Servlet类,即index.jsp转化为index_jsp.java:index_jsp.java:
/*
* Generated by the Jasper component of Apache Tomcat
* Version: Apache Tomcat/8.5.47
* Generated at: 2019-11-07 08:52:49 UTC
* Note: The last modified time of this file was set to
* the last modified time of the source file after
* generation to assist with modification tracking.
*/
package org.apache.jsp;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
public final class index_jsp extends org.apache.jasper.runtime.HttpJspBase
implements org.apache.jasper.runtime.JspSourceDependent,
org.apache.jasper.runtime.JspSourceImports {
private static final javax.servlet.jsp.JspFactory _jspxFactory =
javax.servlet.jsp.JspFactory.getDefaultFactory();
private static java.util.Map<java.lang.String,java.lang.Long> _jspx_dependants;
private static final java.util.Set<java.lang.String> _jspx_imports_packages;
private static final java.util.Set<java.lang.String> _jspx_imports_classes;
static {
_jspx_imports_packages = new java.util.HashSet<>();
_jspx_imports_packages.add("javax.servlet");
_jspx_imports_packages.add("javax.servlet.http");
_jspx_imports_packages.add("javax.servlet.jsp");
_jspx_imports_classes = null;
}
private volatile javax.el.ExpressionFactory _el_expressionfactory;
private volatile org.apache.tomcat.InstanceManager _jsp_instancemanager;
public java.util.Map<java.lang.String,java.lang.Long> getDependants() {
return _jspx_dependants;
}
public java.util.Set<java.lang.String> getPackageImports() {
return _jspx_imports_packages;
}
public java.util.Set<java.lang.String> getClassImports() {
return _jspx_imports_classes;
}
public javax.el.ExpressionFactory _jsp_getExpressionFactory() {
if (_el_expressionfactory == null) {
synchronized (this) {
if (_el_expressionfactory == null) {
_el_expressionfactory = _jspxFactory.getJspApplicationContext(getServletConfig().getServletContext()).getExpressionFactory();
}
}
}
return _el_expressionfactory;
}
public org.apache.tomcat.InstanceManager _jsp_getInstanceManager() {
if (_jsp_instancemanager == null) {
synchronized (this) {
if (_jsp_instancemanager == null) {
_jsp_instancemanager = org.apache.jasper.runtime.InstanceManagerFactory.getInstanceManager(getServletConfig());
}
}
}
return _jsp_instancemanager;
}
public void _jspInit() {
}
public void _jspDestroy() {
}
public void _jspService(final javax.servlet.http.HttpServletRequest request, final javax.servlet.http.HttpServletResponse response)
throws java.io.IOException, javax.servlet.ServletException {
final java.lang.String _jspx_method = request.getMethod();
if (!"GET".equals(_jspx_method) && !"POST".equals(_jspx_method) && !"HEAD".equals(_jspx_method) && !javax.servlet.DispatcherType.ERROR.equals(request.getDispatcherType())) {
response.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED, "JSPs only permit GET POST or HEAD");
return;
}
final javax.servlet.jsp.PageContext pageContext;
javax.servlet.http.HttpSession session = null;
final javax.servlet.ServletContext application;
final javax.servlet.ServletConfig config;
javax.servlet.jsp.JspWriter out = null;
final java.lang.Object page = this;
javax.servlet.jsp.JspWriter _jspx_out = null;
javax.servlet.jsp.PageContext _jspx_page_context = null;
try {
response.setContentType("text/html");
pageContext = _jspxFactory.getPageContext(this, request, response,
null, true, 8192, true);
_jspx_page_context = pageContext;
application = pageContext.getServletContext();
config = pageContext.getServletConfig();
session = pageContext.getSession();
out = pageContext.getOut();
_jspx_out = out;
out.write("<html>\n");
out.write("<body>\n");
out.write("<h2>\n");
out.println("Hello Tomcat");
out.write("\n");
out.write("</h2>\n");
out.write("</body>\n");
out.write("</html>\n");
} catch (java.lang.Throwable t) {
if (!(t instanceof javax.servlet.jsp.SkipPageException)){
out = _jspx_out;
if (out != null && out.getBufferSize() != 0)
try {
if (response.isCommitted()) {
out.flush();
} else {
out.clearBuffer();
}
} catch (java.io.IOException e) {}
if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);
else throw new ServletException(t);
}
} finally {
_jspxFactory.releasePageContext(_jspx_page_context);
}
}
}
从转化后的代码,可知jsp页面里的HTML、CSS、JS,最终都被嵌套在Servlet程序的java代码里。我们可以推断jsp页面只是方便我们编写Servlet程序,就像在拼接一个长长的字符串。但是在前后端分离的开发中(可以参考《前后端分离的趋势》),jsp显然是不适应的。