使用原生JS和jQuery搞定Ajax

一、原生JS

说到Ajax,不得不先提一下HTTP(HTTP,HyperText Transfer Protocol)协议,中文名:超文本传输协议,是互联网上应用最为广泛的一种网络协议。所有的WWW文件都必须遵守这个标准。设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法。一次HTTP请求,包含了两个重要的部分:上行request(请求)和下行response(响应)

HTTP协议定义了很多与服务器交互的方法,最基本的有4种,分别是GET,POST,PUT,DELETE. 一个URL地址用于描述一个网络上的资源,而HTTP中的GET, POST, PUT,DELETE就对应着对这个资源的查,改,增,删4个操作。 我们最常见的也是我们关心的就是GET和POST了。GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。
我们看看GET和POST的区别:

  1. GET提交的数据会放在URL之后,以?分割URL和传输数据,参数之间以&相连,如EditPosts.aspx?name=test1&id=123456. POST方法是把提交的数据放在HTTP包的Body中.
  2. GET提交的数据大小有限制(因为浏览器对URL的长度有限制,本身并没有限制),而POST方法提交的数据没有限制。
  3. GET方式提交数据,会带来安全问题,比如一个登录页面,通过GET方式提交数据时,用户名和密码将出现在URL上,如果页面可以被缓存或者其他人可以访问这台机器,就可以从历史记录获得该用户的账号和密码。
    如果你使用chrome浏览器的话,可以再下面的页面中看到这两种请求携带的信息:



通常,浏览器产生HTTP请求,是由于用户输入了新的网址、或者点击了超级链接,使页面跳转,这将导致页面的全局刷新。而Ajax(Asynchronous Javascript And XML:异步JavaScript和XML)技术,可以使网页悄悄地、偷偷地发起HTTP请求,请求回来的数据在页面局部刷新呈递。ajax的使用其实很简单:
第一步,new出一个XMLHttpRequest对象:


这里变量名xhr可以随便起,只是一般工程师都喜欢使用这个名字,就像var arr一样,姑且当做一种约定俗成的东西就好,方便大家交流。第二步,处理服务器上面返回的响应:

其中,if语句小括号中的的语句:readyState表示返回XMLHTTP请求的当前状态,具体数值示意如下:
0、未初始化
对象已建立,但是尚未初始化(尚未调用open方法)
1、初始化
已调用send()方法,正在发送请求
2 、发送数据
send方法调用完成,但是当前的状态及http头未知
3 、数据传送中
已接收部分数据,因为响应及http头不全,这时通过responseBody和responseText获取部分数据会出现错误,
4、完成
数据接收完毕,此时可以通过通过responseBody和responseText获取完整的回应数据

第三步,创建一个请求,第一个参数是请求的类型get或者post,第二个参数就是请求的路径,第三个参数叫做是否使用异步机制:



如果是post请求,在发送请求前需要做以下处理:



第四步,发送请求:

总结一下:

1   //Ajax的一个固定的模板:
2   //第1步创建一个xhr对象,使用new关键来调用一个内置构造函数
3   var xhr = new XMLHttpRequest();
4   //第2步指定接收回来的内容,怎么处理。监听xhr对象的onreadystatechange事件,这个事件在xhr对象的“就绪状态”改变的时候触发。我们只关心就绪状态为4的时候的事情。
5   xhr.onreadystatechange = function(){
6       if(xhr.readyState == 4){
7           //接收完文件要做的事情,让h1的内容变为读取的东西
8           biaoti.innerHTML = xhr.responseText;
9       }
10  }
11  
12  //第3步创建一个请求,第一个参数是请求的类型get或者post,第二个参数就是请求的路径,第三个参数叫做是否使用异步机制
13  xhr.open("get","a.txt",true);
14  //第4步发送请求,圆括号里面是请求头内容,get请求没有报文头写null
15  xhr.send(null);

如果是post,对应如下修改:

1. xhr.open("post","do2.php",true);
2. //如果用post发送请求,那么必须写一句话,模拟成form表单提交:
3. xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
4. xhr.send("xingming="+encodeURIComponent("枫")+"&age=18");

二、jQuery

1.1 $.get()方法

1   $.get("a.json"  ,   {"id":1,"name":"考拉"}  ,  function(text){
2           alert(typeof text);
3   });

jQuery默默的帮我们:
1) encodingURIComponent中文了;
2) 如果请求是404等错误状态,不会执行回调函数;
3) jQuery识别传回来的东西像JSON,已经帮我们转JSON了,

jQuery中get方法还可以这样使用两个参数:

1   $.get("a.json?id=1&name=枫", function(text){
2           alert(typeof text);
3   });
1.2 $.post()方法
1   $.post("a.json",{"id":1,"name":"枫"},function(data){
2       alert(typeof data);
3       alert(data.content[2].id);
4   });

1.3 $.ajax()方法
配置信息非常多,写在json里面进行配置:

1   $.ajax("b.json",{
2       //请求类型
3       "type"  :   "get",
4       //传到服务器上的数据
5       "data"  :   {
6           "name":"xiaoming",
7           "age" :10
8       },
9       //成功做的事情
10      "success" : function(data){
11          alert(typeof data);
12      },
13      //错误做的事情
14      "error": function(XMLHttpRequest, textStatus, errorThrown){
15          alert(errorThrown);
16      }
17  });
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容

  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 3,173评论 0 7
  • 原文链接 http://blog.poetries.top/2016/10/20/review-jQuery 关注...
    程序员poetry阅读 16,635评论 18 503
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,600评论 18 139
  • 第一章 入门 基本功能:访问和操作 dom 元素,控制页面样式,对页面的事件处理,与ajax完美结合,有丰富的插件...
    X_Arts阅读 1,027评论 0 2
  • 前言: 初识 kotlin ,看到他的语法与swift 语言有相同,也有不同,对我来说,我喜欢对比的学习;在swi...
    扬起帆前行阅读 902评论 0 0