原生js调用json方法总结
ajax基础
ajax:无刷新数据读取,读取服务器上的信息
http请求方法:
get:用于获取数据,如浏览帖子
ajax.judgexmlhttprequest('get', 'index.php', function(data){ alert(data); //这是服务器返回的数据 })
post:用于上传数据,如用户注册
var datajson = { name: 'ys',age: 123 } ajax.judgexmlhttprequest('post', 'index.php', function(data){ alert(data); //这是服务器返回的数据 },datajson)
get与post的区别:
get:通过网址传递(放入url中),会将传递的数据放到网址上面,名字=值&名字=值
get方式容量小,安全性低,有缓存
post:不通过网址传递
post容量较大,一般可达2g,安全性相对较高,没有缓存
原生ajax的编写
ajax运行步骤
创建一个ajax对象
非ie6浏览器:
var oajax=new xmlhttprequest();
ie6浏览器:
var oajax=new activexobject("microsoft.xmlhttp");
连接到服务器
ajax.open(方法,文件名,异步传输);
阻止缓存方法:
ajax.open('get','a.txt?t='+new date().gettime(),true);
同步:js中指事情必须一件一件来
异步:js中指多件事情要一起做
ajax是做异步传输的,并不是同步
发送请求
ajax.send();
接收返回值
请求状态监控:onreadystatechange事件:当自己的ajax与服务器之间有通讯时触发,主要通过readystate属性来判断结束没有,结束了也并没有代表成功,status属性来判断
readystate属性:请求状态
0(未初始化)还没有调用open方法
1(载入)已经调用send()方法,正在发送请求
2(载入完成)send()方法完成,已经收到全部相应内容
3(解析)正在解析收到的响应内容
4(完成)响应内容解析完成,可以在客户端调用(完成并不一定成功,需要status来检测是成功还是失败)
status属性:
请求结果,是成功(200)还是失败(404):ajax.status==200
返回值responsetext:
从服务器返回来的文本:ajax.responsetext(返回的值是一个字符串,有时需要进一步处理成其他格式的形式)
oajax.onreadystatechange=function(){ //oajax.readystate: 表示浏览器和服务器之间进行到哪一步了 if(oajax.readystate==4){ //读取完成 if(oajax.status==200){ //读取的结果是成功 alert('成功:'+oajax.responsetext); } } }
将原生ajax封装成一个函数使用,最终编写的原生ajax为:
get方法封装的函数为:
function ajax(url,fnsuccess,fnfaild){ //1.创建ajax对象。js中,使用一个没有定义的变量会报错,使用一个没有定义的属性,是undefined。ie6下使用没有定义的xmlhttprequest会报错,所以当做window的一个属性使用 if (window.xmlhttprequest) { var oajax=new xmlhttprequest();//非ie6 }else{ var oajax=new activexobject("microsoft.xmlhttp");//ie6 } //2.连接到服务器 oajax.open('get',url,true); //3.发送请求 oajax.send(); //4.接收返回值 oajax.onreadystatechange=function(){ //oajax.readystate--浏览器和服务器之间进行到哪一步了 if(oajax.readystate==4){ //读取完成 if(oajax.status==200){ //读取的结果是成功 fnsuccess(oajax.responsetext); //成功时执行的函数 }else{ if(fnfaild){ //判断是否传入失败是的函数,即用户是否关心失败时的结果 fnfaild(oajax.responsetext); //对失败的原因做出处理 } } } } }
post方法封装的函数为:
function ajaxpost(url,id,fnsuccess,fnfaild){ //1.创建ajax对象 if (window.xmlhttprequest) { var xhr=new xmlhttprequest();//非ie6 }else{ var xhr=new activexobject("microsoft.xmlhttp");//ie6 } //2.连接到服务器 xhr.open("post",url,true); //设置头信息 xhr.setrequestheader("content-type","application/x-www-form-urlencoded"); var form=document.getelementbyid(id); //3.发送请求,传递数据 xhr.send(serialize(form)); xhr.onreadystatechange=function(){ if(xhr.readystate==4){ if ((xhr.status>=200 && xhr.status<300) || xhr.status==304) { fnsuccess(xhr.responsetext); }else{ fnfaild(xhr.responsetext); } } }; }
字符集编码:网页和被请求的文件的编码要相同,如都是utf8
缓存,阻止缓存(经常改变的数据等,不能够缓存.主要用于get方法),传参时在路径后面加?+'可变的数据' 可以不影响原数据
ajax('a.txt?t='+new date().gettime(),function(str){ alert(str); },function(str){ alert(str); });
ajax请求动态数据:如json文件
1 ajax返回值是一个字符串,可通过eval转换后来读取返回的数组/json数据
alert(str); alert(typeof(str)); var arr=eval(str); alert(typeof(arr)); alert(arr[1]); alert(arr[1].c);
2 结合dom创建元素,来显示返回的内容
obtn.onclick=function(){ ajax('data/arr3.txt?t='+new date().gettime(),function(str){ var arr=eval(str); for (var i = 0; i < arr.length; i++) { var oli=document.createelement('li'); oli.innerhtml='用户名:<span>'+arr[i].user+'</span>密码:<span>'+arr[i].pass+'</span>'; oul.appendchild(oli); } },function(str){ alert(str); }); }
数据类型-->返回的数据类型可能是xml(几乎已经淘汰),json(现在常用)
下面来看个我最近刚写原生js通过get方法调用json的例子:
if(!isnan(matchid)) { var xmlhttp = null; try {// chrome, firefox, opera, safari xmlhttp = new xmlhttprequest(); }catch (e) { try {// internet explorer ie 6.0+ xmlhttp = new activexobject("msxml2.xmlhttp"); } catch (e) { try {// internet explorer ie 5.5+ xmlhttp = new activexobject("microsoft.xmlhttp"); } catch (e) { alert("your browser not support ajax!"); } } } window.onload = function () { xmlhttp.open("get",/api/clientmatch/commonmatchdiagram.json?matchid=" + matchid,true); xmlhttp.send(); xmlhttp.onreadystatechange = doresult; //设置回调函数 }; function doresult() { var html=''; if ((xmlhttp.readystate == 4)&&(xmlhttp.status == 200)) {//4代表执行完成,200代表执行成功 var data = json.parse(xmlhttp.responsetext); if(data.code == 200){ //代码执行 } document.getelementbyid('appmatch').innerhtml = html; } } }