ajax(ajax同步和异步的区别)

ajax全称“AsynchronousJavascriptAndXML”,并不是一种新技术,是由javascript、xml、XMLHttpRequest组合在一起、能实现异步提交的功能,是一种创建交互式网页应用的网页开发技术。
图片[1]-ajax(ajax同步和异步的区别)-小白之家,ajax同步和异步的区别,第一节Ajax与http

术语ajax最早产生于2005年,Ajax表明AsynchronousJavaScriptandXML(异步JavaScript和XML),可是它不是像HTML、JavaScript或CSS这样的一种“正式的”技能,它是表明一些技能的混合交互的一个术语(JavaScript、Web浏览器和Web服务器),它使我们能够获取和显现新的内容而不用载入一个新的Web页面。增强用户体验,更有桌面程序的感觉。

1.1什么是Ajax?

Ajax是一种技能方案,但并不是一种新技能。它依靠现有的CSS/HTML/JavaScript,而其中最中心的依靠是浏览器供给的XMLHttpRequest目标,是这个目标使得浏览器能够发出HTTP恳求与接纳HTTP呼应。实现了在页面不改写个情况下和服务器进行数据交互。

异步的javascript和xmlAJAX是一种用于创立快速动态网页的技能。ajax用来与后台交互

1.2Ajax能够做什么?

显现新的HTML内容而不用载入整个页面提交一个表单而且立即显现结果登录而不用跳转到新的页面星级鉴定组件遍历数据库信息加载更多而不改写页面1.3客户端与服务器

本章作业

Ajax是什么有什么用

第二节Ajax恳求过程

2.1Ajax恳求分4步完结

创立XMLHttpRequest目标预备发送恳求open()发送恳求数据send()恳求回来的回调函数onreadystatechange=function(){}XMLHttpRequest目标用来在【浏览器】与【服务器】之间传送数据。浅显上来说将此目标称为request恳求目标、恳求目标或恳求。

2.1.1创立ajax过程

1.创立XMLHttpRequest目标–进行ajax恳求

目标用来在【浏览器】与【服务器】之间传送数据浏览器供给给我们的目标

varxhr=newXMLHttpRequest();

2.预备发送数据open()办法

语法:xhr.open(‘恳求类型’,’url地址’,是否异步);

xhr.open(‘get’,’02-post.php’,true);

3.发送send()实际发送的数据get恳求为空null

xhr.send(null);

4.回调函数onreadystatechange特点指向一个回调函数。

当页面的加载状况发生改变的时候readyState特点就会跟从发生变化,而这时readystatechange特点所对应的回调函数就会主动被调用。

