文档章节

jsp---->Jsp语法

小强斋太
 小强斋太
发布于 2016/11/09 20:08
字数 1228
阅读 0
收藏 0

1、jsp注释

JSP注释常用的有两种:HTML注释和隐藏注释(JSP专有注释)

◆显式注释:HTML 注释:最终会发送到客户端,通过右键查看源文件可以发现这些注释

注释说明:能在客户端显示的一个注释,标记内的所有JSP脚本元素、指令和动作正常执行,也就是说编译器会扫描注释内的代码。

HTML语法:<!—注释-->

语法示例:

例1

<!—这段注释显示在客户端的浏览器页面中 -->

在客户端的HTML源代码中产生和上面一样的数据;
例2

<!—这个页面加载于 <%= (new java.util.Date()).toString()%> -->

在客户端的HTML源代码中显示为:

<!--这个页面加载于Sat May 08 19:51:56 CST 2010 -->

小结:可以在注释中使用任何有效的JSP表达式。表达式是动态的,当用户第一次调用该页面或该页面后来被重新调用时,该表达式将被重新赋值。JSP引擎对HTML注释中的表达式执行完后,其执行的结果将代替JSP语句。然后该结果和HTML注释中的其它内容一起输出到客户端。在客户端的浏览器中,浏览者可通过查看源文件的方法看到该注释。

◆隐藏注释(JSP注释):

注释说明:用隐藏注释标记的字符会在JSP编译时被忽略掉,标记内的所有JSP脚本元素、指令和动作都将不起作用。也就是说,JSP编译器不会对注释符之间的任何语句进行编译,其中的任何代码都不会显示在客户端浏览器的任何位置。

JSP语法:<%--注释  --%>

注释示例:

<%@ page language="java" %>

<html>

<head><title>注释测试</title></head>

<body>

<h2>注释测试</h2>

<%--在页面源代码中,这个注释是看不见的 --%>

</body>

</html>

小结:JSP引擎对JSP注释不作任何处理。JSP注释既不发送到客户端,也不在客户端的JSP页面中显示。在客户端查看源文件时也看不到。因此,如果只想在JSP页面源程序中写文档说明时,JSP注释是很有用的。

2、jsp输出

<%! %>:                             声明全局变量、类、方法全局变量,实例化一次,
<%=输出值%>:                  表达式 类似于:out.println() ;

<% int i=0; out.print(i);%>     java脚本代码中声明的为局部变量

<html>
<head>
	<title>JSP</title>
</head>
<body>
<table border="1">
<%
	// 打印9×9的表格
	for(int i=0;i<9;i++)
	{
%>
		<tr>
<%
		for(int j=0;j<9;j++)
		{
%>
			<td><%=i*j%></td>
<%
		}
%>
		</tr>
<%
	}
%>
</table>
</body>
</html>

3、Scriptlet(脚本小程序)

< %
if(xxx)
{
%>
< %
}
%>

4、form 表单提交方式的讨论:
· post:提交内容不会显示,没有长度要求
· get:提交的内容会显示出来 , 地址栏中的长度只有 4k~5k,如果传递大数据,则无法使用

5、page指令

<%@ page contentType="text/html;charset=gb2312"%>
< %@ page import="java.util.*"%>

<%@ page import="java.io.*,java.sql.*"%>



       <%@ page 

 

  [ language="java" ] 

 

  [ extends="package.class" ]

 

  [ import="{package.class | package.*}, ..." ]

 

  [ session="true | false" ] 

 

  [ buffer="none | 8kb | sizekb" ]

 

  [ autoFlush="true | false" ]

 

  [ isThreadSafe="true | false" ]

 

  [ info="text" ] 

 

  [ errorPage="relativeURL" ]

 

  [ contentType="mimeType [ ;charset=characterSet ]" | "text/html ; charset=ISO-8859-1" ]

 

  [ isErrorPage="true | false" ]

 

  %>

属性说明

  • language="java"   声明脚本语言的种类,暂时只能用"java"
  • extends="package.class"   标明JSP编译时需要加入的Java Class的全名,但是得慎重的使用它,它会限制JSP的编译能力. import="{package.class | package.* }, ..." 需要导入的Java包的列表,这些包可以多次导入,也可以以逗号隔开
  • session="true | false" 设定客户是否需要HTTP Session,如果它为true,那么Session是有用的。如果它有false,那么你就不能使用session对象,以及定义了scope=session的<jsp:useBean>元素。这样的使用会导致错误. 缺省值是true.
  • buffer="none | 8kb | sizekb" ,buffer的大小被out对象用于处理执行后的JSP对客户浏览器的输出。缺省值是8kb
  • autoFlush="true | false" ,设置如果buffer溢出,是否需要强制输出,如果其值被定义为true(缺省值),输出正常,如果它被设置为false,如果这个buffer溢出,就会导致一个意外错误的发生.如果你把buffer设置为none,那么你就不能把autoFlush设置为false.
  •  isThreadSafe="true | false" 设置Jsp文件是否能多线程使用。缺省值是true,也就是说,JSP能够同时处理多个用户的请求,如果设置为false,一个jsp只能一次处理一个请求
  • info="text" 一个文本在执行JSP将会被逐字加入JSP中,你能够使用Servlet.getServletInfo方法取回。
  • errorPage="relativeURL"  设置处理异常事件的JSP文件。
  •  isErrorPage="true | false" 设置此页是否为出错页,如果被设置为true,你就能使用exception对象.
  •  contentType="mimeType [ ;charset=characterSet ]" | "text/html;charset=ISO-8859-1" 设置MIME类型 。缺省MIME 类型是: text/html, 缺省字符集为 ISO-8859-1. 解决中文乱码问题

本文转载自:http://www.cnblogs.com/xqzt/archive/2012/08/17/5637268.html

共有 人打赏支持
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
私信 提问
(JavaEE-07)JSP.md

JSP JSP全称是Java Server Pages,它和Servlet技术一样,都是SUN公司定义的一种用于开发动态Web资源的技术。JSP的编写就像编写HTML一样简单,但是与HTML不同的是,在JSP中,可以编写Java代码...

_-Leon-_
2014/07/04
0
0
jsp中include乱码的三种解决方案

问题描述:<%@ include file="/footer.html" %> 的中文乱码问题 第一种情况可以修改被include的文件: 1.当jsp include动态文件时(jsp文件)可以在被include的jsp文件头部加上代码: <%@ pa...

扁-哥
2013/04/12
0
0
web 基础巩固——JSP基础

本文按照官网文档总结,但是有可能会理解错误,学习时尽量和其他网站进行对比,同时也欢迎指出错误,好让我及时改正 什么是JSP页面? JSP页面是一个文本文档,包含两种类型的文本:静态数据,...

SXJR
11/26
0
0
tomcat 5.5 部署项目报错 关于Filter的错误。。

我在tomcat7.0部署没不报错,但是再tomcat5.5就会报错。。 listener.ContextListener UrlRewriteFilter org.tuckey.web.filters.urlrewrite.UrlRewriteFilter logLevel WARN UrlRewriteFilte......

庄泽锐
2014/03/06
1K
5
JSP语法的xml写法

大家总是不喜欢看到<%和%>在jsp页面上,其实我们可以使用比较优雅的xml方式来表达 1,隐含的注释 JSP语法:<%-- 内容 --%> XML语法:无 2,变量或函数的声明 JSP语法:<%! declaration;[decla...

crazyinsomnia
2010/03/23
249
0

没有更多内容

加载失败,请刷新页面

加载更多

vuex进阶知识点巩固

我们先回忆一下上一篇的代码 computed:{ getName(){ return this.$store.state.name }} 这里假设现在逻辑有变,我们最终期望得到的数据(getName),是基于 this.$store.state.na...

嫣然丫丫丫
10分钟前
1
0
Python出现安全策略问题的解决方法

Python运行期间出现如下错误 import: attempt to perform an operation not allowed by the security policy `PS' @ error/constitute.c/IsCoderAuthorized/408. 解决方法:在脚本的开头添加......

大糊涂
17分钟前
1
0
Angularjs实现控制器之间通信方式示例

利用angularjs开发项目中,控制器之间的通信,比如参数的传递,数据的传递,都是比较常见的。控制器之间的通信,显得尤为重要。常见的方式有如下两种:一、angular服务的方式;二、基于事件广...

前端攻城老湿
25分钟前
1
0
xshell使用xftp传输文件

12月11日任务 15.4 xshell使用xftp传输文件 15.5 使用pure-ftpd搭建ftp服务 1.xshell使用xftp传输文件 示例一:xshell使用sftp传输文件 新建一个会话 定义为sftp 连接登入 可以get文件,下载...

hhpuppy
27分钟前
2
0
深入解析Vuex实战总结

这篇文章主要介绍了Vuex的初探与实战小结,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 1.背景 最近在做一个单页面的管理后台项...

前端攻城小牛
28分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部