html页面上的JS
<script language="javascript">
var XMLHttpReq;
//创建XMLHttpRequest对象
function createXMLHttpRequest() {
if(window.XMLHttpRequest) { //Mozilla 浏览器
XMLHttpReq = new XMLHttpRequest();
}
else if (window.ActiveXObject) { // IE浏览器
try {
XMLHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
}
//发送请求函数
function sendRequest(url) {
createXMLHttpRequest();
XMLHttpReq.open("GET", url, true);
XMLHttpReq.onreadystatechange = processResponse;//指定响应函数
XMLHttpReq.send(null); // 发送请求
}
// 处理返回信息函数
function processResponse() {
if (XMLHttpReq.readyState == 4) { // 判断对象状态
if (XMLHttpReq.status == 200) { // 信息已经成功返回,开始处理信息
updateList();
} else { //页面不正常
window.alert("您所请求的页面有异常。");
}
}
}
//
function refreshList() {
var sort = document.getElementById("sort").value;
if(sort == "" ) {
clearList();
return;
}
var url = "MyJsp.jsp?sort=" + sort;
sendRequest(url)
} function updateList() {
clearList();
var product = document.getElementById("product");
var results = XMLHttpReq.responseXML.getElementsByTagName("name");
var option = null;
alert(results.length) ;// 输出results.length = 0
for(var i = 0; i < results.length; i++) {
option = document.createElement("option");
option.appendChild(document.createTextNode(results[i].firstChild.nodeValue));
product.appendChild(option);
}
} function clearList() {
var product = document.getElementById("product");
while(product.childNodes.length > 0) {
product.removeChild(product.childNodes[0]);
}
}
</script>发送到JSP页面上的代码
<%
request.setCharacterEncoding("UTF-8");
//接收浏览器端提交的信息
String sort = request.getParameter("sort");
System.out.println("aaaaaaa") ;
//设置输出信息的格式及字符集
response.setContentType("text/xml; charset=UTF-8");
response.setHeader("Cache-Control", "no-cache");
//创建输出流对象
//PrintWriter out1 = response.getWriter();
//依据验证结果输出不同的数据信息
out.println("<response>");
System.out.println("aaaaaaa") ;
//数据库操作
DB db = new DB();
ResultSet rs;
String strSql=null;
//查找该品牌具体型号
/*strSql = "select product.name,product.id from sort,product where sort.id=product.sortid and sort.name='"
+ sort + "'";
*/
strSql="select name from test" ;
rs = db.executeQuery(strSql);
try {
while (rs.next()) {
out.println("<name>" + rs.getString("name") + "</name>");
System.out.println( rs.getString("name")) ;//运行时输出有值
}
} catch (SQLException e) {
e.printStackTrace();
}
out.println("</response>");
//out.clear();
%>
我初学AJAX 不知道为什么 从JSP将数据回传到HTML页面时候function updateList()中RS为0 导致第2个列表不能更新数据。请教了。JSP是不是要设置回传路径?要程序知道将参数传回哪个html页面? 还是怎么样 ?
<script language="javascript">
var XMLHttpReq;
//创建XMLHttpRequest对象
function createXMLHttpRequest() {
if(window.XMLHttpRequest) { //Mozilla 浏览器
XMLHttpReq = new XMLHttpRequest();
}
else if (window.ActiveXObject) { // IE浏览器
try {
XMLHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
}
//发送请求函数
function sendRequest(url) {
createXMLHttpRequest();
XMLHttpReq.open("GET", url, true);
XMLHttpReq.onreadystatechange = processResponse;//指定响应函数
XMLHttpReq.send(null); // 发送请求
}
// 处理返回信息函数
function processResponse() {
if (XMLHttpReq.readyState == 4) { // 判断对象状态
if (XMLHttpReq.status == 200) { // 信息已经成功返回,开始处理信息
updateList();
} else { //页面不正常
window.alert("您所请求的页面有异常。");
}
}
}
//
function refreshList() {
var sort = document.getElementById("sort").value;
if(sort == "" ) {
clearList();
return;
}
var url = "MyJsp.jsp?sort=" + sort;
sendRequest(url)
} function updateList() {
clearList();
var product = document.getElementById("product");
var results = XMLHttpReq.responseXML.getElementsByTagName("name");
var option = null;
alert(results.length) ;// 输出results.length = 0
for(var i = 0; i < results.length; i++) {
option = document.createElement("option");
option.appendChild(document.createTextNode(results[i].firstChild.nodeValue));
product.appendChild(option);
}
} function clearList() {
var product = document.getElementById("product");
while(product.childNodes.length > 0) {
product.removeChild(product.childNodes[0]);
}
}
</script>发送到JSP页面上的代码
<%
request.setCharacterEncoding("UTF-8");
//接收浏览器端提交的信息
String sort = request.getParameter("sort");
System.out.println("aaaaaaa") ;
//设置输出信息的格式及字符集
response.setContentType("text/xml; charset=UTF-8");
response.setHeader("Cache-Control", "no-cache");
//创建输出流对象
//PrintWriter out1 = response.getWriter();
//依据验证结果输出不同的数据信息
out.println("<response>");
System.out.println("aaaaaaa") ;
//数据库操作
DB db = new DB();
ResultSet rs;
String strSql=null;
//查找该品牌具体型号
/*strSql = "select product.name,product.id from sort,product where sort.id=product.sortid and sort.name='"
+ sort + "'";
*/
strSql="select name from test" ;
rs = db.executeQuery(strSql);
try {
while (rs.next()) {
out.println("<name>" + rs.getString("name") + "</name>");
System.out.println( rs.getString("name")) ;//运行时输出有值
}
} catch (SQLException e) {
e.printStackTrace();
}
out.println("</response>");
//out.clear();
%>
我初学AJAX 不知道为什么 从JSP将数据回传到HTML页面时候function updateList()中RS为0 导致第2个列表不能更新数据。请教了。JSP是不是要设置回传路径?要程序知道将参数传回哪个html页面? 还是怎么样 ?
拼装起来...
response.setContentType("text/html");
response.setCharacterEncoding("UTF-8");
response.getWriter().print(str.toString());在JSP里
function processResponse() {
if (XMLHttpReq.readyState == 4) { // 判断对象状态
if (XMLHttpReq.status == 200) { // 信息已经成功返回,开始处理信息
var info = XMLHttpReq.responseText; //这个就是你action拼装返回出来的值!你可以把updateList()改成updateList(info)把info传过去
updateList();
} else { //页面不正常
window.alert("您所请求的页面有异常。");
}
}
}
alert(info) ; 看的到了
可是怎么在里面
function updateList(info) {
clearList();
var product = document.getElementById("product");
var results = XMLHttpReq.responseXML.getElementsByTagName("name");
var option = null;
for(var i = 0; i < results.length; i++) {
option = document.createElement("option");
option.appendChild(document.createTextNode(results[i].firstChild.nodeValue));
product.appendChild(option);
}
}
怎么用info 来构造输出呢?
至于你说的 JSP是不是要设置回传路径?要程序知道将参数传回哪个html页面? 还是怎么样 ?哪个页面请求,服务器端查询的数据 就返回给哪个页面
然后在请求页上 使用js的dom对象调用xml文件中的各个节点的值
然后使用innerHTML 显示在页面中
但是
function updateList() {
clearList();
var product = document.getElementById("product");
var results = XMLHttpReq.responseXML.getElementsByTagName("name");
var option = null;
alert(results.length) ;// 输出results.length = 0
for(var i = 0; i < results.length; i++) {
option = document.createElement("option");
option.appendChild(document.createTextNode(results[i].firstChild.nodeValue));
product.appendChild(option);
}
}
但是XMLHttpReq.responseXML.getElementsByTagName("name"); 取不出东西啊
服务端那边 数据可以输出 ,但是传过html来就接不到
-->>
var results = XMLHttpReq.responseXML.documentElement.getElementsByTagName("name");
放上去没反应
alert(results.length)都不执行
request.setCharacterEncoding("UTF-8");
//接收浏览器端提交的信息
String sort = request.getParameter("sort");
System.out.println("aaaaaaa") ; //设置输出信息的格式及字符集
response.setContentType("text/xml; charset=UTF-8");
response.setHeader("Cache-Control", "no-cache");
//创建输出流对象
//PrintWriter out1 = response.getWriter();
//依据验证结果输出不同的数据信息
out.println(" <response>");
System.out.println("aaaaaaa") ;
//数据库操作
DB db = new DB();
ResultSet rs;
String strSql=null;
//查找该品牌具体型号
/*strSql = "select product.name,product.id from sort,product where sort.id=product.sortid and sort.name='"
+ sort + "'";
*/
strSql="select name from test" ;
rs = db.executeQuery(strSql);
try {
while (rs.next()) {
out.println(" <name>" + rs.getString("name") + " </name>");
System.out.println( rs.getString("name")) ;//运行时输出有值
}
} catch (SQLException e) {
e.printStackTrace();
}
out.println(" </response>");
out.clear();
把这代码放到action里面 html里面的JS不变 就改下URL 就能运行哦
为什么放到JSP里面就不行哦 郁闷