用过AJAX的朋友肯定知道javascript是使用UTF-8国际编码,即每个汉字用3个字节来存储,但是这就造成了用AJAX来send数据的时候出现乱码。
有一种解决办法就是使用encodeURIComponent加上修改 Content-Type 为 application/x-www-form-urlencoded\" 来把数据统一编码成 url 格式,但是这样做有一个弊端,使用php的urldecode根本不能得到正确的文字。
另一种方法就是通过vbscript 的写的函数把数据转成gb2312格式的,我个人觉得这种方法比较好。有兴趣的朋友可以到网上去查一下。
今天突发奇想,AJAX调用的时候会不会发送cookie 呢?马上写了一个程序测试一下,果然能,这样就可以在调用ajax之前,先把数据通过javascript写到cookie里,然后再send就可以将cookie里的数据发送出去了,太爽了!!
客户端代码 ajax.htm
function getReady()
{
if(xh.readyState==4)
{
if(xh.status==200)
{
oDiv.innerHTML = \"完成\"
}
else
{
oDiv.innerHTML = \"抱歉,装载数据失败。原因:\" + xh.statusText
}
}
} //author : longbill www.longbill.cn
function setcookie(name,value)
{
var cookiestr=name+\"=\"+value+\";\";
var expires = \"\";
var cookieexp=60*60*1000;
var d = new Date();
d.setTime( d.getTime() + cookieexp);
expires = \"expires=\" + d.toGMTString()+\";\";
document.cookie = cookiestr+ expires;
}
function $(a)
{
return document.getElementById(a);
}
</script>
<body>
AJAX使用cookie传值例子:<br>
<form name=myform>
name:<input id=name value=\"变量名甚至可以是中文\" size=20><br>
value:<input type=text size=20 id=val value=这里><br>
<input onclick=\"getXML()\" type=\"button\" value=\"送出数据\">
<input onclick=\"if(xh && xh.responseText) {alert(xh.responseText);}\" type=\"button\" value=\"显示返回结果\"><br>
<div id=m bgcolor=blue>在此显示状态</div>
<input type=button onclick=\"alert(document.cookie)\" value=显示本地COOKIE>
</form>
本文地址:https://www.stayed.cn/item/5816
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我