D3.js - चयन एपीआई
चयन दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) के शक्तिशाली डेटा-चालित परिवर्तन हैं। इसका उपयोग विशेषताएँ, शैलियाँ, गुण, HTML या पाठ सामग्री सेट करने के लिए किया जाता है और बहुत कुछ। यह अध्याय चयन एपीआई को विस्तार से बताता है।
एपीआई को कॉन्फ़िगर करना
आप नीचे दी गई स्क्रिप्ट का उपयोग करके सीधे एपीआई को कॉन्फ़िगर कर सकते हैं।
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script>
</script>
चयन एपीआई तरीके
चयन एपीआई में सबसे महत्वपूर्ण तरीके निम्नलिखित हैं।
- 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)
- चयन। लंबा (फ़ंक्शन [, तर्क ...])
- d3.local()
- स्थानीय .सेट (नोड, मान)
- 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 (चयनकर्ता)
इस विधि का उपयोग किसी तत्व का चयन करने के लिए किया जाता है। यह उन निर्दिष्ट तत्वों का चयन करता है जो निर्दिष्ट चयनकर्ता स्ट्रिंग से मेल खाते हैं। लौटे चयन में तत्वों को इस चयन में उनके संबंधित मूल नोड द्वारा वर्गीकृत किया गया है। यदि कोई तत्व वर्तमान तत्व के लिए निर्दिष्ट चयनकर्ता से मेल नहीं खाता है, या यदि चयनकर्ता शून्य है, तो वर्तमान सूचकांक में समूह खाली हो जाएगा।
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 (चयनकर्ता)
इस पद्धति का उपयोग निर्दिष्ट चयनकर्ता को निर्दिष्ट करने के लिए किया जाता है। यह एक फंक्शन लौटाता है, जो सच होता है।
Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।
var p = selection.filter(d3.matcher("p"));
d3.creator (नाम)
इस पद्धति का उपयोग निर्दिष्ट तत्व नाम को निर्दिष्ट करने के लिए किया जाता है यह एक फ़ंक्शन देता है, जो दिए गए नाम का एक तत्व बनाता है, यह मानते हुए कि यह मूल तत्व है।
Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।
selection.append(d3.creator("p"));
selection.each (समारोह)
इस विधि का उपयोग प्रत्येक चयनित तत्व के लिए निर्दिष्ट कार्य को वर्तमान डेटम (d), वर्तमान सूचकांक (i) और वर्तमान समूह (नोड्स) द्वारा वर्तमान DOM तत्व (नोड्स [i] के रूप में पारित करने के लिए किया जाता है। ])। इसे नीचे समझाया गया है।
parent.each(function(p, j) {
d3.select(this)
.selectAll(".child")
.text(function(d, i) { return "child " + d.name + " of " + p.name; });
});
चयन। लंबा (फ़ंक्शन [, तर्क ...])
इसका उपयोग निर्दिष्ट फ़ंक्शन को एक बार ठीक करने के लिए किया जाता है। वाक्य रचना नीचे दिखाया गया है।
function name(selection, first, last) {
selection.attr("first-name", first).attr("last-name", last);
}
इस विधि को नीचे दिखाए अनुसार निर्दिष्ट किया जा सकता है।
d3.selectAll("p").call(name, "Adam", "David");
d3.local ()
डी 3 स्थानीय आपको डेटा से स्वतंत्र स्थानीय स्थिति को परिभाषित करने की अनुमति देता है।
Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।
var data = d3.local();
वर् के विपरीत, प्रत्येक स्थानीय का मान भी DOM द्वारा स्कोप किया जाता है।
स्थानीय .सेट (नोड, मान)
यह विधि इस स्थानीय के मान को निर्दिष्ट नोड पर मान पर सेट करती है।
Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।
selection.each(function(d)
{ data.set(this, d.value); });
local.get(node)
यह विधि निर्दिष्ट नोड पर इस स्थानीय का मान लौटाती है। यदि नोड इस स्थानीय को परिभाषित नहीं करता है, तो यह निकटतम पूर्वज से मान लौटाता है जो इसे परिभाषित करता है।
local.remove (नोड)
यह विधि निर्दिष्ट नोड से इस स्थानीय मान को हटा देती है। यदि नोड परिभाषित किया गया है, तो यह सही है, अन्यथा गलत है।