xhr.onreadystatechange=function(){if(xhr.readyState==4){//表明服务器数据已经彻底接纳if(xhr.status==200){//,OK,访问正常console.log(xhr.responseText)}}}

onreadystatechange事情

当恳求被发送到服务器时,我们需要履行一些基于呼应的使命。

每当readyState改变时,就会触发onreadystatechange事情。

readyState特点存有XMLHttpRequest的状况信息。

2.1.2readyState状况码

2.1.3get有参

document.querySelector(‘.btn’).onclick=function(){varusername=document.querySelector(‘.name’).value;varpassword=document.querySelector(‘.psd’).value;varxhr=newXMLHttpRequest();xhr.open(‘get’,’06ajax_get.php?userName=’+username+’&passWord=’+password,true);xhr.send();xhr.onreadystatechange=function(){if(xhr.readyState==4){if(xhr.status==200){console.log(xhr.responseText);}}}}

2.1.4post有参

document.querySelector(‘.btn’).onclick=function(){varusername=document.querySelector(‘.name’).value;varpassword=document.querySelector(‘.psd’).value;varxhr=newXMLHttpRequest();//newDate()xhr.open(‘post’,’06ajax_get.php’,true);vardata=’userName=’+username+’&passWord=’+password;xhr.setRequestHeader(“Content-type”,”application/x-www-form-urlencoded;charset=utf-8″);xhr.send(data);xhr.onreadystatechange=function(){if(xhr.readyState==4){if(xhr.status==200){console.log(xhr.responseText);}}}}

2.1.5获取json数据

document.querySelector(‘.btn’).onclick=function(){varxhr=newXMLHttpRequest();//newDate()xhr.open(‘get’,’data/data.json’,true);xhr.send();xhr.onreadystatechange=function(){if(xhr.readyState==4){if(xhr.status==200){vardataJson=JSON.parse(xhr.responseText);console.log(dataJson);varbooks=dataJson.data;for(vari=0;ivarlis=document.createElement(‘li’);lis.innerHTML=books[i].name;document.getElementById(‘ul’).appendChild(lis);}}}}}

【json数据】

2.1.6XMLHttpRequest兼容

一切现代浏览器(IE7+、Firefox、Chrome、Safari以及Opera)均内建XMLHttpRequest目标。

创立XMLHttpRequest目标的语法:

variable=newXMLHttpRequest();

老版本的InternetExplorer(IE5和IE6)运用ActiveX目标:

variable=newActiveXObject(“Microsoft.XMLHTTP”);

【代码演示】

varxmlhttp;if(window.XMLHttpRequest){//IE7+,Firefox,Chrome,Opera,Safari浏览器履行代码xmlhttp=newXMLHttpRequest();}else{//IE6,IE5浏览器履行代码xmlhttp=newActiveXObject(“Microsoft.XMLHTTP”);}

2.1.7timout

本章作业

1.默写ajax恳求过程

2.get传递参数post传递参数

3.json数据解析

第三节jquery的ajax

3.1Ajax过程

$(‘#btn’).click(function(){varname=$(“.name”).val();$.ajax({type:’post’,//恳求办法url:’09jquery_ajax.php’,data:{uname:name,},success:function(res){console.log(res);$(“.info”).html(res);},error:function(){console.log(“恳求失利”);},beforeSend:function(){//恳求数据之前履行的内容console.log(“数据恳求中…..”);$(“.info”).html(‘数据恳求中…..’);},})})

3.2回调函数

假如要处理$.ajax()得到的数据,则需要运用回调函数。beforeSend、error、dataFilter、success、complete。

beforeSend在发送恳求之前调用,而且传入一个XMLHttpRequest作为参数。

error在恳求出错时调用。传入XMLHttpRequest目标,描绘错误类型的字符串以及一个异常目标

dataFilter在恳求成功之后调用。传入回来的数据以及”dataType”参数的值。而且必须回来新的数据(可能是处理过的)传递给success回调函数。

success当恳求之后调用。传入回来后的数据,以及包括成功代码的字符串。

complete当恳求完结之后调用这个函数,无论成功或失利。传入XMLHttpRequest目标,以及一个包括成功或错误代码的字符串。

3.2.1防止重复数据

在实际项目开发中,提交表单时常常因为网络或者其原因,用户点击提交按钮误认为自己没有操作成功,进而会重复提交按钮操作次数,假如页面前端代码没有做一些相应的处理,通常会导致多条同样的数据刺进数据库,导致脏数据的添加。要避免这种现象,在$.ajax恳求中的beforeSend办法中把提交按钮禁用掉,等到Ajax恳求履行完毕,在康复按钮的可用状况。举个比如://提交表单数据到后台处理$.ajax({type:”post”,data:studentInfo,contentType:”application/json”,url:”/Home/Submit”,beforeSend:function(){//禁用按钮防止重复提交$(“#submit”).attr({disabled:”disabled”});},success:function(data){if(data==”Success”){//清空输入框clearBox();}},complete:function(){$(“#submit”).removeAttr(“disabled”);},error:function(data){console.info(“error:”+data.responseText);}});

3.2.2模仿Toast效果

ajax恳求服务器加载数据列表时提示loading(“加载中,请稍后…”),$.ajax({type:”post”,contentType:”application/json”,url:”/Home/GetList”,beforeSend:function(){$(“loading”).show();},success:function(data){if(data==”Success”){//…}},complete:function(){$(“loading”).hide();},error:function(data){console.info(“error:”+data.responseText);}});

本章作业

1.jquery的ajax过程

2.beforeSend()complete()函数运用

第四节jquery的ajax办法

4.1jquery封装的ajax办法

$.get(url,[data],[callback],[type])

url:待载入页面的URL地址

data:待发送Key/value参数。

callback:载入成功时回调函数。

type:回来内容格局,xml,html,script,json,text,_default。

$.get(“test.php”,{},function(data){alert(“DataLoaded:”+data);},’json’);

$.getJSON(url,[data],[callback])

url:发送恳求地址。

data:待发送Key/value参数。

callback:载入成功时回调函数。

$.getJSON(“test.js”,{name:”John”,time:”2pm”},function(json){alert(“JSONData:”+json.users[3].name);});

$.post(url,[data],[callback],[type])

url:发送恳求地址。

data:待发送Key/value参数。

callback:发送成功时回调函数。

type:回来内容格局,xml,html,script,json,text,_default。

$.post(“test.php”,{name:”John”,time:”2pm”},function(data){process(data);},”xml”);

4.2从浏览器输入url地址,到页面最终烘托完结,中心发生了什么

1.DNS解析将域名地址解析为ip地址

2.TCP衔接-TCP三次握手

第一次握手:由客户端建议,告知服务端我将要发送恳求了

第2次握手:由服务端建议,告知客户端我知道了,你放马过来

第三次握手:由客户端建议,告知服务端我知道了,你真的要发了,你赶紧预备承受

3.发送恳求恳求报文

4.承受呼应

5.呼应恳求处理数据

6.发送数据呼应数据

7.烘托页面

8.断开衔接-TCP四次挥手

第一次挥手:由服务端建议,告知客户端东西(恳求报文)承受完了

第2次挥手:由客户端建议,告知服务端,那好,我封闭了发送东西的接口

第三次挥手:由客户端建议,告知服务端东西(呼应报文)承受完了

第四次挥手:由服务端建议,告知客户端我预备封闭了,你也预备封闭吧

本章作业

1.点击按钮显现数据

2.查询物流信息获取数据烘托到页面上

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论