• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    AJAX中文乱码解决新方法分享

    用过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 

    复制代码 代码如下:

    title>AJAX使用cookie传值例子/title>  
    script>  
    var oDiv         
    var xh                
    function getXML()  
    {  
        setcookie($('name').value,$('val').value);  
        oDiv = document.all.m  
        oDiv.innerHTML = "正在装载,请稍侯......."  
        oDiv.style.display= ""  
        xh = new ActiveXObject("Microsoft.XMLHTTP")  
        xh.onreadystatechange = getReady  
        xh.open("POST","a.php",false)  
        xh.send();  
    }  

    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>

    服务器端代码 a.php 

    复制代码 代码如下:

    ?  
    header("Content-type: text/html;charset=GB2312");  
    echo "以下是您送出的所有COOKIE变量及其值\n";  
    print_r($_COOKIE);  
    ?>

    您可能感兴趣的文章:
    • JQuery中Ajax的Post提交在IE下中文乱码的解决方法
    • ajax请求乱码的解决方法(中文乱码)
    • jquery.ajax的url中传递中文乱码问题的解决方法
    • AJAX中文乱码问题探讨及解决
    • 解决ajax+php中文乱码的方法详解
    • JQuery AJAX 中文乱码问题解决
    • ajax中文乱码问题解决方案
    • jquery的ajax()函数传值中文乱码解决方法介绍
    • ajax中文乱码的各种解决办法总结
    • AJAX中文乱码PHP中完美解决方法
    • JQuery AJAX提交中文乱码的解决方案
    • Javascript和Ajax中文乱码吐血版解决方案
    • PHP Ajax中文乱码问题解决方法
    • 一句话解决AJAX中文乱码问题[推荐]
    • ajax+php中文乱码解决办法
    上一篇:Ajax核心技术代码分享
    下一篇:jquery中的ajax如何返回结果而非回调方式即为同顺序执行
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    AJAX中文乱码解决新方法分享 AJAX,中文,乱码,解决,新方法,