首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2EE开发 >

IE上ajax只能响应一次

2012-09-04 
IE下ajax只能响应一次功能是这样的,前台ajax每隔一秒向服务器发送请求,并且将返回的数据在网页中显示出来。

IE下ajax只能响应一次
功能是这样的,前台ajax每隔一秒向服务器发送请求,并且将返回的数据在网页中显示出来。但是在IE下面只有第一次的请求能正常返回,之后的请求服务器是接收到了请求,但是似乎前台得不到响应。

火狐下没问题,一切OK,但是在IE下就有问题,网上查了下可能是缓存问题,但是所有的解决方案都试过了还是不行。
代码如下:

HTML code
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>  <head>    <base href="<%=basePath%>">        <title>My JSP 'index.jsp' starting page</title>    <meta http-equiv="pragma" content="no-cache">    <meta http-equiv="cache-control" content="no-cache">    <meta http-equiv="expires" content="0">        <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">    <meta http-equiv="description" content="This is my page">    <script type="text/javascript" src="json2.js"></script>    <!--    <link rel="stylesheet" type="text/css" href="styles.css">    -->    <script type="text/javascript">    var xmlhttp;    var length = 0;    if (window.XMLHttpRequest)      {// code for IE7+, Firefox, Chrome, Opera, Safari      xmlhttp=new XMLHttpRequest();      }    else      {// code for IE6, IE5      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");      }        function query(){            json();            var t = setTimeout("query()", 1000);  //每隔一秒向服务器发送请求        }        function json(){            xmlhttp.onreadystatechange=function(){                alert(xmlhttp.readyState + " " + xmlhttp.status);  //只有第一次能正常响应                if (xmlhttp.readyState==4 && xmlhttp.status==200)                {                    var query = "";                    var i = 0;                    var result = eval(xmlhttp.responseText);                    if(length < result.length){                    for(;i < result.length; i++){                        query = query + result[i].name + ":" + result[i].text + "\n";                    }                                        document.getElementById("query").value = query;                    length = result.length;                    }                }}                                        xmlhttp.open("GET","/Chat/json?time="+new Date(),true);            xmlhttp.send();                                                }        function add(){            var name = document.getElementById("name").value;            var text = document.getElementById("text").value;            xmlhttp.onreadystatechange=function()              {              if (xmlhttp.readyState==4 && xmlhttp.status==200)                {                                    }              }            xmlhttp.open("GET","/Chat/json?name="+name+"&text="+text+"&mode=add&time="+new Date(),true);            xmlhttp.send();        }    </script>  </head>    <body onload="query()">    <textarea rows="5" cols="30" id="query"></textarea>        <input type="text" id="name">         <textarea rows="5" cols="30" id="text" ></textarea>        <input type="button" value="提交" onclick="add()">  </body></html>


后台代码肯定没问题,因为火狐下一切正常!!!

------解决方案--------------------


你的json()方法是在onload里面调用的,而你执行完Ajax应该是不会重新load页面,所以也没执行,

你可以把json()方法放在add()方法里面调用试试看。。。
[解决办法]
是缓存的原因:按照我说的去试验一下。右键IE属性---->点击设置----->(检查所存网页的较新版本项)选择每次访问页时
[解决办法]
缓存问题。。。 直接在url后面 加上 "&date=" +(new Date().getTime());

热点排行