sp的出現(xiàn)
原始的界面由servlet中使用response.write()輸出,但是特別復(fù)雜
出現(xiàn)了jsp=html +java+css+js+jsp的語法
html只能展示靜態(tài)的數(shù)據(jù),結(jié)合java和jsp的語法實現(xiàn)了動態(tài)的展示數(shù)據(jù)
jsp的語法
<%@page import="java.util.Date"%> <%@page language="java" pageEncoding="UTF-8"%>
執(zhí)行流程
jsp文件>>翻譯為.java>>編輯為,class>>裝載起來
翻譯的文件:在work下, \work\Catalina\localhost\ROOT\org\apache\jsp
相關(guān)代碼在_jspService()方法中();所以在方法中不能定義再方法
<% %> 包含的是java代碼 <%! %> 全局的 <%=%> 輸出語句 <!-- 注釋內(nèi)容--> html的注釋 <%-- 該部分注釋在網(wǎng)頁中不會被顯示--%> jsp的注解 在瀏覽器中不會顯示
jsp常見指令
<%@ page ...%> 引入依賴比如腳本文件 error頁面 容器提供當(dāng)前頁面的使用說明。一個JSP頁面可以包含多個page指令 import="java.util.*"; <%@ include ...%> 包含其他文件 <%@ taglib ...%> 引入標(biāo)簽庫 頭部命令 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
jsp九大對象
include的區(qū)別
hello.jsp文件包含以下代碼 <%@include file="footer.jsp" %> footer.jsp的內(nèi)容會被插入到 hello.jsp 轉(zhuǎn)譯 成的hello_jsp.java中,最后只會生成一個hello_jsp.java文件 <jsp:include page="footer.jsp" /> footer.jsp的內(nèi)容不會被插入到 hello.jsp 轉(zhuǎn)譯 成的hello_jsp.java中, 還會有一個footer_jsp.java獨立存在。 hello_jsp.java 會在服務(wù)端訪問footer_jsp.java, 然后把返回的結(jié)果,嵌入到響應(yīng)中。
JSTL
導(dǎo)入
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
常見的jstl語句
<C:if test=""></c:if> <c:choose> <c:when test="">//todo </c:when> <c:otherwise>//todo</c:otherwise> </c:choose> <c:forEach items="${list}" var="listItem" varStatus="1" > <tr> <td><c:out value="${listItem.col1}" /></td> <td><c:out value="${listItem.col2}" /></td> </tr> </c:forEach> fmt 格式化 <%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix='fmt' %> 日期 <% Date now=new Date(); pageContext.setAttribute("now",now); %> 完整日期: <fmt:formatDate value="${now}" pattern="G yyyy年MM月dd日 E"/><br> 完整時間: <fmt:formatDate value="${now}" pattern="a HH:mm:ss.S z"/><br> 常見格式: <fmt:formatDate value="${now}" pattern="yyyy-MM-dd HH:mm:ss"/> 數(shù)字格式化 <fmt:formatNumber 表示格式化數(shù)字 minFractionDigits 小數(shù)點至少要有的位數(shù) maxFractionDigits 小數(shù)點最多能有的位數(shù) <fmt:formatNumber type="number" value="${money}" minFractionDigits="2"/>
EL表達(dá)式
引入
<%@page 標(biāo)簽里加上isELIgnored="false" <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false"%> 取值順序 pageContext>request>session>application 使用${key} 取值 支持表達(dá)式 大小于 equals等,三元運算符
轉(zhuǎn)發(fā)與轉(zhuǎn)向的區(qū)別
轉(zhuǎn)發(fā)(forward
轉(zhuǎn)發(fā)通過forword帶走request的response,所以能帶走對象,可以共享數(shù)據(jù),地址欄不會改變,經(jīng)歷了一次請求,在服務(wù)端完成的處理,
WEB-INF下的頁面不能通過地址欄訪問,需要經(jīng)過轉(zhuǎn)發(fā)才能訪問
轉(zhuǎn)向(redirect)
轉(zhuǎn)向,請求到這里之后,告訴瀏覽器需要進(jìn)行二次請求,所以瀏覽器地址改變,數(shù)據(jù)也不能共享了,兩次請求的效率也比與轉(zhuǎn)發(fā)的一次請求慢低一些.
瀏覽器地址改變了,就可以跳轉(zhuǎn)到當(dāng)前web意外的頁面
困難行業(yè)企業(yè)穩(wěn)就業(yè)補貼”線上經(jīng)辦系統(tǒng)已上線運行啦!符合條件的企業(yè)可通過上海市人力資源和社會保障自助經(jīng)辦系統(tǒng)的“惠企點單辦”申請。具體步驟趕緊往下看:
01
登錄“上海市人力資源和社會保障自助經(jīng)辦系統(tǒng)”(https://zzjb.rsj.sh.gov.cn/zzjbdl/jsp/login.html)。
02
03
選擇“困難行業(yè)企業(yè)穩(wěn)就業(yè)補貼”事項,點擊“辦理”。
04
企業(yè)確認(rèn)承諾書內(nèi)容,點擊“下一步”。
05
系統(tǒng)自動檢驗后顯示企業(yè)相關(guān)信息,需填寫補貼申請經(jīng)辦人信息。
06
企業(yè)可根據(jù)實際,點擊“登記/修改銀行賬號”進(jìn)入銀行賬號修改界面,更改補貼擬發(fā)放賬戶信息。
07
系統(tǒng)自動提取企業(yè)統(tǒng)一社會信用代碼證書等電子資料,若提取失敗,須自行上傳相關(guān)影像資料,完成后點擊“下一步”。
08
確認(rèn)申請信息無誤后(重點核對“銀行賬戶”“聯(lián)系手機”“上月應(yīng)繳城鎮(zhèn)職工社會保險人數(shù)”等關(guān)鍵信息),點擊“確認(rèn)提交”。
表達(dá)式語言(Expression Language,EL),EL表達(dá)式是用"${}"括起來的腳本,用來更方便的讀取對象!
<%@ page language="java" contentType="text/html" pageEncoding="UTF-8"%> <html> <head> <title>向session設(shè)置一個屬性</title> </head> <body> <% //向session設(shè)置一個屬性 session.setAttribute("name", "aaa"); System.out.println("向session設(shè)置了一個屬性"); %> </body> </html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title></title> </head> <body> <% String value=(String) session.getAttribute("name"); out.write(value); %> </body> </html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title></title> </head> <body> ${name} </body> </html>
${標(biāo)識符}
獲取各類數(shù)據(jù)
獲取域?qū)ο蟮臄?shù)據(jù)
<% //向ServletContext設(shè)置一個屬性 application.setAttribute("name", "aaa"); System.out.println("向application設(shè)置了一個屬性"); %>
<% ${name} %>
獲取JavaBean的屬性
<jsp:useBean id="person" class="domain.Person" scope="session"/> <jsp:setProperty name="person" property="age" value="22"/>
在2.jsp中取出Session的屬性
<% Person person=(Person) session.getAttribute("person"); System.out.println(person.getAge()); %>
//等同于person.getAge() ${person.age}
獲取集合的數(shù)據(jù)
<% List<Person> list=new ArrayList(); Person person1=new Person(); person1.setUsername("zhongfucheng"); Person person2=new Person(); person2.setUsername("ouzicheng"); list.add(person1); list.add(person2); session.setAttribute("list",list); %>
<% List<Person> list=(List) session.getAttribute("list"); out.write(list.get(0).getUsername()+"<br>"); out.write(list.get(1).getUsername()); %>
使用EL表達(dá)式又是怎么樣的效果呢?我們來看看!
<%--取出list集合的第1個元素(下標(biāo)從0開始),獲取username屬性--%> ${list[0].username} <br> <%--取出list集合的第2個元素,獲取username屬性--%> ${list[1].username}
<% Map<String, Person> map=new HashMap<>(); Person person1=new Person(); person1.setUsername("zhongfucheng1"); Person person2=new Person(); person2.setUsername("ouzicheng1"); map.put("aa",person1); map.put("bb",person2); session.setAttribute("map",map); %>
${map.aa.username} <br> ${map.bb.username}
${map["1"].username} <br> ${map["2"].username}
EL運算符
<% List<Person> list=null; %> ${list==null?"list集合為空":"list集合不為空"}
EL表達(dá)式11個內(nèi)置對象
EL表達(dá)式主要是來對內(nèi)容的顯示,為了顯示的方便,EL表達(dá)式提供了11個內(nèi)置對象。
<%--pageContext內(nèi)置對象--%> <% pageContext.setAttribute("pageContext1", "pageContext"); %> pageContext內(nèi)置對象:${pageContext.getAttribute("pageContext1")} <br> <%--pageScope內(nèi)置對象--%> <% pageContext.setAttribute("pageScope1","pageScope"); %> pageScope內(nèi)置對象:${pageScope.pageScope1} <br> <%--requestScope內(nèi)置對象--%> <% request.setAttribute("request1","reqeust"); %> requestScope內(nèi)置對象:${requestScope.request1} <br> <%--sessionScope內(nèi)置對象--%> <% session.setAttribute("session1", "session"); %> sessionScope內(nèi)置對象:${sessionScope.session1} <br> <%--applicationScope內(nèi)置對象--%> <% application.setAttribute("application1","application"); %> applicationScopt內(nèi)置對象:${applicationScope.application1} <br> <%--header內(nèi)置對象--%> header內(nèi)置對象:${header.Host} <br> <%--headerValues內(nèi)置對象,取出第一個Cookie--%> headerValues內(nèi)置對象:${headerValues.Cookie[0]} <br> <%--Cookie內(nèi)置對象--%> <% Cookie cookie=new Cookie("Cookie1", "cookie"); %> Cookie內(nèi)置對象:${cookie.JSESSIONID.value} <br> <%--initParam內(nèi)置對象,需要為該Context配置參數(shù)才能看出效果【jsp配置的無效!親測】--%> initParam內(nèi)置對象:${initParam.name} <br>
注意事項:
<form action="/zhongfucheng/1.jsp" method="post"> 用戶名:<input type="text" name="username"><br> 年齡:<input type="text " name="age"><br> 愛好: <input type="checkbox" name="hobbies" value="football">足球 <input type="checkbox" name="hobbies" value="basketball">籃球 <input type="checkbox" name="hobbies" value="table tennis">兵乓球<br> <input type="submit" value="提交"><br> </form>
${param.username} <br> ${param.age} <br> //沒有學(xué)習(xí)jstl之前就一個一個寫吧。 ${paramValues.hobbies[0]} <br> ${paramValues.hobbies[1]} <br> ${paramValues.hobbies[2]} <br>
EL表達(dá)式回顯數(shù)據(jù)
EL表達(dá)式最大的特點就是:如果獲取到的數(shù)據(jù)為null,輸出空白字符串""!這個特點可以讓我們數(shù)據(jù)回顯
<%--模擬數(shù)據(jù)回顯場景--%> <% User user=new User(); user.setGender("male"); //數(shù)據(jù)回顯 request.setAttribute("user",user); %> <input type="radio" name="gender" value="male" ${user.gender=='male'?'checked':'' }>男 <input type="radio" name="gender" value="female" ${user.gender=='female'?'checked':'' }>女
EL自定義函數(shù)用于擴(kuò)展EL表達(dá)式的功能,可以讓EL表達(dá)式完成普通Java程序代碼所能完成的功能
步驟:
public static String filter(String message) { if (message==null) return (null); char content[]=new char[message.length()]; message.getChars(0, message.length(), content, 0); StringBuilder result=new StringBuilder(content.length + 50); for (int i=0; i < content.length; i++) { switch (content[i]) { case '<': result.append("<"); break; case '>': result.append(">"); break; case '&': result.append("&"); break; case '"': result.append("""); break; default: result.append(content[i]); } } return (result.toString()); }
<?xml version="1.0" encoding="ISO-8859-1"?> <taglib xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd" version="2.1"> <tlib-version>1.0</tlib-version> <short-name>myshortname</short-name> <uri>/zhongfucheng</uri> <!--函數(shù)的描述--> <function> <!--函數(shù)的名字--> <name>filter</name> <!--函數(shù)位置--> <function-class>utils.HTMLFilter</function-class> <!--函數(shù)的方法聲明--> <function-signature>java.lang.String filter(java.lang.String)</function-signature> </function> </taglib>
<%@ page language="java" contentType="text/html" pageEncoding="UTF-8" %> <%@taglib prefix="fn" uri="/WEB-INF/zhongfucheng.tld" %> <html> <head> <title></title> </head> <body> //完成了HTML轉(zhuǎn)義的功能 ${fn:filter("<a href='#'>點我</a>")} </body> </html>
<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
contains:${fn:contains("zhongfucheng",zhong )}<br> containsIgnoreCase:${fn:containsIgnoreCase("zhongfucheng",ZHONG )}<br> endsWith:${fn:endsWith("zhongfucheng","eng" )}<br> escapeXml:${fn:escapeXml("<zhongfucheng>你是誰呀</zhongfucheng>")}<br> indexOf:${fn:indexOf("zhongfucheng","g" )}<br> length:${fn:length("zhongfucheng")}<br> replace:${fn:replace("zhongfucheng","zhong" ,"ou" )}<br> split:${fn:split("zhong,fu,cheng","," )}<br> startsWith:${fn:startsWith("zhongfucheng","zho" )}<br> substring:${fn:substring("zhongfucheng","2" , fn:length("zhongfucheng"))}<br> substringAfter:${fn:substringAfter("zhongfucheng","zhong" )}<br> substringBefore:${fn:substringBefore("zhongfucheng","fu" )}<br> toLowerCase:${fn:toLowerCase("zhonGFUcheng")}<br> toUpperCase:${fn:toUpperCase("zhongFUcheng")}<br> trim:${fn:trim(" zhong fucheng ")}<br> <%--將分割成的字符數(shù)組用"."拼接成一個字符串--%> join:${fn:join(fn:split("zhong,fu,cheng","," ),"." )}<br>
<% User user=new User(); String likes[]={"sing"}; user.setLikes(likes); //數(shù)據(jù)回顯 request.setAttribute("user",user); %> <%--java的字符數(shù)組以","號分割開,首先拼接成一個字符串,再判讀該字符串有沒有包含關(guān)鍵字,如果有就checked--%> <input type="checkbox"${ fn:contains(fn:join(user.likes,","),"sing")?'checked':'' }>唱歌 <input type="checkbox"${ fn:contains(fn:join(user.likes,","),"dance")?'checked':'' }>跳舞
原文鏈接:https://dwz.cn/bOdF7S6R
作者:Java3y
*請認(rèn)真填寫需求信息,我們會在24小時內(nèi)與您取得聯(lián)系。