D3.js-컬렉션 API

컬렉션은 여러 요소를 하나의 단위로 그룹화하는 단순한 개체입니다. 컨테이너라고도합니다. 이 장에서는 컬렉션 API에 대해 자세히 설명합니다.

API 구성

다음 스크립트를 사용하여 API를 구성 할 수 있습니다.

<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script>

</script>

Collections API 메서드

Collections API에는 객체,지도, 집합 및 중첩이 포함됩니다. 다음은 가장 일반적으로 사용되는 컬렉션 API 메서드입니다.

  • Objects API
  • Maps API
  • API 설정
  • Nests API

각 API를 자세히 살펴 보겠습니다.

Objects API

Object API는 중요한 데이터 유형 중 하나입니다. 다음 방법을 지원합니다-

  • d3.keys(object) −이 메서드는 객체 속성 키를 포함하고 속성 이름의 배열을 반환합니다.

  • d3.values(object) −이 메서드는 객체 값을 포함하고 속성 값의 배열을 반환합니다.

  • d3.entries(object)−이 메서드는 지정된 객체의 키와 값을 모두 포함하는 배열을 반환하는 데 사용됩니다. 각 항목은 키와 값이있는 개체입니다.

Example − 다음 코드를 살펴 보겠습니다.

d3.entries({one: 1})

여기서 키는 1이고 값은 1입니다.

Example − 웹 페이지 생성 objects.html 다음 변경 사항을 추가하십시오.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = {"jan": 1, "Feb": 2, "mar": 3, "apr": 4};
         console.log(d3.keys(month));
         console.log(d3.values(month));
         console.log(d3.entries(month));
      </script>
   </body>
</html>

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

Maps API

맵에는 키 및 값 쌍을 기반으로하는 값이 포함됩니다. 각 키 및 값 쌍을 항목이라고합니다. 맵에는 고유 한 키만 포함됩니다. 키를 기반으로 요소를 검색, 업데이트 또는 삭제하는 데 유용합니다. 다양한 Maps API 메소드를 자세히 살펴 보겠습니다.

  • d3.map([object[, key]])−이 방법은 새 맵을 생성하는 데 사용됩니다. 개체는 열거 가능한 모든 속성을 복사하는 데 사용됩니다.

  • map.has(key) −이 방법은 맵에 지정된 키 문자열에 대한 항목이 있는지 확인하는 데 사용됩니다.

  • map.get(key) −이 메서드는 지정된 키 문자열의 값을 반환하는 데 사용됩니다.

  • map.set(key, value)−이 방법은 지정된 키 문자열의 값을 설정하는 데 사용됩니다. 이전에 맵에 동일한 키 문자열에 대한 항목이있는 경우 이전 항목이 새 값으로 대체됩니다.

  • map.remove(key)− 맵 항목을 제거하는 데 사용됩니다. 키를 지정하지 않으면 false를 반환합니다.

  • map.clear() −이 맵에서 모든 항목을 제거합니다.

  • map.keys() −이 맵의 모든 항목에 대한 문자열 키 배열을 반환합니다.

  • map.values() −이 맵의 모든 항목에 대한 값 배열을 반환합니다.

  • map.entries() −이 맵의 각 항목에 대한 키-값 객체의 배열을 반환합니다.

  • (x) map.each(function) −이 메소드는 맵의 각 항목에 대해 지정된 함수를 호출하는 데 사용됩니다.

  • (xi) map.empty() −이 맵에 항목이없는 경우에만 true를 반환합니다.

  • (xii) map.size() −이 맵의 항목 수를 반환합니다.

Example − 웹 페이지 생성 maps.html 다음 변경 사항을 추가하십시오.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var month = d3.map([{name: "jan"}, {name: "feb"}], 
            function(d) { return d.name; });
         console.log(month.get("jan")); // {"name": "jan"}
         console.log(month.get("apr")); // undefined
         console.log(month.has("feb")); // true
         
         var map =  d3.map().set("fruit", "mango");
         console.log(map.get("fruit")); // mango
         console.log(map.remove("fruit")); // remove key and return true.
         console.log(map.size());    // size is 0 because key removed.
         console.log(map.empty());   // true
      </script>
   </body>
