Jquery中的ajax
1:为什么要使用jq的ajax方法,与原生ajax和自己封装的方法相比有何优点?
因为如果没有 jQuery,AJAX编程还是有些难度的。编写常规的 AJAX 代码并不容易,因为不同的浏览器对 AJAX 的实现并不相同。这意味着您必须编写额外的代码对浏览器进行测试。不过,jQuery 团队为我们解决了这个难题,我们只需要一行简单的代码,就可以实现 AJAX 功能。jQuery 提供多个与 AJAX 有关的方法。
通过 jQuery AJAX 方法,能够使用 HTTP Get 和 HTTP Post 从远程服务器上请求文本、HTML、XML 或 JSON - 同时您能够把这些外部数据直接载入网页的被选元素中。
注:个人认为jqajax最大的优点是解决了兼容性问题,并且在封装的过程程序中有着完美严谨的处理,将ajax变得相当简单,您甚至不用理解ajax只要会使用jq的ajax方法便可以玩转ajax。与自己封装的方法相比,jq的ajax更严谨,对各种可能出现的情况进行了判断处理,有着良好的报错机制,更人性化。(上篇自己封装的方法并未对兼容性进行处理,所有现代浏览器均支持XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)因此对于ie5-ie6需要特别处理。虽然ie5-ie6目前基本上已无人使用但并不代表就可以不对其处理,这些兼容性问题jq都对其进行了很好的处理…)
2:jq中常用的ajax方法:
以下只是简单的整理,举例,若想查看相关方法详细,请前往w3c官网:http://www.w3school.com.cn/的jquery分类下查看。
2.1:load()方法:
Load()方法是jq简单但强大的ajax方法,load()方法从服务器加载数据并将返回的数据加载到所选的元素中。
Load()方法语法:
$(selector).load(URL,data,callback);
Load()方法参数说明:
参数1:url:指定请求的地址
参数2:data:要发送的数据
参数3:callback:回调函数:function(responseTxt,statusTxt,xhr){},responseTxt:包含调用成功返回的结果
StatusTxt:包含调用的状态
Xhr:包含 包含 XMLHttpRequest 对象
使用示例:
2.2:$.get()方法:
$.get()方法通过HTTP get请求从服务器上请求数据。
语法:
$.get(URL,callback);
参数:
url:请求的地址,注意:由于get方式数据在url后,所以使用此方法时传入的不单单是url,若有数据应该把数据通过?拼接在url后,多个参数通过&拼接。
callback:成功后执行的回调函数,回调函数参数:1:data:返回的数据,2:ststus:返回调用状态。
示例:
2.3:$.post()方法:
$.post() 方法通过 HTTP POST 请求从服务器上请求数据。
语法:
$.post(URL,data,callback);
参数:
1:url:请求地址
2:data:要发送的数据,注:传数据可通过:value1=key1&value2=key2...此方式,也可通过类似于对象的方式:
{
name:'拿破仑',
skill:'军事指挥'
}
示例:
2.4:$.ajax()方法:
$.ajax() 方法通过 HTTP 请求加载远程数据。
该方法是 jQuery 底层 AJAX 实现。简单易用的高层实现见 $.get, $.post 等。$.ajax() 返回其创建的 XMLHttpRequest 对象。大多数情况下你无需直接操作该函数,除非你需要操作不常用的选项,以获得更多的灵活性。
语法:
jquery.ajax([settings]);
可选。用于配置 Ajax 请求的键值对集合。可以通过 $.ajaxSetup() 设置任何选项的默认值。具体参数可查看w3c:
options
类型:Object
可选。AJAX 请求设置。所有选项都是可选的。
async
类型:Boolean
默认值: true。默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。
注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
beforeSend(XHR)
类型:Function
发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。
XMLHttpRequest对象是唯一的参数。
这是一个 Ajax 事件。如果返回 false 可以取消本次 ajax 请求。
cache
类型:Boolean
默认值: true,dataType 为 script 和 jsonp 时默认为 false。设置为 false 将不缓存此页面。
jQuery1.2 新功能。
complete(XHR,TS)
类型:Function
请求完成后回调函数 (请求成功或失败之后均调用)。
参数: XMLHttpRequest 对象和一个描述请求类型的字符串。
这是一个 Ajax 事件。
contentType
类型:String
默认值: "application/x-www-form-urlencoded"。发送信息至服务器时内容编码类型。
默认值适合大多数情况。如果你明确地传递了一个content-type 给$.ajax() 那么它必定会发送给服务器(即使没有数据要发送)。
context
类型:Object
这个对象用于设置 Ajax 相关回调函数的上下文。也就是说,让回调函数内 this 指向这个对象(如果不设定这个参数,那么 this 就指向调用本次 AJAX 请求时传递的 options 参数)。比如指定一个 DOM 元素作为 context 参数,这样就设置了 success 回调函数的上下文为这个 DOM 元素。
就像这样:
$.ajax({ url: "test.html", context: document.body, success: function(){
$(this).addClass("done");
}});
data
类型:String
发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1","bar2"]} 转换为'&foo=bar1&foo=bar2'。
dataFilter
类型:Function
给 Ajax 返回的原始数据的进行预处理的函数。提供 data 和 type 两个参数:data 是 Ajax 返回的原始数据,type 是调用 jQuery.ajax 时提供的 dataType 参数。函数返回的值将由 jQuery 进一步处理。
dataType
类型:String
预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:
· "xml": 返回 XML 文档,可用 jQuery 处理。
· "html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。
· "script": 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)
· "json": 返回 JSON 数据。
· "jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?"jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
· "text": 返回纯文本字符串
· error
类型:Function
默认值: 自动判断 (xml 或 html)。请求失败时调用此函数。
有以下三个参数:XMLHttpRequest 对象、错误信息、(可选)捕获的异常对象。
如果发生了错误,错误信息(第二个参数)除了得到 null 之外,还可能是 "timeout","error", "notmodified" 和 "parsererror"。
这是一个 Ajax 事件。
global
类型:Boolean
是否触发全局 AJAX 事件。默认值: true。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 可用于控制不同的 Ajax 事件。
ifModified
类型:Boolean
仅在服务器数据改变时获取新数据。默认值: false。使用 HTTP 包 Last-Modified 头信息判断。在 jQuery 1.4 中,它也会检查服务器指定的 'etag' 来确定数据没有被修改过。
jsonp
类型:String
在一个 jsonp 请求中重写回调函数的名字。这个值用来替代在"callback=?" 这种 GET 或 POST 请求中 URL 参数里的 "callback" 部分,比如 {jsonp:'onJsonPLoad'} 会导致将 "onJsonPLoad=?" 传给服务器。
jsonpCallback
类型:String
为 jsonp 请求指定一个回调函数名。这个值将用来取代 jQuery自动生成的随机函数名。这主要用来让 jQuery 生成度独特的函数名,这样管理请求更容易,也能方便地提供回调函数和错误处理。你也可以在想让浏览器缓存 GET 请求的时候,指定这个回调函数名。
password
类型:String
用于响应 HTTP 访问认证请求的密码
processData
类型:Boolean
默认值: true。默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。scriptCharset
类型:String
只有当请求时 dataType 为 "jsonp" 或 "script",并且 type 是 "GET" 才会用于强制修改 charset。通常只在本地和远程的内容编码不同时使用。
success
类型:Function
请求成功后的回调函数。
参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。
这是一个 Ajax 事件。
traditional
类型:Boolean
如果你想要用传统的方式来序列化数据,那么就设置为 true。请参考工具分类下面的 jQuery.param 方法。timeout
类型:Number
设置请求超时时间(毫秒)。此设置将覆盖全局设置。
type
类型:String
默认值: "GET")。请求方式 ("POST" 或 "GET"),默认为"GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。
url
类型:String
默认值: 当前页地址。发送请求的地址。
username
类型:String
用于响应 HTTP 访问认证请求的用户名。
xhr
类型:Function
需要返回一个 XMLHttpRequest 对象。默认在 IE 下是 ActiveXObject 而其他情况下是 XMLHttpRequest 。用于重写或者提供一个增强的 XMLHttpRequest 对象。这个参数在 jQuery 1.3 以前不可用。
回调函数
如果要处理 $.ajax() 得到的数据,则需要使用回调函数:beforeSend、error、dataFilter、success、complete。
beforeSend
在发送请求之前调用,并且传入一个 XMLHttpRequest 作为参数。
error
在请求出错时调用。传入 XMLHttpRequest 对象,描述错误类型的字符串以及一个异常对象(如果有的话)
dataFilter
在请求成功之后调用。传入返回的数据以及"dataType" 参数的值。并且必须返回新的数据(可能是处理过的)传递给 success 回调函数。
success
当请求之后调用。传入返回后的数据,以及包含成功代码的字符串。
complete
当请求完成之后调用这个函数,无论成功或失败。传入XMLHttpRequest 对象,以及一个包含成功或错误代码的字符串。
示例:
注:
1:在使用jq提供的$get()方法时,一定要切记,get方法传送的数据是拼接在url后面的,url与data之间以?连接!
2:$.ajax()方法自由度极高(本人较喜欢,使用方便自由),所有参数都可自己设置,但使用的难度也相对较高,因为参数是比较多的,需要记忆参数名称。
关于ajax跨域问题
1:同源策略:
要理解跨域,先要了解一下“同源策略”。同源策略/SOP(Same origin policy)是一种约定,由Netscape公司1995年引入浏览器,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS、CSFR等攻击。所谓同源是指,域名、协议、端口相同。所谓“同源策略“,简单的说就是基于安全考虑,当前域不能访问其他域的东西。
1-1:什么是同源、不同源、跨域?
同源:协议、域名、端口3者均相同 的情况下称之为同源。
不同源:协议、域名、端口3者有一 个不相同即为不同源。
跨域:简单的说访问获取非同源的网域数据,即为跨域。
1-2:参照表:
1-3:为什么会跨域?跨域未处理的情况下会导致怎样的结果?
在同源策略下,在某个服务器下的页面是无法获取到该服务器以外的数据的。此时如果我们要获取其他服务器或域的数据,就是跨域。若“未处理”则会发生错误,无法正常拿到想要的数据。报错信息如下:
2:跨域解决方案:
2-1:从报错信息可知,是由于后端access-control-allow-headers未允许。只需后端在服务器进行配置允许即可。
2-2:但<img>
的src(获取图片),<link>
的href(获取css),<script>
的src(获取javascript)这三个都不符合同源策略,它们可以跨域获取数据。这里要介绍的JSONP就是利用<script>
的src来实现跨域获取数据的。
3:JSONP:
3-1:什么是jsonp:
jSONP 是 JSON withpadding(填充式 JSON 或参数式 JSON)的简写。JSONP 由两部分组成:回调函数和数据。回调函数是当响应到来时应该在页面中调用的函数。回调函数的名字一般是在请求中指定的。而数据就是传入回调函数中的 JSON 数据。(jsonp原理在此不做深入研究,初期先“一把梭”会用框架封装好的方法实现跨域即可。)
4:jQuery中封装的JSONP
对于经常用jQuery的开发者来说,能注意到jQuery封装的$.ajax
中有一个dataType
属性,将该属性设置成dataType:"jsonp"
,就能实现JSONP跨域了。需要了解的一点是,虽然jQuery将JSONP封装在$.ajax
中,但是其本质与$.ajax
不一样。(为什么不一样在于jsonp原理)。
实例:
此处实例api:https://api.asilu.com/phone/
此api为一个免费手机归属地查询api,只有一个参数phone(手机号码),为jsonp接口。
1:通过jq的$.ajax()方法实现跨域:
返回结果:
若无指定dataType: "jsonp", 将会报如下跨域错误:
除了$.ajax()的方法可实现跨域外,以下两方法亦可实现跨域:
2: 通过 $.getJSON() 方法来实现,只要在地址中加入 callback=? 参数即可。参考代码如下:常用的数据传输格式(xml/json)
目前数据传输格式主要是xml和json。
1:xml:
扩展标记语言 (Extensible MarkupLanguage,XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML是标准通用标记语言 (SGML) 的子集,非常适合 Web 传输。XML 提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。
使用Xml作为数据传输格式的优势:
1. 格式统一, 符合标准
2.容易与其他系统进行远程交互, 数据共享比较方便
Xml的缺点:
1:xml文件格式庞大复杂,传输占用带宽大
2:服务器端和客户端都需要花费大量代码来解析xml,不论服务器端和客服端代码变得异常复杂,不利于维护
3:当数据特别大和复杂时,解析xml将会特别困难,并且易出错
故而xml虽然是标准的数据传输格式,但因为其缺点目前使用越来越少,除了xml还有一种叫json轻量级格式数据交换模式来替代xml。
之前一直未解析过xml,此处补上一个ajax获取xml数据并解析的实例:
api:http://wthrcdn.etouch.cn/WeatherApi?city=北京
通过城市名字获得天气数据,xml
格式数据
返回数据格式如下:
Ajax实例代码如下:
此时获取到了接口返回的数据,但并未解析(此时拿到的只是字符串!),解析步骤如下:
① 将返回字符串转为document对象,原生ajax通过xhr.reaponsexml即可,jq只需添加dataType=’xml’即可。
② 已经转成dom对象,像js操作dom对象那样操作即可。
2:JSON:(简单整理,详见w3c等)
2-1:什么是json:
Json指的是javascript对象表示法(javascriptobject notation)
Json是存储和交换文本信息的语法,类似于xml。
Json是轻量级的文本交换格式,Json比xml更小,更快,更容易解析。
Json具有自我描述性,更容易理解。
Json具有层级结构,值中存在值。
Json使用javascript语法来描述数据对象,但是json任然独立于语言和平台。Json解析器和json库支持许多不同的编程语言。
Json文件的文件类型是:“.json”,Json文本的MIME类型是“application/json”
2-2:json的语法规则:
Json语法是javascript对象表示法的子集。
•数据在名称/值对中
•数据由逗号分隔
•花括号保存对象
•方括号保存数组
Json的值可以是:
•数字(整数或浮点数)
•字符串(在双引号中)
•布尔值(true/false)
•数组(方括号中)
•对象(花括号中)
•null
2-3:json优缺点:
优点:
1.数据格式比较简单, 易于读写, 格式都是压缩的, 占用带宽小
2.易于解析这种语言, 客户端JavaScript可以简单的通过eval_r()进行JSON数据的读取
3.支持多种语言, 包括ActionScript, C, C#, ColdFusion, Java,JavaScript, Perl, PHP, Python,Ruby等语言服务器端语言, 便于服务器端的解析
4.在PHP世界,已经有PHP-JSON和JSON-PHP出现了, 便于PHP序列化后的程序直接调用.PHP服务器端的对象、数组等能够直接生JSON格式, 便于客户端的访问提取.
5.因为JSON格式能够直接为服务器端代码使用, 大大简化了服务器端和客户端的代码开发量, 但是完成的任务不变, 且易于维护
缺点:
1.没有XML格式这么推广的深入人心和使用广泛, 没有XML那么通用性
2.JSON格式目前在Web Service中推广还属于初级阶段
3:json与xml比较:(以下内容来自于https://blog.csdn.net/tangtiantian520/article/details/50945582)感谢前辈!为方便阅读将部分内容转载于此,详细可点击链接跳转查看。
1. 在可读性方面,JSON和XML的数据可读性基本相同。JSON和XML的可读性可谓不相上下,一边是建议的语法,一边是规范的标签形式,很难分出胜负。
2.在可扩展性方面,XML天生有很好的扩展性,JSON当然也有,没有什么是XML能扩展,JSON不能的。
3.在编码难度方面,XML有丰富的编码工具,比如Dom4j、JDom等,JSON也有json.org提供的工具,但是JSON的编码明显比XML容易许多,即使不借助工具也能写出JSON的代码,可是要写好XML就不太容易了。
4.在解码难度方面,XML的解析得考虑子节点父节点,让人头昏眼花,而JSON的解析难度几乎为0。这一点XML输的真是没话说。
5.在流行度方面,XML已经被业界广泛的使用,而JSON才刚刚开始,但是在Ajax这个特定的领域,未来的发展一定是XML让位于JSON。到时Ajax应该变成Ajaj(AsynchronousJavascript and JSON)了。
6.JSON和XML同样拥有丰富的解析手段。
7. JSON相对于XML来讲,数据的体积小。
8. JSON与JavaScript的交互更加方便。
9. JSON对数据的描述性比XML较差。
10. JSON的速度要远远快于XML。
1.数据交换格式比较之关于XML和JSON:
XML:extensiblemarkup language,一种类似于HTML的语言,他没有预先定义的标签,使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。具体的可以问Google或百度。相比之JSON这种轻量级的数据交换格式,XML可以称为重量级的了。
JSON :JavaScript Object Notation 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScript Programming Language , Standard ECMA-262 3rd Edition-December 1999 的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++,C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。
2.数据交换格式比较之关于轻量级和重量级:
轻量级和重量级是相对来说的,那么XML相对于JSON的重量级体现在哪呢?我想应该体现在解析上,XML目前设计了两种解析方式:DOM和SAX;
DOM是把一个数据交换格式XML看成一个DOM对象,需要把XML文件整个读入内存,这一点上JSON和XML的原理是一样的,但是XML要考虑父节点和子节点,这一点上JSON的解析难度要小很多,因为JSON构建于两种结构:key/value,键值对的集合;值的有序集合,可理解为数组;
SAX不需要整个读入文档就可以对解析出的内容进行处理,是一种逐步解析的方法。程序也可以随时终止解析。这样,一个大的文档就可以逐步的、一点一点的展现出来,所以SAX适合于大规模的解析。这一点,JSON目前是做不到得。
所以,JSON和XML的轻/重量级的区别在于:JSON只提供整体解析方案,而这种方法只在解析较少的数据时才能起到良好的效果;而XML提 供了对大规模数据的逐步解析方案,这种方案很适合于对大量数据的处理。
3.数据交换格式比较之关于数据格式编码及解析的难度:
在编码上,虽然XML和JSON都有各自的编码工具,但是JSON的编码要比XML简单,即使不借助工具,也可以写出JSON代码,但要写出好的XML代码就有点困难;与XML一样,JSON也是基于文本的,且它们都使用Unicode编码,且其与数据交换格式XML一样具有可读性。
主观上来看,JSON更为清晰且冗余更少些。JSON网站提供了对JSON语法的严格描述,只是描述较简短。从总体来看,XML比较适合于标记 文档,而JSON却更适于进行数据交换处理。
在解析上,在普通的web应用领域,开发者经常为XML的解析伤脑筋,无论是服务器端生成或处理XML,还是客户端用 JavaScript解析XML,都常常导致复杂的代码,极低的开发效率。
实际上,对于大多数web应用来说,他们根本不需要复杂的XML来传输数据,XML宣称的扩展性在此就很少具有优势;许多Ajax应用甚至直接返回HTML片段来构建动态web页面。和返回XML并解析它相比,返回HTML片段大大降低了系统的复杂性,但同时缺少了一定的灵活性。同XML或 HTML片段相比,数据交换格式JSON 提供了更好的简单性和灵活性。在web serivice应用中,至少就目前来说XML仍有不可动摇的地位。
后记
关于ajax部分的内容就到此结束了,整理了很久,发布在csdn上备忘,以供需要时随时查看,同时也希望可以帮助到刚入坑前端,对ajax学习和使用很迷茫的朋友。本人目前尚是大二学生,所学不过皮毛,文中若有错误还请大神指教,感谢。ajax作为前后端数据家交互的桥梁,对于刚刚接触ajax的初学者可能会觉得ajax很难,上一篇分析过为何难。其实只要掌握合理的学习方法,当你学完后你会发现ajax并不难。不推荐直接去w3c等网站直接查看ajax文档,因为那些文档对于初学者来说是有难度的,会让初学者感到很困惑,云里雾里。建议去慕课网等教育网站寻找相应的教学视频,跟随讲师步伐走。其次学习ajax只看只记是远远不够的,需要大量的练习!在练习中理解提高。下面给初学者推荐几个练习api:
天气查询:网上很多,推荐:百度/高德。本人使用高德(更简单方便些)百度搜索高德地图api注册即可使用,有完整详细api说明文档。本人所做如下:
图灵聊天机器人:百度搜索图灵机器人注册即可,有完整详细api说明文档。本人所做如下:
自己做的王者荣耀英雄查询系统:(无api,可自己去王者官网pvp.qq.com通过开发者工具自己分析拿到数据,学会使用开发者工具是非常必要的),所做如下:
其他api:
手机号码归属地API接口:https://www.juhe.cn/docs/api/id/11
历史上的今天API接口:https://www.juhe.cn/docs/api/id/63
股票数据API接口:https://www.juhe.cn/docs/api/id/21
全国WIFI接口:https://www.juhe.cn/docs/api/id/18
星座运势接口:https://www.juhe.cn/docs/api/id/58
黄金数据接口:https://www.juhe.cn/docs/api/id/29
语音识别接口:https://www.juhe.cn/docs/api/id/134
周公解梦接口:https://www.juhe.cn/docs/api/id/64
天气预报API接口:https://www.juhe.cn/docs/api/id/73
身份证查询API接口:https://www.juhe.cn/docs/api/id/38
笑话大全API接口:https://www.juhe.cn/docs/api/id/95
邮编查询接口:https://www.juhe.cn/docs/api/id/66
老黄历接口:https://www.juhe.cn/docs/api/id/65
网站安全检测接口:https://www.juhe.cn/docs/api/id/19
手机固话来电显示接口:https://www.juhe.cn/docs/api/id/72
。。。。若有需要可自行百度,会后端也可自己写需要的api!
序章:初识ajax之同步与异步:点击打开链接
初章:初识ajax之原生ajax及ajax封装:点击打开链接
免费api分享:点击打开链接
json/xml比较:点击打开链接