- D3.js 教程
- D3.js - 主页
- D3.js - 简介
- D3.js - 安装
- D3.js - 概念
- D3.js - 选择
- D3.js - 数据连接
- D3.js - SVG 简介
- D3.js - SVG 转换
- D3.js - 过渡
- D3.js - 动画
- D3.js - 绘制图表
- D3.js - 图表
- D3.js - 地理
- D3.js - 数组 API
- D3.js - 集合 API
- D3.js - 选择 API
- D3.js - 路径 API
- D3.js - 秤 API
- D3.js - 轴 API
- D3.js - 形状 API
- D3.js - 颜色 API
- D3.js - 转换 API
- D3.js - 拖动 API
- D3.js - 缩放 API
- D3.js - 请求 API
- 分隔符分隔值 API
- D3.js - 计时器 API
- D3.js - 工作示例
- D3.js 有用资源
- D3.js - 快速指南
- D3.js - 有用的资源
- D3.js - 讨论
D3.js - 请求 API
D3.js 提供了一个请求 API 来执行 XMLHttpRequest。本章详细解释了各种请求 API。
XMLHttp请求
XMLHttpRequest 是内置的http 客户端,用于模拟浏览器XMLHttpRequest 对象。它可以与为浏览器设计的 JS 一起使用,以提高代码的重用性并允许使用现有的库。
您可以将该模块包含在您的项目中并用作基于浏览器的 XHR 对象,如下所述。
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest; var xhr = new XMLHttpRequest();
它支持异步和同步请求,并执行 GET、POST、PUT 和 DELETE 请求。
配置请求
您可以使用下面的脚本直接从“d3js.org”加载。
<script src = "https://d3js.org/d3-request.v1.min.js"></script> <script> d3.json("/path/to/sample.json", callback); </script>
这里,请求 API 内置了对解析 JSON、CSV 和 TSV 的支持。您可以直接使用请求或文本来解析其他格式。
加载文本文件
要加载文本文件,请使用以下语法。
d3.text("/path/to/sample.txt", function(error, text) { if (error) throw error; console.log(text); });
解析 CSV 文件
要加载和解析 CSV 文件,请使用以下语法。
d3.csv("/path/to/sample.csv", function(error, data) { if (error) throw error; console.log(data); });
同样,您也可以加载 JSON 和 TSV 文件。
工作示例
让我们通过一个简单的示例来了解如何加载和解析 CSV 文件。在此之前,您需要在 d3 应用程序文件夹中创建一个名为“sample.csv”的 CSV 文件,如下所示。
Num1,Num2 1,2 3,4 5,6 7,8 9,10
现在,使用以下脚本创建一个网页“requests.html”。
<!DOCTYPE html> <html> <head> <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script> </head> <body> <h3> D3.js Requests API </h3> <script> d3.csv("sample.csv", function(data) { console.log(data); }); </script> </body> </html>
现在,请求浏览器,您将看到以下响应,
请求 API 方法
以下是一些最常用的 Requests API 方法。
- d3.request(url[,回调])
- request.header(名称[,值])
- request.mimeType([类型])
- request.user([值])
- 请求.密码([值])
- 请求超时([超时])
- 请求.get([数据])
- 请求.post([数据])
- request.send(方法[,数据])
- 请求.abort()
- d3.csv(url[[,行],回调])
现在让我们简要讨论其中的每一个。
d3.request(url[,回调])
它返回给定 URL 的新请求。如果分配了回调,则将其视为调用请求,否则尚未调用请求。它的定义如下。
d3.request(url) .get(callback);
您可以使用以下语法发布一些查询参数。
d3.request("/path/to/resource") .header("X-Requested-With", "XMLHttpRequest") .header("Content-Type", "application/x-www-form-urlencoded") .post("a = 2&b = 3", callback);
如果您希望指定请求标头或 mime 类型,则不得指定构造函数的回调。
request.header(名称[,值])
它用于将值设置到具有指定名称的请求标头。如果未指定值,它将删除具有指定名称的请求标头。它的定义如下。
d3.request(url) .header("Accept-Language", "en-US") .header("X-Requested-With", "XMLHttpRequest") .get(callback);
这里,XMLHttpRequest 的 X-Requested-With 标头是默认请求。
request.mimeType([类型])
它用于将 mime 类型分配给给定值。它的定义如下。
d3.request(url) .mimeType("text/csv") .get(callback);
request.user([值])
它用于分配用于身份验证的用户名。如果未指定用户名,则默认为 null。
请求.密码([值])
如果指定了一个值,它将设置用于身份验证的密码。
请求超时([超时])
如果指定了超时,则会将超时设置为指定的毫秒数。
请求.get([数据])
该方法用于通过 GET 方法发送请求。它的定义如下。
request.send("GET", data, callback);
请求.post([数据])
该方法用于通过POST方法发送请求。它的定义如下。
request.send("POST", data, callback);
request.send(方法[,数据])
此方法用于使用给定的 GET 或 POST 方法发送请求。
请求.abort()
该方法用于中止请求。
d3.csv(url[[,行],回调])
返回对指定 URL 处的 CSV 文件的新请求,默认 Mime 类型为 text/csv。以下语法显示没有回调。
d3.request(url) .mimeType("text/csv") .response(function(xhr) { return d3.csvParse(xhr.responseText, row); });
如果您使用 POST 方法指定回调,则其定义如下。
d3.request(url) .mimeType("text/csv") .response(function(xhr) { return d3.csvParse(xhr.responseText, row); }) .post(callback);
例子
在 d3 应用程序根文件夹目录中创建一个名为“lang.csv”的 csv 文件,并向其中添加以下更改。
Year,Language,Author 1972,C,Dennis Ritchie 1995,Java,James gosling 2011,D3 js,Mike Bostock
创建一个网页“csv.html”并向其中添加以下脚本。
<!DOCTYPE html> <html> <head> <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script> </head> <body> <h3> D3.js request API</h3> <script> d3.csv("lang.csv", function(d) { return { year: new Date(+d.Year, 0, 1), // convert "Year" column to Date language: d.Language, author: d.Author, }; }, function(error, rows) { console.log(error); console.log(rows[0].year); }); </script> </body> </html>
现在,请求浏览器,我们将看到以下响应。