AJAX:Asynchronous JS And XML,包括HTML、CSS、JS、DOM、XML、JSON等,客户端技术范畴。主要目标:发起异步请求/响应,实现页面内容的局部刷新,提高浏览体验;实现动态页面的静态化。

使用AJAX的步骤:

(1)创建XHR对象——XMLDOM对象

(2)绑定onreadystatechange事件监听函数

(3)创建请求消息

(4)发送请求消息

AJAX的原理图:

使用AJAX发起GET请求:

(1)

(2)

(3) xhr.open('GET', 'xx.php?k=v&k=v', true)

(4) xhr.send( null )

使用AJAX发起POST请求:

(1)

(2)

(3) xhr.open('POST', 'xx.php', true)

(3.5) xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')

(4) xhr.send( 'k=v&k=v&k=v' )

常见的MIME(Multipurpose Internet Mail Extension):

.jpeg .jpg <= image/jpeg

.html .htm <= text/html

.mpeg3 .mp3 <= audio/mpeg3

MIME类型,就是用于唯一的标示一种特定格式的文件的一个描述符

常见的MIME类型:

image/jpeg image/gif image/png

text/plain text/html text/css

application/javascript application/xml application/json

application/msword ....

1.使用AJAX接收服务器返回的text响应

示例:点击酒馆,获得英雄列表

服务器端:

header('Content-Type: text/plain');

客户端:

(1)(2) console.log(xhr.responseText);

(3)(4)

2.使用AJAX接收服务器返回的html响应——重点

示例:动态数据的级联下拉列表

服务器端:

header('Content-Type', 'text/html');

客户端:

(1)(2) document.getElementXxxx().innerHTML = xhr.responseText;

(3)(4)

3.使用AJAX接收服务器返回的script响应

示例:加载不同的JS,实现页面主题的定制

服务器端:

header('Content-Type', 'application/javascript')

客户端:

(1)

(2) typeof( xhr.responseText ); //string

eval( xhr.responseText ); //把string作为js来执行

(3)

(4)

服务器如何异步的向客户端返回批量有结构的数据?如多个商品、多条帖子....

text/plain(无格式):'tom9070mary105john120'

text/plain(有格式):'tom#90#70@mary#10#5@john#1#20'

text/html(有格式):

'<div><p>tom<p><p>90</p><p>70</p></div><div><p>mary<p><p>90</p><p>70</p></div>'

批量响应数据最好的形式:有数据、有格式、跟HTML标签无关系、编程语言易于处理

application/xml:

application/json:

4.使用AJAX接收服务器返回的xml响应

HTML:HyperText Markup Language,所有的HTML标签已经为了在浏览器中加以而固定下来。用标签来呈现网页内容。

XML:eXtensible Markup Language,可扩展的标签语言,用标签的形式来描述数据(财务、航天、化学、无线...),没有预定义任何的标签,所有的标签都由使用者随意指定。XML语言标准规定了XML数据的格式必须满足:

(1)双标签有开始,就必须有结束;单标记标签必须有/

(2)标签名严格区分大小写

(3)属性值必须使用引号括起来

(4)...

W3C DOM分为三部分:

(1)核心DOM:用于处理任意的ML文档

document childNodes firstChild lastChild parentNode

nextSibling previousSibling

document.getElementXxxx

node.getAttribute() node.setAttribute()

(2)HTML DOM:用于HTML文档

(3)XML DOM:用于处理XML文档

XMLHttpRequest DOMParser - 可以把一段XML字符串解析为一棵DOM树

示例:异步的加载新闻列表

5.使用AJAX接收服务器返回的json响应——重点

JSON:原本是JS中创建的对象的“直接量”法,后来从JS中独立出来,作为一种字符串数据的表示法,被各种语言所支持。其作用于XML类似,但比XML更加轻量级、简洁、处理速度更快。

JSON格式表示字符串,有两种格式:

JSON对象字符串格式:'{ "k1":"v1", "k2": v2 }'

JSON数组字符串格式:'[ v1, v2, v3... ]'

示例:异步的加载新闻列表

服务器端:

header('Content-Type: application/json');

$arr = [ ];

echo json_encode( $arr ); //PHP数组=>JSON字符串

客户端:

(1)

(2) var jsObj =       JSON.parse( xhr.responseText ); //把JSON字符串解析为JS数组/对象

(3)

(4)

服务器端(PHP数据) => JSON字符串 => 客户端(JS对象)

悦为(深圳)科技有限公司

乐享其志

微信:JoyVisYOJOY

