XML 和 HTML

1.XML 被设计用来传输和存储数据。

2.HTML 被设计用来显示数据。

  1. XHR:
    ajax技术的核心是XMLHttpRequest对象(简称XHR),这是由微软首先引入的一个特性,其他浏览器提供商后来都提供了相同的实现。XHR为向服务器发送请求和解析服务器响应提供了流畅的接口,能够以异步方式从服务器取得更多信息,意味着用户单击后,可以不必刷新页面也能取得新数据
    参考
    https://www.runoob.com/xml/xml-intro.html
# [XHR简介](https://www.cnblogs.com/syfwhu/p/6116323.html

在XHR诞生前,网页要获取客户端和服务器的任何状态更新,都需要刷新一次,在XHR诞生后就可以完全通过JS代码异步实现这一过程。XHR的诞生也使最初的网页制作转换为开发交互应用,拉开了WEB2.0的序幕。 

XHR是一种浏览器API,极大简化了异步通信的过程,开发者并不需要关注底层的实现,因为浏览器会为我们完成这些工作,如连接管理、协议协商、HTTP请求格式化等等。最初版本的XHR能力非常有限,只支持文本传输,处理上传能力也不足,对于跨域请求也不支持。为解决这些问题,W3C于2008年发布了“XMLHttpRequest Level2”草案,新增了如下功能:

*   支持请求超时;
*   支持传输二进制和文本数据;
*   支持重写媒体类型和编码响应;
*   支持监控每个请求的进度事件;
*   支持有效的文件上传;
*   支持安全的跨来源请求。

2011年,W3C将“XMLHttpRequest Level2”规范与最初的“XMLHttpRequest”规范合并,所有XHR2新增的功能也都并入了原来的XHR API中,接口不变,功能增强。

## 1.XHR简介

XMLHttpRequest 对象提供了对 HTTP 协议的完全的访问,包括做出 POST 和 HEAD 请求以及普通的 GET 请求的能力。XMLHttpRequest 可以同步或异步地返回 Web 服务器的响应,并且能够以文本或者一个 DOM 文档的形式返回内容。XHR接口强制要求每个请求都具备严格的HTTP语义–应用提供数据和URL,浏览器格式化请求并管理每个连接的完整生命周期,所以XHR仅仅允许应用自定义一些HTTP首部,但更多的首部是不能自己设定的,如:

*   Accept-Charset, Accept-Encoding, Access-Control-*
*   Host, Upgrade, Connection, Referer, Origin
*   Cookie, Sec-, Proxy-, 及其他首部

浏览器会拒绝绝对不安全的首部重写,以保证应用不能假扮用户代理、用户或请求来源,如Origin由浏览器自动设置,Access-Control-Allow-Origin由服务器设置,如果接受该请求,不包含该字段即可,浏览器发出的请求将作废。

*   CORS请求会省略cookie和HTTP认证等用户凭据;
*   客户端被限制只能发送“简单的跨域请求”,包括只能使用GET POSD HEAD三种方式,只能访问通过XHR发送并读取的HTTP首部。

如果想要启用cookie和HTTP认证,客户端必须在发送请求时通过XHR对象发送额外的属性(withCredentials),而服务器也需要以Access-Control-Allow-Credentials响应,表示允许应用发送隐私数据。同样,如果客户需要写入或读取自定义HTTP标头或想要使用“非简单的方法”的请求,那么它必须首先通过发出一个预备请求,以获取第三方服务器的许可,如下所示:


`// Preflight request`

`OPTIONS /resource.js HTTP/1.1`

`Host: thirdparty.com`

`Origin: http:``//example.com`

`Access-Control-Request-Method: POST`

`Access-Control-Request-Headers: My-Custom-Header`

`...`

`// Preflight response`

`HTTP/1.1 200 OK`

`Access-Control-Allow-Origin: http:``//example.com`

`Access-Control-Allow-Methods: GET, POST, PUT`

`Access-Control-Allow-Headers: My-Custom-Header`

`...`

`(actual HTTP request)`

 |

W3C CORS规范定义的什么时候必须使用预备请求,“简单”的请求可以跳过它,但也有各种各样场景需要使用预备请求,这就添加一次往返网络延迟。可喜的是,一旦预备请求完成,它可以由客户端缓存,以避免在后续请求进行相同的验证。 
在XHR中,可以通过responseType-设置改变响应类型,如下所示:

*   “” 字符串(默认值)
*   “arraybuffer” ArrayBuffer
*   “blob” Blob
*   “document” Document
*   “json” JavaScript 对象,解析自服务器传递回来的JSON 字符串。
*   “text” 字符串

## 2.数据传输

### 2.1.数据请求:

下面是通过XHR获取一张图片,并显示到网页上的示例:


`var` `xhr = ``new` `XMLHttpRequest();`

`xhr.addEventListener(``"progress"``, updateProgress, ``false``);`

`xhr.addEventListener(``"load"``, transferComplete, ``false``);`

`xhr.addEventListener(``"error"``, transferFailed, ``false``);`

`xhr.addEventListener(``"abort"``, transferCanceled, ``false``);`

`xhr.open(``'GET'``, ``'/images/photo.webp'``);`

`xhr.responseType = ``'blob'``;`

`xhr.onload = ``function``() {`

`if` `(``this``.status == 200) {`

`var` `img = document.createElement(``'img'``);`

`img.src = window.URL.createObjectURL(``this``.response);`

`img.onload = ``function``() {`

`window.URL.revokeObjectURL(``this``.src);`

`}`

`document.body.appendChild(img);`

`}`

`};`

`xhr.send();`

 |

### 2.2.数据上传

上传相关事件在 XMLHttpRequest.upload 对象上被触发,像下面这样,向服务器发送一个formdata格式数据:


`var` `formData = ``new` `FormData();`

`formData.append(``'id'``, 123456);`

`formData.append(``'topic'``, ``'performance'``);`

`var` `xhr = ``new` `XMLHttpRequest();`

`xhr.upload.addEventListener(``"progress"``, updateProgress);`

`xhr.upload.addEventListener(``"load"``, transferComplete);`

`xhr.upload.addEventListener(``"error"``, transferFailed);`

`xhr.upload.addEventListener(``"abort"``, transferCanceled);`

`xhr.open(``'POST'``, ``'/upload'``);`

`xhr.onload = ``function``() { ... };`

`xhr.send(formData);`

 |

### 2.3.数据分片上传:


`var` `blob = ...;`

`const BYTES_PER_CHUNK = 1024 * 1024;`

`const SIZE = blob.size;`

`var` `start = 0;`

`var` `end = BYTES_PER_CHUNK;`

`while``(start < SIZE) {`

`var` `xhr = ``new` `XMLHttpRequest();`

`xhr.open(``'POST'``, ``'/upload'``);`

`xhr.onload = ``function``() { ... };`

`xhr.setRequestHeader(``'Content-Range'``, start+``'-'``+end+``'/'``+SIZE);`

`xhr.send(blob.slice(start, end));`

`start = end;`

`end = start + BYTES_PER_CHUNK;`

`}`

 |

注意:progress 事件在使用 file: 协议的情况下是无效的。

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