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]