D3.js-선택 API
선택 항목은 DOM (문서 개체 모델)의 강력한 데이터 기반 변환입니다. 속성, 스타일, 속성, HTML 또는 텍스트 콘텐츠 등을 설정하는 데 사용됩니다. 이 장에서는 선택 API에 대해 자세히 설명합니다.
API 구성
아래 스크립트를 사용하여 API를 직접 구성 할 수 있습니다.
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script>
</script>
선택 API 방법
다음은 선택 API에서 가장 중요한 방법입니다.
- d3.selection()
- d3.select(selector)
- d3.selectAll(selector)
- selection.selectAll(selector)
- selection.filter(filter)
- selection.merge(other)
- d3.matcher(selector)
- d3.creator(name)
- selection.each(function)
- selection.call (함수 [, 인수…])
- d3.local()
- local.set (노드, 값)
- local.get(node)
- local.remove(node)
이제 각각에 대해 자세히 논의하겠습니다.
d3.selection ()
이 방법은 루트 요소를 선택하는 데 사용됩니다. 이 함수는 선택을 테스트하거나 선택 d3js를 확장하는 데 사용할 수도 있습니다.
d3.select (선택기)
이 메서드는 지정된 선택자 문자열과 일치하는 첫 번째 요소를 선택하는 데 사용됩니다.
Example − 다음 예를 살펴 보겠습니다.
var body = d3.select("body");
선택기가 문자열이 아닌 경우 아래 정의 된 지정된 노드를 선택합니다.
d3.select("p").style("color", "red");
d3.selectAll (선택기)
이 메서드는 지정된 선택기 문자열과 일치하는 모든 요소를 선택합니다.
Example − 다음 예를 살펴 보겠습니다.
var body = d3.selectAll("body");
선택기가 문자열이 아닌 경우 아래 정의 된 지정된 노드 배열을 선택합니다.
d3.selectAll("body").style("color", "red");
selection.selectAll (선택기)
이 방법은 요소를 선택하는 데 사용됩니다. 지정된 선택자 문자열과 일치하는 하위 요소를 선택합니다. 반환 된 선택 항목의 요소는이 선택 항목의 해당 상위 노드별로 그룹화됩니다. 현재 요소에 대해 지정된 선택기와 일치하는 요소가 없거나 선택기가 null 인 경우 현재 색인의 그룹은 비어 있습니다.
Example − 다음 예를 살펴 보겠습니다.
var b = d3.selectAll("p").selectAll("b");
selection.filter (필터)
이 메서드는 선택 항목을 필터링하는 데 사용되며 지정된 필터가 참인 요소 만 포함 된 새 선택 항목을 반환합니다.
Example − 다음 예를 살펴 보겠습니다.
var even = d3.selectAll("tr").filter(":nth-child(odd)");
여기에서 선택한 테이블 행을 필터링하면 홀수 만 반환됩니다.
selection.merge (기타)
이 메서드는 지정된 다른 선택과 병합되는 새 선택을 반환하는 데 사용됩니다.
Example − 다음 예를 살펴 보겠습니다.
var rect = svg.selectAll("rect").data(data);
rect.enter().append("rect").merge(rect);
d3.matcher (선택기)
이 방법은 지정된 선택자를 할당하는 데 사용됩니다. true를 반환하는 함수를 반환합니다.
Example − 다음 예를 살펴 보겠습니다.
var p = selection.filter(d3.matcher("p"));
d3.creator (이름)
이 메서드는 지정된 요소 이름을 할당하는 데 사용됩니다. 이것이 부모 요소라고 가정하고 지정된 이름의 요소를 만드는 함수를 반환합니다.
Example − 다음 예를 살펴 보겠습니다.
selection.append(d3.creator("p"));
selection.each (함수)
이 메서드는 현재 기준 (d), 현재 인덱스 (i) 및 현재 DOM 요소 (nodes [i)로 현재 그룹 (노드)에 의해 전달 된 순서대로 선택한 각 요소에 대해 지정된 함수를 호출하는 데 사용됩니다. ]). 아래에 설명되어 있습니다.
parent.each(function(p, j) {
d3.select(this)
.selectAll(".child")
.text(function(d, i) { return "child " + d.name + " of " + p.name; });
});
selection.call (함수 [, 인수…])
지정된 함수를 정확히 한 번 호출하는 데 사용됩니다. 구문은 아래와 같습니다.
function name(selection, first, last) {
selection.attr("first-name", first).attr("last-name", last);
}
이 방법은 아래와 같이 지정할 수 있습니다.
d3.selectAll("p").call(name, "Adam", "David");
d3.local ()
D3 로컬을 사용하면 데이터와 독립적 인 로컬 상태를 정의 할 수 있습니다.
Example − 다음 예를 살펴 보겠습니다.
var data = d3.local();
var와 달리 각 로컬 값도 DOM에 의해 범위가 지정됩니다.
local.set (노드, 값)
이 메서드는 지정된 노드의이 로컬 값을 값으로 설정합니다.
Example − 다음 예를 살펴 보겠습니다.
selection.each(function(d)
{ data.set(this, d.value); });
local.get(node)
이 메서드는 지정된 노드에서이 로컬 값을 반환합니다. 노드가이 로컬을 정의하지 않으면이를 정의하는 가장 가까운 조상의 값을 반환합니다.
local.remove (노드)
이 메서드는 지정된 노드에서이 로컬 값을 삭제합니다. 노드가 정의되어 있으면 true를 반환하고 그렇지 않으면 false를 반환합니다.