</html>

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

마찬가지로 다른 작업도 수행 할 수 있습니다.

API 설정

집합은 중복 요소를 포함 할 수없는 모음입니다. 수학적 집합 추상화를 모델링합니다. 다양한 Sets API 메서드를 자세히 살펴 보겠습니다.

  • d3.set([array[, accessor]])−이 방법은 새로운 세트를 생성하는 데 사용됩니다. 배열은 문자열 값을 추가하는 데 사용됩니다. 접근자는 선택 사항입니다.

  • set.has(value) −이 방법은 세트에 지정된 값 문자열에 대한 항목이 있는지 확인하는 데 사용됩니다.

  • set.add(value) − 지정된 값 문자열을 세트에 추가하는 데 사용됩니다.

  • set.remove(value) − 지정된 값 문자열이 포함 된 집합을 제거하는 데 사용됩니다.

  • set.clear() −이 세트에서 모든 값을 제거합니다.

  • set.values() −이 방법은 값 배열을 집합으로 반환하는 데 사용됩니다.

  • set.empty() −이 세트에 0 값이있는 경우에만 참을 반환합니다.

  • set.size() −이 세트의 값 수를 반환합니다.

Example − 웹 페이지 생성 sets.html 다음 변경 사항을 추가하십시오.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 collection API</h3>
      <script>
         var fruits =  d3.set().add("mango")
          .add("apple").add("orange");
         console.log(fruits.has("grapes")); // return false.
         console.log(fruits.remove("apple")); //true
         console.log(fruits.size());    // size is 2
         console.log(fruits.empty());   // true
      </script>
   </body>
</html>

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

마찬가지로 다른 작업도 수행 할 수 있습니다.

Nests API

중첩 API는 배열의 요소를 포함하고 계층 적 트리 구조에서 수행됩니다. 다양한 Nests API 메서드를 자세히 살펴 보겠습니다.

  • d3.nest() −이 방법은 새 둥지를 만드는 데 사용됩니다.

  • nest.key(key)−이 방법은 새로운 키 기능을 초기화하는 데 사용됩니다. 이 함수는 입력 배열의 각 요소를 호출하고 그룹의 요소를 반환하는 데 사용됩니다.

  • nest.sortKeys(comparator)−이 방법은 지정된 비교기에서 키를 정렬하는 데 사용됩니다. 함수는 d3.ascending 또는 d3.descending으로 정의됩니다.

  • nest.sortValues(comparator)−이 방법은 지정된 비교기에서 값을 정렬하는 데 사용됩니다. Comparator 함수는 리프 요소를 정렬합니다.

  • nest.map(array)−이 방법은 지정된 배열을 적용하고 중첩 된 맵을 반환하는 데 사용됩니다. 반환 된 맵의 각 항목은 첫 번째 키 함수에서 반환 한 고유 키 값에 해당합니다. 입력 값은 등록 된 키 기능의 수에 따라 다릅니다.

  • nest.object(array) −이 방법은 지정된 배열에 중첩 연산자를 적용하고 중첩 된 객체를 반환하는 데 사용됩니다.

  • nest.entries(array) −이 메서드는 지정된 배열에 중첩 연산자를 적용하고 키-값 항목의 배열을 반환하는 데 사용됩니다.

간단한 웹 페이지 고려 nest.html 위에서 설명한 중첩 방법을 수행합니다.

Example − 다음 예를 살펴 보겠습니다.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 Nest API</h3>
      <script>
         var data = [
            {
               "color" : "red",
               "key" : 1
            },
            {
               "color" : "green",
               "key" : 2
            },
            {
               "color" : "blue",
               "key" : 75
            }
         ]
         var nest =  d3.nest()
            .key(function (d) { return d.color; })
            .entries(data)console.log(nest);
         var filter = nest.filter(function (d) { return d.key = = = 'red' })
         console.log(filter);
      </script>
   </body>
</html>

이제 브라우저에서 결과를 확인하면 다음과 같은 결과를 볼 수 있습니다.

Array[3]
0: Object
1: Object
2: Object
length: 3
__proto__: Array[0]

Array[1]
0: Object
length: 1
__proto__: Array[0]