// 因为大部分接口得到的数据都是json
// 所以我们在接受到数据的第一步操作一般为JSON.parse()
// 能不能把JSON.parse操作放在函数中
//封装一个函数直接将获取到的json字符串转换为json对象
function getJSON(url,callback,error){
//这里我们不仅要考虑成功时候执行的函数还要考虑失败时执行的函数
//所以我们要写入两个回调函数
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState === 4 && xhr.status === 200){
callback && callback(JSON.parse(xhr.responseText));
//把实参直接转化为JSON字符串
}else if(xhr.readyState === 4 && xhr.status === 404){
error && error(xhr.statusText);//对应失败时status的文字描述
}
}
xhr.open('GET',url,true);
xhr.send();
}
getJSON('url',function(data){
//声明getJSON函数时,回调函数中传入对应的结果,那么这个data就是对应传入的值
//所以为了获取到转换后的JSON对象,我们可以直接传入JSON.parse(xhr.responseText);
},function(errorText){
alert(errorText);
//errorText就是错误信息
})
在请求结果中,除了xhr.responseText还有一个xhr.responseXML 备注:这是后台给你传的是XML格式的时候你的接收方式
在这里再说一下JSON.parse 只能够转JSON字符串因为JSON的个是比较严格
{
"name" : "张三";
}
当我们初学者去请求php接口数据时经常会遇到Unexpected token < in JSON at position 0
这个错误是JSON.parse 转换失败的后台报错
如果遇到这个问题,直接找到请求到的数据即可,查看数据格式是否正确。