D3.js-선택

선택은 D3.js의 핵심 개념 중 하나입니다. CSS 선택자를 기반으로합니다. 웹 페이지에서 하나 이상의 요소를 선택할 수 있습니다. 또한 사전 정의 된 데이터 세트와 관련된 요소를 수정, 추가 또는 제거 할 수 있습니다. 이 장에서는 선택 항목을 사용하여 데이터 시각화를 만드는 방법을 살펴 봅니다.

D3.js는 다음 두 가지 방법을 사용하여 HTML 페이지에서 요소를 선택하는 데 도움이됩니다.

  • select()− 주어진 CSS 선택자와 일치하여 하나의 DOM 요소 만 선택합니다. 주어진 CSS 선택기에 둘 이상의 요소가있는 경우 첫 번째 요소 만 선택합니다.

  • selectAll()− 주어진 CSS 선택자를 일치시켜 모든 DOM 요소를 선택합니다. jQuery로 요소를 선택하는 데 익숙하다면 D3.js 선택기는 거의 동일합니다.

각 방법을 자세히 살펴 보겠습니다.

select () 메서드

select () 메서드는 CSS 선택자를 기반으로 HTML 요소를 선택합니다. CSS 선택기에서 다음 세 가지 방법으로 HTML 요소를 정의하고 액세스 할 수 있습니다.

  • HTML 요소의 태그 (예 : div, h1, p, span 등)
  • HTML 요소의 클래스 이름
  • HTML 요소의 ID

예제를 통해 실제로 살펴 보겠습니다.

태그 별 선택

TAG를 사용하여 HTML 요소를 선택할 수 있습니다. 다음 구문은 "div"태그 요소를 선택하는 데 사용됩니다.

d3.select(“div”)

Example −“select_by_tag.html”페이지를 생성하고 다음 변경 사항을 추가합니다.

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

   <body>
      <div>
         Hello World!    
      </div>
      
      <script>
         alert(d3.select("div").text());
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

클래스 이름으로 선택

CSS 클래스를 사용하여 스타일이 지정된 HTML 요소는 다음 구문을 사용하여 선택할 수 있습니다.

d3.select(“.<class name>”)

"select_by_class.html"웹 페이지를 만들고 다음 변경 사항을 추가하십시오.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         alert(d3.select(".myclass").text());
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

ID로 선택

HTML 페이지의 모든 요소에는 고유 한 ID가 있어야합니다. 요소의이 고유 ID를 사용하여 아래 지정된대로 select () 메서드를 사용하여 액세스 할 수 있습니다.

