>웹 프론트엔드 >JS 튜토리얼 >D3.js에서 `selectAll(null)`을 사용하는 이유는 무엇입니까?

D3.js에서 `selectAll(null)`을 사용하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-03 20:53:29594검색

Why Use `selectAll(null)` in D3.js?

null 선택: D3.js의 selectAll(null) 뒤에 숨겨진 논리

D3.js에서는 다음과 같은 코드가 발생할 수 있습니다. DOM 요소를 추가하는 경우:

var circles = svg.selectAll(null)
    .data(data)
    .enter()
    .append("circle");

"circle", "p" 또는 ".foo"와 같은 특정 요소를 선택하는 것이 일반적이지만 "null"을 선택하는 것은 혼란스러워 보일 수 있습니다. 그러나 이 기술을 사용하면 "입력" 선택이 항상 데이터 배열과 일치하며 각 데이터 포인트에 대해 하나의 요소가 포함됩니다.

"입력" 선택

"입력" 선택은 해당 DOM 요소가 없는 데이터 요소로 구성됩니다. D3.js를 사용하면 기존 DOM 요소에 데이터를 바인딩할 수 있습니다. 그러나 DOM 요소보다 데이터 포인트가 더 많은 경우 초과된 데이터 포인트는 "입력" 선택에 속합니다. 이 선택 항목에 "추가" 기능을 사용하면 새로운 DOM 요소가 생성되어 데이터가 해당 요소에 바인딩됩니다.

기존 요소에 데이터 바인딩

일반적으로 다음 요소를 선택합니다. 바인딩은 다음과 같습니다.

var circles = svg.selectAll("circle")
    .data(data);

circles.enter()
.append("circle");

이 접근 방식은 기존 원 요소에 대한 "업데이트" 선택을 생성하는 반면, "입력" 선택은 해당 요소 없이 데이터 포인트를 처리합니다.

그러나, selectAll(null)은 기존 요소의 유무에 관계없이 전체 데이터 배열을 나타내는 선택 항목을 반환합니다. 이렇게 하면 DOM 상태에 관계없이 "입력" 선택에 항상 전체 데이터 세트가 포함됩니다.

이 개념을 설명하려면 다음을 따르세요. 다음 예를 고려해 보세요.

var body = d3.select("body");
var data = ["red", "blue", "green"];
var p = body.selectAll("p")
  .data(data)
  .enter()
  .append("p")
  .text(d=> "I am a " + d + " paragraph!")
  .style("color", String);

처음에 selectAll(null)은 "입력" 선택에 모든 데이터 포인트가 포함되도록 하고 그에 따라 단락이 생성되도록 합니다.

요약하자면, selectAll(null)은 "입력" 선택을 보장하기 위한 일관된 메커니즘을 제공합니다. " 선택은 항상 데이터 배열과 정렬되므로 DOM 상태에 관계없이 데이터 바인딩이 간단해집니다.

위 내용은 D3.js에서 `selectAll(null)`을 사용하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.