日期:2014-05-16  浏览次数:20708 次

Ajax怎么传对象

我想用ajax操作 只更新这个div ??
这个div 主要就针对“thisTest” 这个对象。
其实就是更新thisTest这个对象。
但是 我看XMLHttprequest只有responseText和responseXML??
就是说 只能接收Text 和Xml 怎么接收对象呢?

<div id = "TestChangDIV">
<div id="TestNameDIV">
<b>
题目:${thisTest.testName }
</b>
</div>


<div id="TestAnswerDIV">
<c:forEach items="${thisTest.answers}" var="answer" varStatus="a">
${a.index+1 } :
?<input type="checkbox" id="${answer.id }"
? name="check${answer.rightOrNot }">
?<span id='span${answer.rightOrNot }'>${answer.answerValue} </span>
?</input>
?<p />
</c:forEach>
</div>
<div id="descriptionDIV">
<table border="1" style="font-size:13px;color:gray">
<tr>
<th>
本题难度
</th>
<th>
做过本题人数
</th>
<th>
做对本题人数
</th>
<th>
本题来源
</th>
<th>
出题老师
</th>
</tr>
<tr>
<td>
${thisTest.difficulty }
</td>
<td>
${thisTest.doneUc }
</td>
<td>
${thisTest.rightUc }
</td>
<td>
<a href="#">
${thisTest.testFrom }
</a>
</td>
<td>
<a href="#">
${thisTest.teacherName }
</a>
</td>
</tr>
</table>
</div>

<div id="answerDIV">
<div id="judgeDIV" style="color:red"></div>
用时:
<span id="timeDIV"></span>

<p />
本题正确答案将以红色字体显示!
<p />
试题详解:${thisTest.testDesc}
</div>
</div>
?
服务器端如果用 response.getWriter().print("nextTest");
这样发过去的就是text 那要怎么发对象呢?
?
<

解决方法


不难,很简单的。其实responseText和responseXML就是显示内容,你可以读取动态页面里的内容,然后再通过responseText输出,赋值给某个标签里的内容。
发个简单的例子给你参考一下:
/*
?*--------------------------------
?*创建一个XMLHttp实例
?*return object 成功创建返回一个xmlhttp对象实例,否则返回false
?*--------------------------------
?*/
function CreateAjax()
{
? var xmlhttp;
? try
? {
? //Firefox, Opera 8.0+, Safari
? xmlhttp=new XMLHttpRequest();
? }
? catch(e)
? {
? try
? {
? //IE6.0+
? xmlhttp=new ActiveXObject("Msxml2.XMLHTTP");??
? }??
? catch(e)
? {
? try
? {
? //IE5.5+
? xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
? }
? catch(e)
? {
? return false;
? }
? }
? }
? return xmlhttp;
}

/*
?*--------------------------------
?*传输数据
?*--------------------------------
?*/
/*
function handlestatechange(ListID)
{
? var VoteIDContent=document.getElementById("Vote"+ListID+'');
? ??
? if(xmlhttp.readyState==4) //客户端完成请求
? {
? if(xmlhttp.status==0 || xmlhttp.status==200) //服务端完成处理并返回数据
? {
? var ResponseText=unescape(xmlhttp.responseText)
? var r=ResponseText.split(",");
? if(r[0]=="Vote")
? {
? alert("每个IP地址每天限投一票,请不要重复投票!");
? VoteIDContent.innerHTML=r[1];
? }
? else
? {
? VoteIDContent.innerHTML=ResponseText;
? alert('您已投票成功!');
? }
? }
? else
? {
? alert("服务器返回异常!");
? top.location.href='index.asp';
? }
? }
? else
? {
? VoteIDContent.innerHTML='<img src="images/Loading.gif">';
? }
? return VoteIDContent.innerHTML;
}
*/

function Vote(ListID)
{
? if(!ListID)
? {
? alert("请不要提交非法数据!");
? return false;
? }
? var Send_Url='Vote.asp?ListID='+ListID+'&n='+Math.random()+'';//这里添加了一个参数n,表示为一个随