D3.js - Pojęcia

D3.js to biblioteka JavaScript typu open source dla -

  • Oparta na danych manipulacja modelem obiektu dokumentu (DOM).
  • Praca z danymi i kształtami.
  • Układanie elementów wizualnych dla danych liniowych, hierarchicznych, sieciowych i geograficznych.
  • Umożliwienie płynnych przejść między stanami interfejsu użytkownika (UI).
  • Umożliwienie efektywnej interakcji z użytkownikiem.

Standardy sieciowe

Zanim zaczniemy używać D3.js do tworzenia wizualizacji, musimy zapoznać się ze standardami sieciowymi. Następujące standardy sieciowe są intensywnie używane w D3.js.

  • HyperText Markup Language (HTML)
  • Model obiektu dokumentu (DOM)
  • Kaskadowe arkusze stylów (CSS)
  • Skalowalna grafika wektorowa (SVG)
  • JavaScript

Przyjrzyjmy się szczegółowo każdemu z tych standardów sieciowych.

HyperText Markup Language (HTML)

Jak wiemy, HTML służy do strukturyzacji zawartości strony internetowej. Jest przechowywany w pliku tekstowym z rozszerzeniem „.html”.

Example - Typowy przykład kodu HTML „bare-bones” wygląda następująco

<!DOCTYPE html>
<html lang = "en">
   <head>
      <meta charset = "UTF-8">
      <title></title>
   </head>

   <body>
   </body>
</html>

Model obiektu dokumentu (DOM)

Kiedy strona HTML jest ładowana przez przeglądarkę, jest konwertowana na strukturę hierarchiczną. Każdy tag w HTML jest konwertowany na element / obiekt w DOM z hierarchią rodzic-dziecko. To sprawia, że ​​nasz HTML ma bardziej logiczną strukturę. Po utworzeniu DOM łatwiej jest manipulować (dodawać / modyfikować / usuwać) elementami na stronie.

Pozwól nam zrozumieć DOM, używając następującego dokumentu HTML -

<!DOCTYPE html>
<html lang = "en">
   <head>
      <title>My Document</title>
   </head>

   <body>
      <div>
         <h1>Greeting</h1>
         <p>Hello World!</p>
      </div>
   </body>
</html>

Model obiektu dokumentu powyższego dokumentu HTML jest następujący:

Kaskadowe arkusze stylów (CSS)

Podczas gdy HTML zapewnia strukturę stronie internetowej, style CSS sprawiają, że strona internetowa jest przyjemniejsza do oglądania. CSS to plikStyle Sheet Languageużywany do opisu prezentacji dokumentu napisanego w HTML lub XML (w tym dialektach XML, takich jak SVG lub XHTML). CSS opisuje, jak elementy powinny być renderowane na stronie internetowej.

Skalowalna grafika wektorowa (SVG)

SVG to sposób renderowania obrazów na stronie internetowej. SVG nie jest bezpośrednim obrazem, ale jest po prostu sposobem tworzenia obrazów za pomocą tekstu. Jak sama nazwa wskazuje, jest to plikScalable Vector. Skaluje się zgodnie z rozmiarem przeglądarki, więc zmiana rozmiaru przeglądarki nie spowoduje zniekształcenia obrazu. Wszystkie przeglądarki obsługują SVG z wyjątkiem IE 8 i starszych. Wizualizacje danych to reprezentacje wizualne i wygodnie jest używać SVG do renderowania wizualizacji za pomocą D3.js.

Pomyśl o SVG jak o płótnie, na którym możemy malować różne kształty. Na początek stwórzmy tag SVG -

<svg width = "500" height = "500"></<svg>

Domyślną miarą SVG są piksele, więc nie musimy określać, czy naszą jednostką jest piksel. Teraz, jeśli chcemy narysować prostokąt, możemy go narysować za pomocą poniższego kodu -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200"></rect>
</svg>

Możemy narysować inne kształty w SVG, takie jak - Linia, Okrąg, Elipsa, Tekst i Ścieżka.

Podobnie jak stylizowanie elementów HTML, stylizowanie elementów SVG jest proste. Ustawmy kolor tła prostokąta na żółty. W tym celu musimy dodać atrybut „fill” i określić wartość na żółto, jak pokazano poniżej -

<svg width = "500" height = "500">
   <rect x = "0" y = "0" width = "300" height = "200" fill = "yellow"></rect>
</svg>

JavaScript

JavaScript to luźno wpisany język skryptowy po stronie klienta, który jest wykonywany w przeglądarce użytkownika. JavaScript współdziała z elementami HTML (elementami DOM) w celu uczynienia internetowego interfejsu użytkownika interaktywnym. JavaScript implementujeECMAScript Standards, który obejmuje podstawowe funkcje oparte na specyfikacjach ECMA-262, a także inne funkcje, które nie są oparte na standardach ECMAScript. Znajomość JavaScript jest warunkiem koniecznym dla D3.js.