ajax 出现乱码的原因

在使用ajax的时候,老会遇到乱码原因。查了资料,很多解决方法,但发现,很多都不实用。后来自己用了两个方法

 

1-----------------------

 var req = null;
 var url = "。。。。。。。。。";
 var post = "page=1&keyWord=中国";
 
 if (window.XMLHttpRequest){
  req = new XMLHttpRequest();
 } else if(window.ActiveXObject){
        req=new ActiveXObject("Microsoft.XMLHttp");
    }
    if(req){
     req.open("POST",url,true);
     req.setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=UTF-8");
     req.send(post); //发送请求
       req.onreadystatechange=function(){
        if(req.readystate==4){
         if(req.status==200){

          document.getElementById("news_v").innerHTML=req.responseText;
          } else {
           alert("服务端返回状态:" + req.status + " " + req.statusText);
          }
      } else {
       document.getElementById ("news_v").innerHTML ="数据加载中...";
   }
  }
     
    }

 

2------------------------------------

 var req = null;
 var url = ".................";
 var post = "page=1&keyWord=中国";
 post = encodeURI(post);
 post = encodeURI(post);//两次
 
 if (window.XMLHttpRequest){
  req = new XMLHttpRequest();
 } else if(window.ActiveXObject){
        req=new ActiveXObject("Microsoft.XMLHttp");
    }
    if(req){
     req.open("POST",url,true);
     req.setrequestheader("cache-control","no-cache"); 

     req.setrequestheader("Content-Type","application/x-www-form-urlencoded");

     req.send(post); //发送请求
       req.onreadystatechange=function(){
        if(req.readystate==4){
         if(req.status==200){

          document.getElementById("news_v").innerHTML=req.responseText;
          } else {
           alert("服务端返回状态:" + req.status + " " + req.statusText);
          }
      } else {
       document.getElementById ("news_v").innerHTML ="数据加载中...";
   }
  }
     
    }

 

 

我的jsp编码采用的是utf-8

 

 

 

其中第二种方法是别人的

 

 

 

比较发现,其实,他们要不是将编码指定  req.setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=UTF-8");

要不就是将字符直接编码post = encodeURI(post);
 post = encodeURI(post);//两次

 

以上提供给大家参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值