zoukankan      html  css  js  c++  java
  • HTML和JSP页面的比较

    一、HTML页面和JSP页面的比较

     
      HTML JSP
    1 *.html中不含有java代码 *.jsp中含有java代码
    能否单独运行 单独的*.html页面可以独立运行 不可以独立运行,*.jsp必须运行在web container中
    运行速度 属于静态文件系统,响应速度比动态请求的响应速度快 属于动态页面系统,运行在web 容器中,响应速度相对于静态页面系统较慢
      =>定义好的固定的html标签

    =>html标签+ scriptlet+<%@page ...%>

    • scriptlet:
      • <%!%>  <%%>    <%=%>
      • <jsp:scriptlet/>等效于<%%>
      • <%@page import="包名.类名"%>
      • java SE API
      • java EE API(九大内置对象:request、response、session、application等等)   
    是否支持页面包含  

    支持

    • 支持静态包含(先包含后处理)
    • 支持动态包含(先处理后包含)
    是否支持页面跳转

    支持:

    • 服务器端跳转:浏览器地址栏不改变;且执行到页面跳转语句时就立刻执行跳转,不会执行当前页面跳转语句后面的代码。
    • 客户端跳转:浏览器地址栏改变;且执行到页面跳转语句时不会立即跳转,而是将当前页面的所有代码都执行完之后才执行页面跳转语句,跳转到目的页面。
      • <a href=""/> 
      • <form action="page2.jsp">
            <input type="submit">
        </form> 
      • 使用特殊标签,设置3秒后由当前*.html页面跳转到另一个页面,具体编程方式如下,在*.html中添加如下标签:

        • <META HTTP-EQUIV="refresh" CONTENT="3;URL=""dashboard.jsp">   

            

    支持

    • 服务器端跳转:浏览器地址栏不改变;且执行到页面跳转语句时就立刻执行跳转,不会执行当前页面跳转语句后面的代码。
      • <jsp:forward/>可以通过其子标签<jsp:param/>向目的页面传递参数
      • 错误跳转:如404/503、NullPointerException
    • 客户端跳转:浏览器地址栏改变;且执行到页面跳转语句时不会立即跳转,而是将当前页面的所有代码都执行完之后才执行页面跳转语句,跳转到目的页面。
      • <a href=""/>  
      • <form action="page2.jsp">
          <input type="submit">
        </form> 
      • response.setHeader("refresh","3;URL=“dashboard.jsp”")三秒后跳转到指定页面
      • response.sendRedirect("dashbord.jsp"),可以通过地址重写的方式向目的页面传递参数
         
         
         
      服务器端端跳转 客户端跳转
    浏览器地址栏 不改变 改变
    跳转语句之后的代码是否被执行

    执行到跳转语句时会立即跳转,不会执行当前页面跳转语句后面的代码。

    执行完当前页面的所有代码之后才会执行该页面中的跳转语句。

    (针对JSP页面)跳转的目的页面

    能否使用在源页面所添加的

    request范围设置的属性

     否
     编程注意事项  

    1)如果使用服务器端跳转方式下的跳转语句,

    请注意一定要在跳转语句之前将当前页面所用到的资源释放掉。

    如果没有在跳转语句之前将当前页面占用的资源释放掉,如没有在跳转语句前将

    当前页面占用的数据库连接、resultSet/PreparedStatement等资源释放掉的话,

    连续访问这样的页面,数据库连接数目超出一定的量之后将出现“数据库连接已达到最大”的异常,

    这时候就只能重启服务器了。

    2)可以使用原页面所添加的request范围的属性

     2)不能使用原页面所添加的request范围的属性

     

     

     

     

     

     

     

    二、HTML页面和JSP页面的交互

    实例一,

    • 问题描述:
      • HTML页面中的表单中的action=“*.jsp”,单击HTML页面的submit类型按钮之后,会跳转到JSP页面
      • *.jsp中使用HTML页面中的标签的值
    • 编程实现:
      • input.html
        • <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
          <html>
          <head>
          <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
          <title>HTML页面向JSP页面传送数据</title>
          </head>
          <body>
              <form action=display.jsp method="get">
                  姓名:<input type="text" name="userName"/>
                  <input type="submit" value="传递给JSP页面">
              </form>
          </body>
          </html>
      • display.jsp  
        • <%@ page language="java" contentType="text/html; charset=UTF-8"
              pageEncoding="UTF-8"%>
          <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
          <html>
          <head>
          <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
          <title>接收HTML页面传递的表单数据,并展示</title>
          </head>
          <body>
              <h1>接收HTML页面传递的表单数据,并展示html页面表单标签的值</h1>
              <%
                  String name=request.getParameter("userName");
                  out.println("<h2>"+name+"</h2>");
              %>
          </body>
          </html>
    • 结果展示:

      •   

          
    学习的过程中总会得到一些心得体会,认真地将它们记录下来并分享给每一个愿意花费时间去阅读它们的人,然后意外地收获某个读者的评论,从而激发出新的感想,是一件十分令人欢快的事。如果你也在研习这方面的知识,欢迎加入到我们的队伍中来,和我们一起进步吧(^_^)
  • 相关阅读:
    使用django开发一个web项目初试
    关于github一些比较重要的命令
    删除github repository的方法
    Node、npm与Vue配置与问题记录
    [记忆]5月第二周
    git am patch冲突解决步骤
    git丢弃本地修改的几种方式
    Log4j 2.X 漏洞解决
    Maven依赖范围Scope及传递性依赖
    Mysql创建事件定时任务
  • 原文地址:https://www.cnblogs.com/lxrm/p/6699446.html
Copyright © 2011-2022 走看看