ajax的全称是asynchronous javascript and xml ,它是异步的js和xml。它是局部刷新,异步操作。本文给大家介绍了ajax的特性及乱码问题,感兴趣的朋友一起看看吧,希望能帮助到大家。
在讲解之前我先给大家说一下线性数据结构吧,我们可以把单线性数据结构当成一条线段,线段是有头有尾的大家总知道吧,单线程就是线段的头部没有前区,尾部没有后区,中间的每个元素前后都各有两个元素,少了一个元素的时候,同时会有两个元素知道并且告诉你。而且是缺一个元素都不行。
回调函数就是把函数a当做参数传递给函数b,函数b执行这个函数a。回调函数最常见的用法就是我们ajax请求数据时用到的succes() and error()这两个函数,还有setinterval里面的第一个参数,也是用了回调函数。回调函数,回调函数,回调的字面意思可不就是掉个头回去再把那条路走一遍嘛。所以ajax在回调函数success()或者error被触发的时候掉过头去又走了一次,然后他就是异步的了,同时ajax是异步的,跟他类似的还有es6的promise(异步的同步操作)。
浏览器的进程是多进程的,至于为什么就跟你为什么叫xxx是一个道理呦~
第二个问题,当万能的前端遇到ajax获取后台数据时乱码是怎么回事应该是大家很纠结的。
-或许是网速问题,网太慢。
-或许是编码格式不统一,你的后台兄弟坑了你,哈哈哈哈
ajax原生代码都可否记得,不如我带你们捋一遍呀,看代码:
//1.创建xmlhttprequest对象
var xhr;
try{
xhr = new xmlhttprequest();
console.log(5555)
}
catch(e){
//ie浏览器低版本兼容
xhr = new activexobject("microsoft.xmlhttp");
}
finally{
console.log(1111)
}
// try{} catch{} finally{}在这里是处理异常的方法,用if{}else{}也ok
//if(window.xmlhttprequest){
// xhr = new xmlhttprequest();
// }else{
//ie浏览器低版本的兼容
// xhr = new activexobject("microsoft.xmlhttp")
//}
//2.建立异步连接
xhr.open("get","url/+string",true/false);//true是异步,false是同步
//xhr.open("post","url",true/false)
//3.发送异步请求
xhr.send(null);//get
xhr.send(string);//post
//4.获取返回数据
xhr.onreadystatechange = function (){
if((xhr.readystate)==4&&(xhr.status==200)){
var data = xhr.responsetext;
var data = json.parse(data);
show(data);
}
}
function show(data){
document.getelementbyid("p1").innerhtml = data;
}
相关推荐:
实例讲解ajax异步请求技术
ajax的常用语法是什么
ajax原理与cors跨域的方法
以上就是详解ajax的特性及乱码问题的详细内容。