微博:http://weibo.com/JoyVis

官网:http://www.yuevis.com/

联系&投稿:service@joyvis.com

异步请求Ajax的更多相关文章

  1. [js开源组件开发]network异步请求ajax的扩展

    network异步请求ajax的扩展 在日常的应用中,你可能直接调用$.ajax是会有些问题的,比如说用户的重复点击,比如说我只希望它成功提交一次后就不能再提交,比如说我希望有个正在提交的loadin ...

  2. 异步请求Ajax(取得json数据)

    异步请求Ajax 没有学习Ajax之前请求数据的时候都是整个页面全部刷新了一次,也就是每次请求都会重新请求所有的资源.但是在很多时候不需要页面全部刷新,仅仅是需要页面的局部数据刷新即可,此时需要发送异 ...

  3. JavaScrpit中异步请求Ajax实现

    在前端页面开发的过程中,经常使用到Ajax请求,异步提交表单数据,或者异步刷新页面. 一般来说,使用Jquery中的$.ajax,$.post,$.getJSON,非常方便,但是有的时候,我们只因为需 ...

  4. 关于异步请求AJAX的具体解释

    1,异步请求的方法步骤: 1,推断当前用户支持的浏览器类型 XMLHttpRequest:推断是否支持非IE浏览器,相应的创建方法:xmlhttp = new XMLHttpRequest(); wi ...

  5. [异步请求]ajax、axios、fetch之间的详细区别以及优缺点

    1.jQuery ajax  $.ajax({ type: 'POST', url: url, data: data, dataType: dataType, success: function () ...

  6. jQuery异步请求ajax()之complete参数详解

    请求完成后回调函数 (请求success 和 error之后均调用).这个回调函数得到2个参数:XMLHTTPRequest) 对象和一个描述请求状态的字符串("success", ...

  7. 异步请求 ajax的使用详解

    https://blog.csdn.net/happyaliceyu/article/details/52381446 可以说是很详细了,赞

  8. 黑马学习AJAX jQuery发送异步请求 $.ajax() $.post() $.get()是在调用方法而不是定义方法

  9. ajax异步请求302分析

    1.前言 遇到这样一种情况,打开网页两个窗口a,b(都是已经登录授权的),在a页面中退出登录,然后在b页面执行增删改查,这个时候因为授权原因,b页面后端的请求肯定出现异常(对这个异常的处理,进行内部跳 ...

随机推荐

  1. Spring pom配置详解

    转载至http://blog.csdn.net/ithomer/article/details/9332071# 原博主注释的很详细 <project xmlns="http://ma ...

  2. RequireJS 基础(一)

    RequireJS由James Burke创建,他也是AMD规范的创始人. RequireJS会让你以不同于往常的方式去写JavaScript,你将不再使用script标签在HTML中引入JS文件,以 ...

  3. UE3 ExampleGame Android版无法运行解决方案

    首先将 UE3\UnrealEngine3\UDKGame\Build\Android 文件夹 拷贝到 ExampleGame\Build下面.里面有相应的android 配置文件.xml 若果此时 ...

  4. android studio中如何设置注释模板

    在开发程序的时候,我们一般都会给文件自动添加上一些关于文件的注释信息,比如开发者的名字,开发的时间,开发者的联系方式等等.那么在android studio中该如何设置呢? 工具/原料   andro ...

  5. eclipse 3.6 + tomcat 6.0 开发SSH框架学习

    1. 下载JDK 1.6.0.35 http://www.oracle.com/technetwork/java/javase/downloads/index-jsp-138363.html 下载之后 ...

  6. c++学习笔记01-输入输出流&&文件输入输出操作

    const int size=50等于#define size 50 字符串默认以0结尾: 一.输入输出流 cin.get()会从输入中取走一个字符: cin.peek()会从输入中检测第一个字符: ...

  7. linux 搭建svn

    1          安装SVN 官网下载:http://subversion.apache.org/packages.html SVN客户端:TortoiseSVN,官网下载:http://tort ...

  8. iOS中线程同步基本详解

    为什么使用线程同步技术:多个线程是同时执行的 如果多个线程同时操作一个资源 会造成此资源的数据错乱 线程同步简介 线程同步,多条线程按顺序地访问某个资源 注意:此处的同步不是一起执行的意思 是一个一个 ...

  9. hashMap的数据结构

    HashMap底层实现还是数组,只是数组的每一项都是一条链.

  10. kendoui treeview grid spreadsheet

    treeview 傻子方式获取id <!DOCTYPE html> <html> <head> <title>API</title> < ...