原生Ajax(获取&请求)数据 及 原理

ajax(Asynchronous Jacascript and XML)

ajax可以在不重新加载整个网页的情况下,对网页的某个部分数据进行更新
ajax不需要任何浏览器插件,只需要用户允许Javascript在浏览器上执行,因为ajax需要借助javascript来实现浏览器和服务器之间的异步交互

工作原理:

在用户端和服务器端之间添加一个中间层(ajax引擎),改变同步交互的过程,并不是所有的用户请求
都提交给服务器端,可以把部分的数据提交给ajax引擎来做,当需要从服务器端读取新的数据时,可以
由ajax引擎项服务器提交请求,从而使用户操作和服务器响应异步化

ajax的组成部分:

Javascript,DOM,CSS,XMLHttpRequest(ajax的核心)
XMLHttpRequest对象负责将客户端信息以异步通信的方式发送给服务器端,并接收服务器端返回的响应

信息和数据:

在ajax中,通过XMLHttpRequset对象向服务器发送异步请求,从服务器端获取数据,使用js操作DOM元素
来刷新页面和重组数据,依靠css来布局

优点:

减轻服务器负担,提高web性能,不需要插件支持,调用外部数据方便,达到页面和数据的分离

缺点:

不能很好的支持移动设备,不能很好的支持搜索引擎


Ajax请求数据

1.创建XMLHttpRequest()对象
2.创建回调函数
3.请求数据
4.设置请求的HTTP头部信息(这是请求头)
5.在回调函数里根据返回的不同状态进行操作

一:创建XMLHttpRequest()对象

var ajax;
if(window.XMLHttpRequest){
    ajax = new XMLHttpRequest(); // 兼容其他浏览器
}else{
    ajax = new ActiveXObject("Microsoft.XMLHTTP"); // 兼容老版IE
}

二:创建回调函数
设置ajax的事件处理函数,交互时的操作

ajax.onreadystatechange = function(){}

三:将请求发送到服务器
使用open方法

ajax.open("POST","data.php",true);

请求数据 类型 为 POST , 路径 data.php ,true异步请求

四:设置请求的HTTP头部信息

ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded"); // 设置表单的请求头

HTTP请求头类型有4种

 // 1.发送表单数据
ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset=utf-8");        
 // 2.发送纯文本(默认值)
ajax.setRequestHeader("Content-type","text/plain;charset=utf-8");       
 // 3.发送html文本
ajax.setRequestHeader("Content-type","text/html;charset=utf-8");        
 // 4.发送json格式的数据:
ajax.setRequestHeader("content-type","application/json;charset=utf-8");

五:在回调函数里根据返回的不同状态进行操作

    ajax.onreadystatechange = function(){ // 事件函数 监听
            
 //     判断readyState == 4(交互完成)status服务器返回的状态(200是ok)
        if(ajax.readyState == 4 && ajax.status == 200){
            
            console.log(ajax.responseText); // 接受到的文本内容     
            var arr = JSON.parse(ajax.responseText); // 返回的是字符串 需要解析            
        
        }else{
            console.log("异步交互失败");
        }
    }

Ajax获取数据

写法与post差不多,就是不用设置请求头

1.创建XMLHttpRequest()对象
2.创建回调函数
3.请求数据
4.将请求发送到服务器
5.在回调函数里根据返回的不同状态进行操作

var ajax;
 // 判断:兼容IE和其他浏览器
if(window.XMLHttpRequest){
    ajax = new XMLHttpRequest();//兼容其他浏览器
}else{
    ajax = new ActiveXObject("Microsoft.XMLHTTP");//兼容老版IE
}
                
 // 设置ajax的事件处理函数,交互时的操作,当readyState的属性值发生改变操作
 // 判断readyState == 4(交互完成)status服务器返回的状态(200是ok)
if(ajax.readyState == 4 && ajax.status == 200){
                        
    console.log(ajax.responseText);//接受到的文本内容
                        
    var arr = JSON.parse(ajax.responseText);//返回的是字符串 需要解析
                    
}else{
    console.log("异步交互失败");
}
                
 // 请求数据 类型 为 GET , 路径 Ajax.json ,异步请求
ajax.open("GET","Ajax.json",true);
                
 // 将请求发送到服务器,就是将请求发送出去,发送到ajax.open的路径
ajax.send();

XMLHttpRequest对象的常用属性和方法

属性:
readyState(0-4) :
0 -- 代表未初始化
1 -- 代表正在加载
2 -- 代表加载已完成
3 -- 代表正在交互
4 -- 代表交互完成

onreadystatechange -- 指定当发生任何状态变化时(readyState的属性值发生改变)的时间处理函数。
ajax.onreadystatechange = function(){} 这是一个事件处理函数

responseText -- 客户端接收到的HTTP响应文本内容
ajax.responseText

status -- 描述服务器返回的HTTP状态代码,比如:200对应ok,404对应 no found, 502, 301 等等

statusText -- 描述服务器返回的HTTP状态代码文本: 比如:ok,not found

方法:

abort() -- 停止当前请求

getAllResponseHeaders() -- 获取HTTP请求的所有响应的头部(获取所有的请求头)

getResponseHeaders() -- 获取指定HTTP请求的响应的头部(获取指定的请求头)

open(arg1,arg2,arg3):
arg1 -- 请求的类型,get或者post
arg2 -- 文件路径或者接口地址
arg3 -- true或者false, true代表异步,false代表同步

send() -- 将请求发送到服务器

setRequestHeader() -- 设置请求的HTTP头部信息(这是请求头)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,039评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,426评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,417评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,868评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,892评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,692评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,416评论 3 419
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,326评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,782评论 1 316
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,957评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,102评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,790评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,442评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,996评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,113评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,332评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,044评论 2 355