四、處理表單數(shù)據(jù)
更新時(shí)間:2006年10月13日 00:00:00 作者:
4.1 表單數(shù)據(jù)概述
如果你曾經(jīng)使用過(guò)Web搜索引擎,或者瀏覽過(guò)在線書(shū)店、股票價(jià)格、機(jī)票信息,或許會(huì)留意到一些古怪的URL,比如“http://host/path?user=Marty+Hall&origin=bwi&dest=lax”。這個(gè)URL中位于問(wèn)號(hào)后面的部分,即“user=Marty+Hall&origin=bwi&dest=lax”,就是表單數(shù)據(jù),這是將Web頁(yè)面數(shù)據(jù)發(fā)送給服務(wù)器程序的最常用方法。對(duì)于GET請(qǐng)求,表單數(shù)據(jù)附加到URL的問(wèn)號(hào)后面(如上例所示);對(duì)于POST請(qǐng)求,表單數(shù)據(jù)用一個(gè)單獨(dú)的行發(fā)送給服務(wù)器。
以前,從這種形式的數(shù)據(jù)提取出所需要的表單變量是CGI編程中最麻煩的事情之一。首先,GET請(qǐng)求和POST請(qǐng)求的數(shù)據(jù)提取方法不同:對(duì)于GET請(qǐng)求,通常要通過(guò)QUERY_STRING環(huán)境變量提取數(shù)據(jù);對(duì)于POST請(qǐng)求,則一般通過(guò)標(biāo)準(zhǔn)輸入提取數(shù)據(jù)。第二,程序員必須負(fù)責(zé)在“&”符號(hào)處截?cái)嘧兞棵?變量值對(duì),再分離出變量名字(等號(hào)左邊)和變量值(等號(hào)右邊)。第三,必須對(duì)變量值進(jìn)行URL反編碼操作。因?yàn)榘l(fā)送數(shù)據(jù)的時(shí)候,字母和數(shù)字以原來(lái)的形式發(fā)送,但空格被轉(zhuǎn)換成加號(hào),其他字符被轉(zhuǎn)換成“%XX”形式,其中XX是十六進(jìn)制表示的字符ASCII(或者ISO Latin-1)編碼值。例如,如果HTML表單中名為“users”的域值為“~hall, ~gates, and ~mcnealy”,則實(shí)際向服務(wù)器發(fā)送的數(shù)據(jù)為“users=%7Ehall%2C+%7Egates%2C+and+%7Emcnealy”。最后,即第四個(gè)導(dǎo)致解析表單數(shù)據(jù)非常困難的原因在于,變量值既可能被省略(如“param1=val1&param2=&param3=val3”),也有可能一個(gè)變量擁有一個(gè)以上的值,即同一個(gè)變量可能出現(xiàn)一次以上(如“param1=val1&param2=val2&param1=val3”)。
Java Servlet的好處之一就在于所有上述解析操作都能夠自動(dòng)完成。只需要簡(jiǎn)單地調(diào)用一下HttpServletRequest的getParameter方法、在調(diào)用參數(shù)中提供表單變量的名字(大小寫(xiě)敏感)即可,而且GET請(qǐng)求和POST請(qǐng)求的處理方法完全相同。
getParameter方法的返回值是一個(gè)字符串,它是參數(shù)中指定的變量名字第一次出現(xiàn)所對(duì)應(yīng)的值經(jīng)反編碼得到得字符串(可以直接使用)。如果指定的表單變量存在,但沒(méi)有值,getParameter返回空字符串;如果指定的表單變量不存在,則返回null。如果表單變量可能對(duì)應(yīng)多個(gè)值,可以用getParameterValues來(lái)取代getParameter。getParameterValues能夠返回一個(gè)字符串?dāng)?shù)組。
最后,雖然在實(shí)際應(yīng)用中Servlet很可能只會(huì)用到那些已知名字的表單變量,但在調(diào)試環(huán)境中,獲得完整的表單變量名字列表往往是很有用的,利用getParamerterNames方法可以方便地實(shí)現(xiàn)這一點(diǎn)。getParamerterNames返回的是一個(gè)Enumeration,其中的每一項(xiàng)都可以轉(zhuǎn)換為調(diào)用getParameter的字符串。
4.2 實(shí)例:讀取三個(gè)表單變量
下面是一個(gè)簡(jiǎn)單的例子,它讀取三個(gè)表單變量param1、param2和param3,并以HTML列表的形式列出它們的值。請(qǐng)注意,雖然在發(fā)送應(yīng)答內(nèi)容之前必須指定應(yīng)答類型(包括內(nèi)容類型、狀態(tài)以及其他HTTP頭信息),但Servlet對(duì)何時(shí)讀取請(qǐng)求內(nèi)容卻沒(méi)有什么要求。
另外,我們也可以很容易地把Servlet做成既能處理GET請(qǐng)求,也能夠處理POST請(qǐng)求,這只需要在doPost方法中調(diào)用doGet方法,或者覆蓋service方法(service方法調(diào)用doGet、doPost、doHead等方法)。在實(shí)際編程中這是一種標(biāo)準(zhǔn)的方法,因?yàn)樗恍枰苌俚念~外工作,卻能夠增加客戶端編碼的靈活性。
如果你習(xí)慣用傳統(tǒng)的CGI方法,通過(guò)標(biāo)準(zhǔn)輸入讀取POST數(shù)據(jù),那么在Servlet中也有類似的方法,即在HttpServletRequest上調(diào)用getReader或者getInputStream,但這種方法對(duì)普通的表單變量來(lái)說(shuō)太麻煩。然而,如果是要上載文件,或者POST數(shù)據(jù)是通過(guò)專門(mén)的客戶程序而不是HTML表單發(fā)送,那么就要用到這種方法。
注意用第二種方法讀取POST數(shù)據(jù)時(shí),不能再用getParameter來(lái)讀取這些數(shù)據(jù)。
ThreeParams.java
package hall;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class ThreeParams extends HttpServlet {
public void doGet(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "讀取三個(gè)請(qǐng)求參數(shù)";
out.println(ServletUtilities.headWithTitle(title) +
"<BODY>\n" +
"<H1 ALIGN=CENTER>" + title + "</H1>\n" +
"<UL>\n" +
" <LI>param1: "
+ request.getParameter("param1") + "\n" +
" <LI>param2: "
+ request.getParameter("param2") + "\n" +
" <LI>param3: "
+ request.getParameter("param3") + "\n" +
"</UL>\n" +
"</BODY></HTML>");
}
public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
4.3 實(shí)例:輸出所有的表單數(shù)據(jù)
下面這個(gè)例子尋找表單所發(fā)送的所有變量名字,并把它們放入表格中,沒(méi)有值或者有多個(gè)值的變量都突出顯示。
首先,程序通過(guò)HttpServletRequest的getParameterNames方法得到所有的變量名字,getParameterNames返回的是一個(gè)Enumeration。接下來(lái),程序用循環(huán)遍歷這個(gè)Enumeration,通過(guò)hasMoreElements確定何時(shí)結(jié)束循環(huán),利用nextElement得到Enumeration中的各個(gè)項(xiàng)。由于nextElement返回的是一個(gè)Object,程序把它轉(zhuǎn)換成字符串后再用這個(gè)字符串來(lái)調(diào)用getParameterValues。
getParameterValues返回一個(gè)字符串?dāng)?shù)組,如果這個(gè)數(shù)組只有一個(gè)元素且等于空字符串,說(shuō)明這個(gè)表單變量沒(méi)有值,Servlet以斜體形式輸出“No Value”;如果數(shù)組元素個(gè)數(shù)大于1,說(shuō)明這個(gè)表單變量有多個(gè)值,Servlet以HTML列表形式輸出這些值;其他情況下Servlet直接把變量值放入表格。
ShowParameters.java
注意,ShowParameters.java用到了前面介紹過(guò)的ServletUtilities.java。
package hall;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class ShowParameters extends HttpServlet {
public void doGet(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "讀取所有請(qǐng)求參數(shù)";
out.println(ServletUtilities.headWithTitle(title) +
"<BODY BGCOLOR=\"#FDF5E6\">\n" +
"<H1 ALIGN=CENTER>" + title + "</H1>\n" +
"<TABLE BORDER=1 ALIGN=CENTER>\n" +
"<TR BGCOLOR=\"#FFAD00\">\n" +
"<TH>參數(shù)名字<TH>參數(shù)值");
Enumeration paramNames = request.getParameterNames();
while(paramNames.hasMoreElements()) {
String paramName = (String)paramNames.nextElement();
out.println("<TR><TD>" + paramName + "\n<TD>");
String[] paramValues = request.getParameterValues(paramName);
if (paramValues.length == 1) {
String paramValue = paramValues[0];
if (paramValue.length() == 0)
out.print("<I>No Value</I>");
else
out.print(paramValue);
} else {
out.println("<UL>");
for(int i=0; i<paramValues.length; i++) {
out.println("<LI>" + paramValues[i]);
}
out.println("</UL>");
}
}
out.println("</TABLE>\n</BODY></HTML>");
}
public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
測(cè)試表單
下面是向上述Servlet發(fā)送數(shù)據(jù)的表單PostForm.html。就像所有包含密碼輸入域的表單一樣,該表單用POST方法發(fā)送數(shù)據(jù)。我們可以看到,在Servlet中同時(shí)實(shí)現(xiàn)doGet和doPost這兩種方法為表單制作帶來(lái)了方便。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>示例表單</TITLE>
</HEAD>
<BODY BGCOLOR="#FDF5E6">
<H1 ALIGN="CENTER">用POST方法發(fā)送數(shù)據(jù)的表單</H1>
<FORM ACTION="/servlet/hall.ShowParameters"
METHOD="POST">
Item Number:
<INPUT TYPE="TEXT" NAME="itemNum"><BR>
Quantity:
<INPUT TYPE="TEXT" NAME="quantity"><BR>
Price Each:
<INPUT TYPE="TEXT" NAME="price" VALUE="$"><BR>
<HR>
First Name:
<INPUT TYPE="TEXT" NAME="firstName"><BR>
Last Name:
<INPUT TYPE="TEXT" NAME="lastName"><BR>
Middle Initial:
<INPUT TYPE="TEXT" NAME="initial"><BR>
Shipping Address:
<TEXTAREA NAME="address" ROWS=3 COLS=40></TEXTAREA><BR>
Credit Card:<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Visa">Visa<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Master Card">Master Card<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Amex">American Express<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Discover">Discover<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Java SmartCard">Java SmartCard<BR>
Credit Card Number:
<INPUT TYPE="PASSWORD" NAME="cardNum"><BR>
Repeat Credit Card Number:
<INPUT TYPE="PASSWORD" NAME="cardNum"><BR><BR>
<CENTER>
<INPUT TYPE="SUBMIT" VALUE="Submit Order">
</CENTER>
</FORM>
</BODY>
</HTML>
如果你曾經(jīng)使用過(guò)Web搜索引擎,或者瀏覽過(guò)在線書(shū)店、股票價(jià)格、機(jī)票信息,或許會(huì)留意到一些古怪的URL,比如“http://host/path?user=Marty+Hall&origin=bwi&dest=lax”。這個(gè)URL中位于問(wèn)號(hào)后面的部分,即“user=Marty+Hall&origin=bwi&dest=lax”,就是表單數(shù)據(jù),這是將Web頁(yè)面數(shù)據(jù)發(fā)送給服務(wù)器程序的最常用方法。對(duì)于GET請(qǐng)求,表單數(shù)據(jù)附加到URL的問(wèn)號(hào)后面(如上例所示);對(duì)于POST請(qǐng)求,表單數(shù)據(jù)用一個(gè)單獨(dú)的行發(fā)送給服務(wù)器。
以前,從這種形式的數(shù)據(jù)提取出所需要的表單變量是CGI編程中最麻煩的事情之一。首先,GET請(qǐng)求和POST請(qǐng)求的數(shù)據(jù)提取方法不同:對(duì)于GET請(qǐng)求,通常要通過(guò)QUERY_STRING環(huán)境變量提取數(shù)據(jù);對(duì)于POST請(qǐng)求,則一般通過(guò)標(biāo)準(zhǔn)輸入提取數(shù)據(jù)。第二,程序員必須負(fù)責(zé)在“&”符號(hào)處截?cái)嘧兞棵?變量值對(duì),再分離出變量名字(等號(hào)左邊)和變量值(等號(hào)右邊)。第三,必須對(duì)變量值進(jìn)行URL反編碼操作。因?yàn)榘l(fā)送數(shù)據(jù)的時(shí)候,字母和數(shù)字以原來(lái)的形式發(fā)送,但空格被轉(zhuǎn)換成加號(hào),其他字符被轉(zhuǎn)換成“%XX”形式,其中XX是十六進(jìn)制表示的字符ASCII(或者ISO Latin-1)編碼值。例如,如果HTML表單中名為“users”的域值為“~hall, ~gates, and ~mcnealy”,則實(shí)際向服務(wù)器發(fā)送的數(shù)據(jù)為“users=%7Ehall%2C+%7Egates%2C+and+%7Emcnealy”。最后,即第四個(gè)導(dǎo)致解析表單數(shù)據(jù)非常困難的原因在于,變量值既可能被省略(如“param1=val1&param2=&param3=val3”),也有可能一個(gè)變量擁有一個(gè)以上的值,即同一個(gè)變量可能出現(xiàn)一次以上(如“param1=val1&param2=val2&param1=val3”)。
Java Servlet的好處之一就在于所有上述解析操作都能夠自動(dòng)完成。只需要簡(jiǎn)單地調(diào)用一下HttpServletRequest的getParameter方法、在調(diào)用參數(shù)中提供表單變量的名字(大小寫(xiě)敏感)即可,而且GET請(qǐng)求和POST請(qǐng)求的處理方法完全相同。
getParameter方法的返回值是一個(gè)字符串,它是參數(shù)中指定的變量名字第一次出現(xiàn)所對(duì)應(yīng)的值經(jīng)反編碼得到得字符串(可以直接使用)。如果指定的表單變量存在,但沒(méi)有值,getParameter返回空字符串;如果指定的表單變量不存在,則返回null。如果表單變量可能對(duì)應(yīng)多個(gè)值,可以用getParameterValues來(lái)取代getParameter。getParameterValues能夠返回一個(gè)字符串?dāng)?shù)組。
最后,雖然在實(shí)際應(yīng)用中Servlet很可能只會(huì)用到那些已知名字的表單變量,但在調(diào)試環(huán)境中,獲得完整的表單變量名字列表往往是很有用的,利用getParamerterNames方法可以方便地實(shí)現(xiàn)這一點(diǎn)。getParamerterNames返回的是一個(gè)Enumeration,其中的每一項(xiàng)都可以轉(zhuǎn)換為調(diào)用getParameter的字符串。
4.2 實(shí)例:讀取三個(gè)表單變量
下面是一個(gè)簡(jiǎn)單的例子,它讀取三個(gè)表單變量param1、param2和param3,并以HTML列表的形式列出它們的值。請(qǐng)注意,雖然在發(fā)送應(yīng)答內(nèi)容之前必須指定應(yīng)答類型(包括內(nèi)容類型、狀態(tài)以及其他HTTP頭信息),但Servlet對(duì)何時(shí)讀取請(qǐng)求內(nèi)容卻沒(méi)有什么要求。
另外,我們也可以很容易地把Servlet做成既能處理GET請(qǐng)求,也能夠處理POST請(qǐng)求,這只需要在doPost方法中調(diào)用doGet方法,或者覆蓋service方法(service方法調(diào)用doGet、doPost、doHead等方法)。在實(shí)際編程中這是一種標(biāo)準(zhǔn)的方法,因?yàn)樗恍枰苌俚念~外工作,卻能夠增加客戶端編碼的靈活性。
如果你習(xí)慣用傳統(tǒng)的CGI方法,通過(guò)標(biāo)準(zhǔn)輸入讀取POST數(shù)據(jù),那么在Servlet中也有類似的方法,即在HttpServletRequest上調(diào)用getReader或者getInputStream,但這種方法對(duì)普通的表單變量來(lái)說(shuō)太麻煩。然而,如果是要上載文件,或者POST數(shù)據(jù)是通過(guò)專門(mén)的客戶程序而不是HTML表單發(fā)送,那么就要用到這種方法。
注意用第二種方法讀取POST數(shù)據(jù)時(shí),不能再用getParameter來(lái)讀取這些數(shù)據(jù)。
ThreeParams.java
package hall;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class ThreeParams extends HttpServlet {
public void doGet(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "讀取三個(gè)請(qǐng)求參數(shù)";
out.println(ServletUtilities.headWithTitle(title) +
"<BODY>\n" +
"<H1 ALIGN=CENTER>" + title + "</H1>\n" +
"<UL>\n" +
" <LI>param1: "
+ request.getParameter("param1") + "\n" +
" <LI>param2: "
+ request.getParameter("param2") + "\n" +
" <LI>param3: "
+ request.getParameter("param3") + "\n" +
"</UL>\n" +
"</BODY></HTML>");
}
public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
4.3 實(shí)例:輸出所有的表單數(shù)據(jù)
下面這個(gè)例子尋找表單所發(fā)送的所有變量名字,并把它們放入表格中,沒(méi)有值或者有多個(gè)值的變量都突出顯示。
首先,程序通過(guò)HttpServletRequest的getParameterNames方法得到所有的變量名字,getParameterNames返回的是一個(gè)Enumeration。接下來(lái),程序用循環(huán)遍歷這個(gè)Enumeration,通過(guò)hasMoreElements確定何時(shí)結(jié)束循環(huán),利用nextElement得到Enumeration中的各個(gè)項(xiàng)。由于nextElement返回的是一個(gè)Object,程序把它轉(zhuǎn)換成字符串后再用這個(gè)字符串來(lái)調(diào)用getParameterValues。
getParameterValues返回一個(gè)字符串?dāng)?shù)組,如果這個(gè)數(shù)組只有一個(gè)元素且等于空字符串,說(shuō)明這個(gè)表單變量沒(méi)有值,Servlet以斜體形式輸出“No Value”;如果數(shù)組元素個(gè)數(shù)大于1,說(shuō)明這個(gè)表單變量有多個(gè)值,Servlet以HTML列表形式輸出這些值;其他情況下Servlet直接把變量值放入表格。
ShowParameters.java
注意,ShowParameters.java用到了前面介紹過(guò)的ServletUtilities.java。
package hall;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
public class ShowParameters extends HttpServlet {
public void doGet(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "讀取所有請(qǐng)求參數(shù)";
out.println(ServletUtilities.headWithTitle(title) +
"<BODY BGCOLOR=\"#FDF5E6\">\n" +
"<H1 ALIGN=CENTER>" + title + "</H1>\n" +
"<TABLE BORDER=1 ALIGN=CENTER>\n" +
"<TR BGCOLOR=\"#FFAD00\">\n" +
"<TH>參數(shù)名字<TH>參數(shù)值");
Enumeration paramNames = request.getParameterNames();
while(paramNames.hasMoreElements()) {
String paramName = (String)paramNames.nextElement();
out.println("<TR><TD>" + paramName + "\n<TD>");
String[] paramValues = request.getParameterValues(paramName);
if (paramValues.length == 1) {
String paramValue = paramValues[0];
if (paramValue.length() == 0)
out.print("<I>No Value</I>");
else
out.print(paramValue);
} else {
out.println("<UL>");
for(int i=0; i<paramValues.length; i++) {
out.println("<LI>" + paramValues[i]);
}
out.println("</UL>");
}
}
out.println("</TABLE>\n</BODY></HTML>");
}
public void doPost(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
測(cè)試表單
下面是向上述Servlet發(fā)送數(shù)據(jù)的表單PostForm.html。就像所有包含密碼輸入域的表單一樣,該表單用POST方法發(fā)送數(shù)據(jù)。我們可以看到,在Servlet中同時(shí)實(shí)現(xiàn)doGet和doPost這兩種方法為表單制作帶來(lái)了方便。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE>示例表單</TITLE>
</HEAD>
<BODY BGCOLOR="#FDF5E6">
<H1 ALIGN="CENTER">用POST方法發(fā)送數(shù)據(jù)的表單</H1>
<FORM ACTION="/servlet/hall.ShowParameters"
METHOD="POST">
Item Number:
<INPUT TYPE="TEXT" NAME="itemNum"><BR>
Quantity:
<INPUT TYPE="TEXT" NAME="quantity"><BR>
Price Each:
<INPUT TYPE="TEXT" NAME="price" VALUE="$"><BR>
<HR>
First Name:
<INPUT TYPE="TEXT" NAME="firstName"><BR>
Last Name:
<INPUT TYPE="TEXT" NAME="lastName"><BR>
Middle Initial:
<INPUT TYPE="TEXT" NAME="initial"><BR>
Shipping Address:
<TEXTAREA NAME="address" ROWS=3 COLS=40></TEXTAREA><BR>
Credit Card:<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Visa">Visa<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Master Card">Master Card<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Amex">American Express<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Discover">Discover<BR>
<INPUT TYPE="RADIO" NAME="cardType"
VALUE="Java SmartCard">Java SmartCard<BR>
Credit Card Number:
<INPUT TYPE="PASSWORD" NAME="cardNum"><BR>
Repeat Credit Card Number:
<INPUT TYPE="PASSWORD" NAME="cardNum"><BR><BR>
<CENTER>
<INPUT TYPE="SUBMIT" VALUE="Submit Order">
</CENTER>
</FORM>
</BODY>
</HTML>
相關(guān)文章
hibernate中的增刪改查實(shí)現(xiàn)代碼
在hibernate中的增刪改查的實(shí)現(xiàn)。hibernate是OR框架,也就是對(duì)象關(guān)系框架,有了 hibernate我們就不用再去寫(xiě)SQL語(yǔ)言,我們只需要操縱對(duì)象去進(jìn)行增刪改查。這里今天寫(xiě)的就是在如何應(yīng)用hibernate實(shí)現(xiàn)增刪改查。2009-01-01jsp連接MySQL操作GIS地圖數(shù)據(jù)實(shí)現(xiàn)添加point的功能代碼
本文為大家介紹下使用jsp連接MySQL操作GIS地圖數(shù)據(jù)并實(shí)現(xiàn)添加point的功能,思路及代碼如下,感興趣的朋友可以參考下2013-08-08java對(duì)XML文件的解析、節(jié)點(diǎn)的增加、刪除操作總結(jié)
java對(duì)XML文件的解析、節(jié)點(diǎn)的增加、刪除操作總結(jié),需要的朋友可以參考下。2009-11-11多個(gè)jsp頁(yè)面共享一個(gè)js對(duì)象的超級(jí)方法
兩個(gè)js頁(yè)面要共享一個(gè)就js對(duì)象,用window.top['_CACHE']來(lái)存放這個(gè)變量,即可實(shí)現(xiàn),不同Jsp頁(yè)面直接的對(duì)象共享2014-06-06