# 请求
> [Wiki](Home) ▸ \[\[API--中文手册\]\] ▸ \[\[核心函数\]\] ▸ **请求**
- 本文档是D3官方文档中文翻译,并保持与[最新版](https://github.com/mbostock/d3/wiki/API-Reference)同步。
- 如发现翻译不当或有其他问题可以通过以下方式联系译者:
- 邮箱:zhang\_tianxu@sina.com
- QQ群:[D3数据可视化](http://jq.qq.com/?_wv=1027&k=ZGcqYF)205076374,[大数据可视化](http://jq.qq.com/?_wv=1027&k=S8wGMe)436442115
如果你不访问数据那么你就不能可视化它。幸运的是有很多的方法可以把数据放到浏览器中。对于小数据集,你可以硬编码到你的脚本里,或者使用数据属性嵌入到DOM中。对于大数据集,你可以引用外部脚本并定义你的数据为一个全局变量。(JSONP就是一个常见的例子)。最通用的方式是使用XMLHttpRequest, 或说XHR加载数据到浏览器。这允许一步加载数据(当数据加载之后其他的页面就可以展示了),并且比JSONP更安全。D3的xhr模块可以简单的加载和解析数据。
当异步加载数据时,代码取决于加载的数据通常存在于回调函数之内。例如D3网站的案例calendar visualization :[http://mbostock.github.com/d3/ex/calendar.html代码不依赖于数据可以在页面加载时立即运行。你也可以发现保存数据到全局命名空间是很方便的,这样你就可以在初始化渲染之后访问它,例如在过渡期间。你可以使用闭包实现它,或者简单地指定加载数据为全局变量。](http://mbostock.github.com/d3/ex/calendar.html%E4%BB%A3%E7%A0%81%E4%B8%8D%E4%BE%9D%E8%B5%96%E4%BA%8E%E6%95%B0%E6%8D%AE%E5%8F%AF%E4%BB%A5%E5%9C%A8%E9%A1%B5%E9%9D%A2%E5%8A%A0%E8%BD%BD%E6%97%B6%E7%AB%8B%E5%8D%B3%E8%BF%90%E8%A1%8C%E3%80%82%E4%BD%A0%E4%B9%9F%E5%8F%AF%E4%BB%A5%E5%8F%91%E7%8E%B0%E4%BF%9D%E5%AD%98%E6%95%B0%E6%8D%AE%E5%88%B0%E5%85%A8%E5%B1%80%E5%91%BD%E5%90%8D%E7%A9%BA%E9%97%B4%E6%98%AF%E5%BE%88%E6%96%B9%E4%BE%BF%E7%9A%84%EF%BC%8C%E8%BF%99%E6%A0%B7%E4%BD%A0%E5%B0%B1%E5%8F%AF%E4%BB%A5%E5%9C%A8%E5%88%9D%E5%A7%8B%E5%8C%96%E6%B8%B2%E6%9F%93%E4%B9%8B%E5%90%8E%E8%AE%BF%E9%97%AE%E5%AE%83%EF%BC%8C%E4%BE%8B%E5%A6%82%E5%9C%A8%E8%BF%87%E6%B8%A1%E6%9C%9F%E9%97%B4%E3%80%82%E4%BD%A0%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%E9%97%AD%E5%8C%85%E5%AE%9E%E7%8E%B0%E5%AE%83%EF%BC%8C%E6%88%96%E8%80%85%E7%AE%80%E5%8D%95%E5%9C%B0%E6%8C%87%E5%AE%9A%E5%8A%A0%E8%BD%BD%E6%95%B0%E6%8D%AE%E4%B8%BA%E5%85%A8%E5%B1%80%E5%8F%98%E9%87%8F%E3%80%82)
```
var data; // a global
d3.json("path/to/file.json", function(error, json) {
if (error) return console.warn(error);
data = json;
visualizeit();
});
```
默认情况下,大多数的浏览器不允许跨域访问。为了支持跨域访问,服务器必须设置头Access-Control-Allow-Origin: \*。更多信息参见W3C的建议跨域资源分享。对于IE9,d3.xhr使用非标准的XDomainRequest支持跨域访问。 跨域资源分享:<http://www.w3.org/TR/cors/>XHR
# d3.xhr(url\[, mimeType\]\[, callback\])
为指定的url创建一个异步访问。参数mimeType可能被指定为第二个参数,例如“text/plain”。如果指定了回调函数,那么请求就会使用GET方法立即发出,并且当资源被加载或者请求失败之后回调函数就会被异步调用。如果有错的话XMLHttpRequest对象代表了response。当错误发生时,response是未定义的。如果response有一个不成功状态值,那么错误就是XMLHttpRequest对象。如果没有指定回调函数,返回的request可以被分发使用xhr.get,xhr.post 或相近的,并使用xhr.on处理。
# xhr.header(name\[, value\])
```
d3.csv("/path/to/file.csv")
.header("header-name", "header-value")
.get(function(error, data) {
// callback
});
```
如果指定了value,设置请求头指定的name参数为指定的value值。如果value参数是null值,就移除指定名称的请求头,如果没指定value值就会返回请求头中指定名称的当前值,请求头名称是大小写敏感的。 请求头只可以在发送请求之前被修改。因此,如果你想指定一个请求头就不能传递回调函数给d3.xhr constructor。而应该使用xhr.get或者相似的。例如:
```
d3.csv("/path/to/file.csv")
.header("header-name", "header-value")
.get(function(error, data) {
// callback
});
```
# xhr.mimeType(\[type\])
如果type参数被指定了,就会设置请求的mime类型为指定的值。如果type是null,就会清楚当前的mime类型(有的话)。如果没有指定mime类型,就返回当前的mime类型,默认是null。Mime类型被用来设置"Accept"请求头和覆盖MimeType。请求头只可以在发送请求之前被修改。
# xhr.responseType(type)
如果type被指定了,设置response类型,例如:"", "arraybuffer","blob","document",或者 "text"。如果type没有指定,就返回当前的response类型默认是””。
# xhr.response(value)
如果指定了value参数,就设置response的值函数为指定的函数。如果value没有被指定,返回当前的response的值函数,默认就是验证函数。response的值函数用来映射返回XMLHttpRequest对象为相应的数据类型。例如,对于文本请求,你可以使用 function(request) { return request.responseText; },而对于JSON请求你可能使用function(request) { return JSON.parse(request.responseText); }。
# xhr.get(\[callback\])
使用GET方法分发请求。如果指定了回调函数,在发送请求或者出错的时候就会被异步调用。回调函数使用两个参数调用:error(有的话)和response值。错误发生时response值是未定义的。如果没有指定回调函数"load"和"error"监听器会通过xhr.on注册。这个方法是xhr.send的一个方便的包装。
# xhr.post(\[data\]\[, callback\])
使用POST方法分发这个请求,在请求体中可选地发送指定的data。如果指定了回调函数,在发送请求或者出错的时候就会被异步调用。回调函数使用两个参数调用:error(有的话)和response值。错误发生时response值是未定义的。如果没有指定回调函数"load"和"error"监听器会通过xhr.on注册。这个方法是xhr.send的一个方便的包装。 使用URL编码的例子:
```
d3.csv("/path/to/file.csv")
.header("Content-Type", "application/x-www-form-urlencoded")
.post("a=2&b=3", function(error, data) {
// callback
});
```
An example using JSON encoding:
```
d3.csv("/path/to/file.csv")
.header("Content-Type", "application/json")
.post(JSON.stringify({a: 2, b: 3}), function(error, data) {
// callback
});
```
# xhr.send(method\[, data\]\[, callback\])
使用指定的方法分发这个请求,在请求体中可选地发送指定的data。如果指定了回调函数,在发送请求或者出错的时候就会被异步调用。回调函数使用两个参数调用:error(有的话)和response值。错误发生时response值是未定义的。如果没有指定回调函数"load"和"error"监听器会通过xhr.on注册。这个方法是xhr.send的一个方便的包装。
# xhr.abort()
中止正在发送的请求。参见XMLHttpRequest的中止: <http://www.w3.org/TR/XMLHttpRequest/#the-abort%28%29-method>
# xhr.on(type\[, listener\])
对指定的类型添加或者移除事件监听器到这个请求。类型必须是以下类型之一: beforesend – 在请求发送之前,允许自定义标题等来进行设定。 progress – 用来监听请求的过程。 load – 当请求成功的完成之后。 error –当请求不成功之后;包含4xx和5xx返回值。
如果一个相同的类型监听器已经被注册,已存在的监听器就会在新监听器添加之前被移除。为了给同一个事件类型注册多个监听器,那么类型将遵循可选的命名空间,例如"load.foo" 和 "load.bar"。为了移除监听器,传递null值为监听器。 如果没有指定监听器,为指定的类型(有的话)返回当前分配的监听器。
简便方法 通常,d3.xhr不会直接使用。取而代之的是使用类型特定的方法,例如: d3.text加载简单文本,d3.json加载JSON,d3.xml 加载XML,d3.html 加载HTML,d3.csv加载逗号分隔值文件,d3.tsv加载制表符分隔文件。
# d3.text(url\[, mimeType\]\[, callback\])
指定的URL创建一个文本文件请求。选项mimeType可以指定为第二参数,例如"text/plain"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和response文本。错误发生时response文本是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
# d3.json(url\[, callback\])
指定的URL创建一个JSON文件请求。选项mimeType可以指定为第二参数,例如"application/json"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和解析过的JSON。错误发生时解析过的JSON是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
# d3.xml(url\[, mimeType\]\[, callback\])
指定的URL创建一个XML文件请求。选项mimeType可以指定为第二参数,例如"application/xml"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和解析为文档的XML。错误发生时解析的XML是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
# d3.html(url\[, callback\])
指定的URL创建一个文本文件请求。选项mimeType可以指定为第二参数,例如"text/html"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和解析为文档碎片的HTML。错误发生时解析后的HTML是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
# d3.csv(url\[, accessor\]\[, callback\])
指定的URL创建一个CSV文件请求。选项mimeType可以指定为第二参数,例如"text/csv"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和每个RFC 4180解析的行数组。错误发生时行数组是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
# d3.tsv(url\[, accessor\]\[, callback\])
指定的URL创建一个文本文件请求。选项mimeType可以指定为第二参数,例如"text/tab-separated-values"。如果指定了回调函数,请求将通过GET方法立即分发,当文件被加载或者请求失败之后回调函数将被异步调用。回调函数的调用使用两个参数:error(有的话)和每个RFC 4180解析的行数组。错误发生时行数组是未定义的。如果没有指定回调函数,返回的请求可能使用xhr.get或近似的方法分发,并使用xhr.on处理。
2014年11月22日 00:11:22 gulu翻译