首頁 > web前端 > js教程 > 為什麼在 D3.js 中使用 selectAll(null) 來追加元素?

為什麼在 D3.js 中使用 selectAll(null) 來追加元素?

Mary-Kate Olsen
發布: 2024-11-04 05:17:29
原創
518 人瀏覽過

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

選擇 null:為什麼在 D3 中使用 selectAll(null)?

背景

在D3 中,常常會看到這樣的模式:

var circles = svg.selectAll(null)
    .data(data)
    .enter()
    .append("circle");
登入後複製

這段程式碼將元素附加到DOM,但為什麼要用selectAll(null)呢?對於特定元素不應該是 selectAll("circle") 或 selectAll("p") 嗎?

回車選擇

D3.js 中「回車」選擇的說明:

將資料綁定到元素時,有三種情況:

  1. 元素和資料點數量相等。
  2. 元素數量多於數據點。
  3. 資料點多於元素。

在場景 #3 中,沒有對應元素的資料點屬於「輸入」選擇。在「輸入」選擇中使用追加會為不符的資料建立新元素。

綁定到現有元素

建議的程式碼片段 var Circles = svg.selectAll("circle").data(data ) 選擇資料並將其綁定到現有圈子。隨後的 Enter() 呼叫處理沒有符合元素的資料點。

使用selectAll(null)

雖然在不存在圓圈時使用selectAll("circle") 可以工作,但使用selectAll(null) 可以提供一致保證「輸入」選擇始終對應於資料數組中的元素。這種方法確保為所有不匹配的資料點附加新元素。

結論

下面的範例示範如何使用 selectAll(null) 將段落附加到正文:

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

以上是為什麼在 D3.js 中使用 selectAll(null) 來追加元素?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板