d3.select(“#<id of an element>”)

웹 페이지 'select_by_id.html'을 만들고 다음 변경 사항을 추가합니다.

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

   <body>
      <div id = "hello">
         Hello World!
      </div>
      
      <script>
         alert(d3.select("#hello").text());
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

DOM 요소 추가

D3.js 선택은 append() 그리고 text()기존 HTML 문서에 새 요소를 추가하는 메소드. 이 섹션에서는 DOM 요소 추가에 대해 자세히 설명합니다.

append () 메서드

append () 메서드는 현재 선택에서 요소의 마지막 자식으로 새 요소를 추가합니다. 이 메서드는 요소의 스타일, 속성, 속성, HTML 및 텍스트 콘텐츠를 수정할 수도 있습니다.

웹 페이지 "select_and_append.html"을 만들고 다음 변경 사항을 추가하십시오.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span");
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력을 볼 수 있습니다.

여기에서 append () 메서드는 아래와 같이 div 태그 안에 새 태그 범위를 추가합니다.

<div class = "myclass">
   Hello World!<span></span>
</div>

text () 메서드

text () 메서드는 선택 / 추가 된 요소의 내용을 설정하는 데 사용됩니다. 위의 예제를 변경하고 아래와 같이 text () 메서드를 추가하겠습니다.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select("div.myclass").append("span").text("from D3.js");
      </script>
   </body>
</html>

이제 웹 페이지를 새로 고치면 다음 응답이 표시됩니다.

여기에서 위의 스크립트는 연결 작업을 수행합니다. D3.js는chain syntax, 당신이 알아볼 수있는 jQuery. 마침표와 함께 메서드를 연결하면 한 줄의 코드에서 여러 작업을 수행 할 수 있습니다. 빠르고 쉽습니다. 동일한 스크립트는 아래와 같이 체인 구문 없이도 액세스 할 수 있습니다.

var body = d3.select("div.myclass");
var span = body.append("span");
span.text("from D3.js");

요소 수정

D3.js는 다양한 방법을 제공합니다. html(), attr()style()선택한 요소의 내용과 스타일을 수정합니다. 이 장에서 수정 메소드를 사용하는 방법을 살펴 보겠습니다.

html () 메서드

html () 메서드는 선택 / 추가 된 요소의 html 콘텐츠를 설정하는 데 사용됩니다.

웹 페이지“select_and_add_html.html”을 생성하고 다음 코드를 추가합니다.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").html("Hello World! <span>from D3.js</span>");
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

attr () 메서드

attr () 메서드는 선택한 요소의 속성을 추가하거나 업데이트하는 데 사용됩니다. 웹 페이지“select_and_modify.html”을 생성하고 다음 코드를 추가합니다.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

style () 메서드

style () 메서드는 선택한 요소의 스타일 속성을 설정하는 데 사용됩니다. 웹 페이지“select_and_style.html”을 만들고 다음 코드를 추가합니다.

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

   <body>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.select(".myclass").style("color", "red");
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

classed () 메서드

classed () 메서드는 HTML 요소의 "class"속성을 설정하는 데 독점적으로 사용됩니다. 따라서 단일 HTML 요소는 여러 클래스를 가질 수 있습니다. HTML 요소에 클래스를 할당 할 때주의해야합니다. 이 메서드는 요소에서 하나 이상의 클래스를 처리하는 방법을 알고 있으며 성능이 뛰어납니다.

  • Add class− 클래스를 추가하려면 분류 된 메서드의 두 번째 매개 변수가 true로 설정되어야합니다. 아래에 정의되어 있습니다-

d3.select(".myclass").classed("myanotherclass", true);
  • Remove class− 클래스를 제거하려면 분류 된 메서드의 두 번째 매개 변수를 false로 설정해야합니다. 아래에 정의되어 있습니다-

d3.select(".myclass").classed("myanotherclass", false);
  • Check class− 클래스의 존재를 확인하려면 두 번째 매개 변수를 생략하고 쿼리중인 클래스 이름을 전달하면됩니다. 존재한다면 true를 반환하고 그렇지 않으면 false를 반환합니다.

d3.select(".myclass").classed("myanotherclass");

선택 항목에 클래스가있는 경우 true를 반환합니다. 사용하다d3.select 단일 요소 선택 용.

  • Toggle class − 클래스를 반대 상태로 전환하려면 – 이미 존재하는 경우 제거하고, 아직 존재하지 않는 경우 추가 – 다음 중 하나를 수행 할 수 있습니다.

    단일 요소의 경우 코드는 다음과 같이 보일 수 있습니다.

var element = d3.select(".myclass")
element.classed("myanotherclass", !oneBar.classed("myanotherclass"));

selectAll () 메서드

selectAll () 메서드는 HTML 문서에서 여러 요소를 선택하는 데 사용됩니다. select 메소드는 첫 번째 요소를 선택하지만 selectAll 메소드는 특정 선택자 문자열과 일치하는 모든 요소를 ​​선택합니다. 선택 항목이 아무것도 일치하지 않으면 빈 선택 항목을 반환합니다. 모든 추가 수정 방법을 연결할 수 있습니다.append(), html(), text(), attr(), style(), classed(),등, selectAll () 메서드에서도 마찬가지입니다. 이 경우 메서드는 일치하는 모든 요소에 영향을줍니다. 새로운 웹 페이지“select_multiple.html”을 생성하고 다음 스크립트를 추가하여 이해합시다.

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

   <body>
      <h2 class = "myclass">Message</h2>
      <div class = "myclass">
         Hello World!
      </div>
      
      <script>
         d3.selectAll(".myclass").attr("style", "color: red");
      </script>
   </body>
</html>

브라우저를 통해 웹 페이지를 요청하면 화면에 다음과 같은 출력이 표시됩니다.

여기서 attr () 메서드는 divh2 tag 두 태그의 텍스트 색상이 빨간색으로 변경됩니다.