百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

JavaEE 从入门到放弃(三):为什么要用 JSP?

yuyutoo 2024-10-12 01:06 5 浏览 0 评论

一、Servlet 与 JSP

Servlet 通常使用字符串拼接的方式动态生成 html,大量的 html 内容使代码难以维护、可读性差。

感受一下,简单地加一个 table 得酱写:


都快看不出来是 Java 代码了。

后来,大佬们想,既然能在 Java 中写 html,能不能在 html 中写 Java 呢?

于是 JSP(JavaServer Pages) 诞生了。

JSP 是基于 Servlet API 的,所以拥有 Servlet 拥有的一系列好处,可以实现各种功能,同时可以很方便地编写或修改网页,不用面对大量的 println 语句,但是,什么事情都要把握一个度,在 html 中混入大量、复杂的业务逻辑也是不可取的。

一种双剑合璧、扬长避短的方法是把 Servlet 当成 Controller 层,用于处理浏览器请求,并调用核心业务逻辑(Model)。而 JSP 则用作 View 层,负责动态地把处理结果输出到 html 中去。

Model、View、Controller,没错,这就是我们所说的 MVC 模式啦!这里先不赘述,以后会有一篇文章专门介绍 MVC 。

二、JSP 简介

JSP 是如何实现这种功能的呢?

通过分析源码,我们发现,JSP 被服务器 “转译” 成了 Servlet。

我们知道,在服务器中部署 Servlet,需要先把 Servlet 编译成 .class 文件,所以添加或修改 Servlet 需要重启服务器才能生效。而 JSP 的转译与编译均由服务完成,服务器如果设置了 JSP 监视,则不需重启就可以应用新增或修改的 JSP。

下面动手来个实践。

本部分内容来自 How2J 的 JSP 教程

test.jsp

在 web 目录下新建一个文件 test.jsp
(Tomcat 的 web 根目录为 /webapps/ROOT)

<%@page contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" import="java.util.*"%>
 
hello,jsp
 
<br>
 
<%=new Date().toLocaleString()%>
12345678

访问 localhost/test.jsp,可以看到运行结果

1 代码分析

Page 指令

<%@page contentType="text/html; charset=UTF-8"  pageEncoding="UTF-8" import="java.util.*"%>
1

<%@page ... %> 是 JSP 的 Page 指令,为浏览器提供当前页面的使用说明,与 html 的头对应。等价的 XML 格式为

<jsp:directive.page contentType="text/html; charset=UTF-8"  pageEncoding="UTF-8" import="java.util.*"/>
1

JSP 表达式

JSP 表达式的语法格式为:<%= 表达式 %>,JSP表达式会先被转化为 String,然后插入到表达式出现的地方。

<%=new Date().toLocaleString()%>
1

本行代码输出当前的时间。

表达式可以出现在文本行中,而不一定是 html 标签。可以使用任何符合 Java 语言规范的表达式。

JSP 执行过程

test.jsp 的执行过程为:

  1. test.jsp 被转译为 test_jsp.java(该类继承自 HttpJspBase,而 HttpJspBase 继承自 HttpServlet)
  2. test_jsp.java 被编译成 hello_jsp.class
  3. 执行 hello_jsp.class,生成 html
  4. 通过 HTTP 协议把 html 响应返回给浏览器

2 页面元素

除了上面提到的指令表达式,JSP 还有以下几种页面元素:

静态内容

即 html/css/javascript 等内容

Scriptlet

<% %> 之间,可以写任何 Java 代码

声明

<% ! %> 之间可以声明字段或方法,但是不建议这么做。

动作

<jsp:include page="Filename"> 在 JSP 页面中包含另一个页面。

注释

<%-- jsp代码 --%>
1

3 其它细节

其它细节方面的内容感兴趣的小伙伴可以自行去了解,还是那句话,编程最重要的是动手去做,不撸个几百万行代码怎么好意思说自己室程序员呢?

Servlet 和 JSP 实际上是各有千秋,我们应该如何扬长避短呢?且听下回分解——


相关推荐

掌握这些CSS知识点,Coding如飞(css的基础知识)

...

CSS:绝对定位、相对定位、固定定位

绝对定位position:absolute...

探索CSS position属性(css position relative)

提示:点击上方"蓝色字体"↑可以订阅噢!摘要51RGB官方微信position是CSS中非常重要的一个属性,通过position属性,我们可以让元素相对于其正常位置,父元素或者浏览器窗口进行偏移。...

你要的CSS布局都在这里(css布局的几种方式)

大家好,我是三木。这篇文章,替大家汇总了css的布局方式,在每个布局的结尾附上了我认为比较好的文章链接,不仅仅可以当作学习资料,也可以当作方法的查询手册,以后开发的时候忘记了某个属性就来查查。看完推荐...

CSS 元素分类与水平居中(css内容水平居中)
CSS 元素分类与水平居中(css内容水平居中)

元素分类在讲解CSS布局之前,我们需要提前知道一些知识,在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素、内联元素(又叫行内元素)和内联块状元...

2025-04-08 20:29 yuyutoo

CSS 定位详解(css定位例子)

CSS有两个最重要的基本属性,前端开发必须掌握:display和position。display属性指定网页的布局。两个重要的布局,我已经介绍过了:弹性布局flex[1]和网格布局grid[2]。本...

CSS精准定位布局——position(css定位position的定位有哪些,有那么特点?)

1简介上一篇文章,介绍了魔鬼属性——浮动布局。浮动布局比较灵活,但是不容易控制。而定位布局使用户精准定位页面中的任意元素成为可能。因此在实际开发中,大家应该灵活使用这两种布局方式,这样才可以更好地满...

浅谈position中absolute和relative

CSSposition属性中absolute和relative很容易让人弄混,基本的概念什么着,你去参考W3C,就不啰嗦了--------------------------------------...

Windows Phone新手开发教程(一)(windows开发ios app)

这是本系列的第1部分。在进行开发的过程之前,我将解释WindowsPhone的基础知识。第1部分涵盖了以下三个开发的基本主题:WindowsPhoneSDK的安装WindowsPhone用户界...

.NET界面开发控件DevExpress v15.2.8发布

以下是DevExpress15.2.8新增的一些功能,以及帮助文档描述。DXDiagramforWPFT353654-当界面上至少有一个item可见时,BringItemsIntoView...

「炫丽」从0开始做一个WPF+Blazor对话小程序

...

QT与C#:选择适合界面开发的最佳框架,并且附带精美案例

QT和C#都提供了丰富的界面开发工具和库,允许开发人员创建各种类型的用户界面。以下是QT和C#界面开发方面的一些对比:...

Windows Phone新手开发教程(二)(windows开发iphone应用)

这是本系列的第2部分。在这里我将讲解StackPanel和Grid元素。很多时候开发人员对于在何处放置包含StackPane或Grid元素的控制元件感到困惑。那么我们就来了解一些关于StackPane...

WPF MVVM嵌套绑定黑科技:父-子ListView深度交互终极指南

场景痛点:当ListView遇上"套娃式"数据绑定在复杂的WPF企业级开发中,我们经常会遇到这样的需求:在父级ListView的每一项中嵌套子ListView,且子控件需要访问父级数据上下文。这种"...

在 WPF 项目中使用 WPFDevelopers NuGet 包

...

取消回复欢迎 发表评论: