JSTL使用总结(1) 核心标签库和SQL标签库

JSTL是JSP的标准标签库,他提供了许多非常实用的功能,免去了我们自定义标签的麻烦,从而达到在JSP页面中无Scriptlet的效果。

JSTL只是方便了我们开发,如果不使用,并不会妨碍我们开发,一般JSTL是与表达式语言一起使用的。

JSTL1.2的包在MyEclipse中配置struts时能够取得。


一、JSTL配置


把JSTL.jar放入tomcat\lib中,并把JSTL.jar中的tld文件放入WEB-INF中,他所提供的tld文件有:

(1)c.tld 核心标签库,提供比如迭代输出等操作。

(2)fmt.tld 格式化操作。

(3)sql.tld 提供sql查询、更新等操作。

(4)x.tld 提供xml的操作。

(5)fn.tld 提供字符串的函数操作,比如contains、startsWith等操作。


二、核心标签库


1.<c:out>


用于输出,一般结构如下:<c:out value="   "    escapeXml="    " default="     "/>

value表示需要输出的值;

escapeXml表示是否需要将类似<转为"&lt";

default表示如果value为null,则输出此语句;


2.<c:set>


用于设置内置对象属性或自定义对象属性,一般结构如下:

(1)<c:set var="    "   value="     "  scope="     "/>

var表示属性的名称;

value表示属性的值;

scope表示存储的范围;

(2)<c:set target="    "  property="    "    value="    "/>

target表示对象名称;

property表示属性名称;

value表示属性的值;


3.<c:remove>


用于移除内置对象属性;一般结构如下:

<c:remove var="    "   scope="     "/>

var表示属性名称;

scope表示属性范围;


4.<c:catch>


用于捕获异常,类似try - catch;一般结构如下:

<c:catch var="    ">

语句

</c:catch>

var用来保存异常的信息;


5.<c:if>


类似if语句,一般结构如下:

<c:if test="     "   var="    "    scope="     ">

执行语句

</c:if>

test 表示判断;

var表示保存判断结果;

scope表示结果保存范围;


6.<c:choose>


用于多重判断;一般结构如下:

<c:choose>

<c:when test = "    ">   <!--用于判断 -->

语句

</c:when>

<c:when test = "    ">

语句

</c:when>

<c:otherwise> <!--当全部的when不成立时,进入 -->

语句

</c:otherwise>

</c:choose>


7.<forEach>


用于迭代输出;一般结构如下:

<c:forEach items="    "    var= "   "    [ begin="    " ]    [ end="     " ]   [   step="    "   ]>

${var}

</c:forEach>

items表示输出的集合;

var表示迭代器的元素;

begin表示从哪个索引开始;

end表示到哪个索引结束;

step表示输出的间隔;


8.<c:forTokens>


用于分隔字符串并迭代输出;一般结构如下:

<c:forTokens items="   "    delims="    "   var="    ">

${var}

</c:forTokens>

items表示字符串;

delims表示分隔符;

var表示迭代器;


9.<c:redirect>


用于客户端跳转,一般结构如下:

<c:redirect url="    " >

<c:param name="   "  value="    "/>     可以传递参数;

</c:redirect>


10.<c:import>


包含某个网页,一般结构如下: 

<c:import url="   "  charEncoding="    " var="     ">

<c:param name="   "  value="   "/>

</c:import>

var表示保存的导入内容对象。

代码实例:

<%@ page contentType="text/html" pageEncoding="GBK" import="java.util.*"%>
<%@ taglib prefix="c" uri="jstl/c"%>
<jsp:useBean id="per" class="org.person.Person" scope="page"/>
<html>
	<head>
		<title></title>
	</head>
	<body>
	<%
		per.setName("xiazdong");
		per.setAge(20);
		pageContext.setAttribute("per",per);
	%>
	<c:out value="${per}" escapeXml="true" default="无内容"/>
	<c:out value="xiazdong"/>
	
	<c:set var="name" value="xiazdong" />
	<h3>姓名:${name}</h3>
	<c:set target="${per}" property="name" value="yxWang"/>
	<c:out value="${per}" escapeXml="true" default="无内容"/>
	<!--设定属性并删除 -->
	<c:set var="attr" value="tmp" scope="request"/>
	<h3>属性为:${attr}</h3>
	<c:remove var="attr" scope="request"/>
	<h3>删除后,属性为:${attr}</h3>
	<c:if test="${30>10}" var="result" scope="page">
		<h3>30比10大</h3>
	</c:if>
	<%
		pageContext.setAttribute("num",15);
	%>
	<c:choose>
		<c:when test="${num<15}">
			<h3>num小于15</h3>
		</c:when>
		<c:when test="${num>15}">
			<h3>num大于15</h3>
		</c:when>
		<c:otherwise>
			<h3>num等于15</h3>
		</c:otherwise>
	</c:choose>
	<%
		List<String> list = new ArrayList<String>();
		list.add("A");
		list.add("B");
		list.add("C");
		list.add("D");
		pageContext.setAttribute("list",list);
	%>
	<c:forEach items="${list}" var="iter">
		${iter}、
	</c:forEach>
	<br />
	<c:forEach items="${list}" var="iter" begin="2">
		${iter}、
	</c:forEach>
	<br />
	<c:forTokens items="a:b:c" delims=":" var="ite">
		${ite}、
	</c:forTokens>
	<br />
	
	</body>
</html>


三、SQL标签库

 

SQL标签库的作用就是只需要一个标签就可以进行数据库连接、增删改查操作;非常方便,但是违背了MVC设计模式:JSP中只有显示操作。

 

1.<sql:setDataSource>

 

此标签用于进行数据库连接,形如:

<sql:setDataSource driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/xiazdong" user="root" password="12345" var="ds"/>

这样就连接了数据库。

 

2.<sql:query>

 

此标签用于查询,形如:

<sql:query sql="    "   var="result"    dataSource="${ds}"  [startRow="    "]    [ maxRows="    "]/>

var中的result存放了结果,查询后怎么显示呢?

startRow表示开始显示的是第几行。

maxRows表示一页能够显示的行数。

因此这个标签可以用于分页

 

<c:forEach items="${result.rows}" var="iter">

     ${iter.name}

     ${iter.age}

</c:forEach>

即可进行迭代输出.

${result.rowCount}返回行数;

3.<sql:update>

 

此标签用于更新数据库记录,形如:

<sql:update sql="    "  var="result"   dataSource="${ds}"/>

 

4.进行类似PreparedStatement功能

 

PreparedStatement能够通过?进行SQL语句的填充,再通过set进行设置。在JSTL中,也是可以实现的,

通过<sql:param value="    "/>和<sql:dateParam type="date" value="     "/>

形如:

request.setAttribute("n","xiazdong");

<sql:query sql="SELECT name FROM emp WHERE name=?" var="result" dataSource="${ds}">

      <sql:param value="${n}"/>

</sql:query>

 

<%@ page contentType="text/html" pageEncoding="GBK"%>
<%@ taglib prefix="c" uri="jstl/c"%>
<%@ taglib prefix="sql" uri="jstl/sql"%>
<html>
	<head></head>
	<body>
		<sql:setDataSource driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/mldn" user="root" password="12345" var="ds"/>
		<sql:query sql="SELECT * FROM emp" var="result" dataSource="${ds}"/>
		<table border="2" width="80%">
			<c:forEach items="${result.rows}" var="iter">
			<tr>
				<td>${iter.empno}</td>
				<td>${iter.ename}</td>
			</tr>
			</c:forEach>
		</table>
		<%
			request.setAttribute("name","zzz");
			request.setAttribute("date",new java.util.Date());
			request.setAttribute("id","2");
		%>
		<sql:update sql="DELETE FROM emp WHERE empno=0" var="dresult" dataSource="${ds}"/>
		<sql:update sql="UPDATE emp SET ename=?,hiredate=? where empno=?" dataSource="${ds}">
			<sql:param value="${name}"/>
			<sql:dateParam value="${date}" type="date"/>
			<sql:param value="${id}"/>
		</sql:update>
	</body>
</html>


四、XML标签库


XML标签库的作用就是能够简单操作XML文件,封装了DOM或者SAX的复杂的步骤,比如DOM解析必须:DocumentBuilderFactory、DocumentBulder等一系列的准备;而JSTL只需要一个标签即可。


1.XPath介绍


在XML标签库中必须要使用XPath,XML文件就像一棵树,XPath能够找到XML中的一个节点。

/    表示根节点;

//   表示任意路径子节点;

../   表示父节点;

@ 表示属性


2.<x:out>


此标签用于输出,形如:

<x:out select="        "/>

select中的内容就是XPath,我们需要找到某个节点 ,并输出其内容。


3.<x:parse>


此标签用于解析XML文件,形如:

<x:parse var="     "   doc="      "/>

doc表示xml文件对象;

var表示解析完的根节点;

一般都是以:

<c:import url="1.xml"     var="xml1"/>

<x:parse doc="${xml1}"   var="root"/>

进行导入并解析;


4.<x:set>


将xml中某个节点的内容保存到一个属性中去;形如:

<x:set select="    "   var="     "     scope="     "/>

select表示XPath路径;

var表示保存的属性;

scope表示保存范围;


5.<x:choose>


此标签类似核心标签库中的<c:choose>,功能是多重判断;

<x:choose>

<x:when select="   ">     //是否存在XPath路径

......

</x:when>

<x:otherwise>

</x:otherwise>

</x:choose>


6.<x:forEach>


迭代输出内容,比如:

<personlist>
	<person>
		<name id="1">xiazdong</name>
		<age>20</age>
	</person>
	<person>
		<name id="2">xzdong</name>
		<age>15</age>
	</person>
</personlist>
我们就可以迭代输出person的内容;因为有两个person;


下面就是迭代输出以上person节点的代码:

<%@ page contentType="text/html" pageEncoding="GBK"%>
<%@ taglib prefix="c" uri="jstl/c"%>
<%@ taglib prefix="x" uri="jstl/x"%>
<html>
	<head></head>
	<body>
		<c:import url="persons.xml" var="pxf" charEncoding="GBK"/>
		<x:parse var="personXml" doc="${pxf}"/>
		
		<x:set select="$personXml//person" var="nameXml"/>
		
		<x:forEach select="$nameXml" var="iter">
			<h3><x:out select="name"/></h3>
		</x:forEach>
	</body>
</html>




 



你可能感兴趣的:(jstl)