D3.js-API 요청

D3.js는 XMLHttpRequest를 수행하기위한 요청 API를 제공합니다. 이 장에서는 다양한 요청 API에 대해 자세히 설명합니다.

XMLHttpRequest

XMLHttpRequest는 브라우저 XMLHttpRequest 객체를 에뮬레이트하기위한 내장 http 클라이언트입니다. 코드 재사용을 개선하고 기존 라이브러리를 사용할 수 있도록 브라우저 용으로 설계된 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 메서드 요청

다음은 가장 일반적으로 사용되는 요청 API 메서드 중 일부입니다.

  • d3.request (url [, 콜백])
  • request.header (이름 [, 값])
  • request.mimeType([type])
  • request.user([value])
  • request.password([value])
  • request.timeout([timeout])
  • request.get([data])
  • request.post([data])
  • request.send (메서드 [, 데이터])
  • request.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입니다.

request.password ([값])

값이 지정되면 인증을위한 비밀번호를 설정합니다.

request.timeout ([타임 아웃])

제한 시간이 지정되면 제한 시간을 지정된 밀리 초 수로 설정합니다.

request.get ([데이터])

이 메서드는 GET 메서드로 요청을 보내는 데 사용됩니다. 아래에 정의되어 있습니다.

request.send("GET", data, callback);

request.post ([데이터])

이 메서드는 POST 메서드로 요청을 보내는 데 사용됩니다. 아래에 정의되어 있습니다.

request.send("POST", data, callback);

request.send (메서드 [, 데이터])

이 메서드는 지정된 GET 또는 POST 메서드를 사용하여 요청을 보내는 데 사용됩니다.

request.abort ()

이 메서드는 요청을 중단하는 데 사용됩니다.

d3.csv (url [[, 행], 콜백])

기본 Mime 유형 text / csv를 사용하여 지정된 URL에서 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>

이제 브라우저를 요청하면 다음과 같은 응답이 표시됩니다.