माइक के पास डी 3 में reusable components लिखने के बारे में एक उत्कृष्ट लेख है। लेख घटकों को कॉन्फ़िगर करने योग्य बनाने के तरीके और चयन में घटक को कैसे लागू करें के पैटर्न का वर्णन करता है।एक एपीआई के साथ डी 3 में पुन: प्रयोज्य घटक कैसे बनाएं जो घटक के प्रत्येक उदाहरण में हेरफेर करता है?
पैटर्न एक घटक घटक को डेटा में शामिल करके कई चयनों के साथ पुन: उपयोग करने की अनुमति देता है; जैसे
var chart = myChart();
d3.select("div.chart")
.data(data)
.call(chart);
मेरे घटक कार्यान्वयन ऐसा दिखाई देता है:
function myChart() {
function my(selection) {
selection.each(function(d, i) {
// generate chart here
// `d` is the data, `i` is the index, `this` is the element
var state = false;
var circle = d3.select(this).append("circle")
.attr("r", "10")
.style("fill", "#000")
.on("click", toggleState);
function toggleState() {
// this function updates the current instance trapped by this closure
(state = !state)
? circle.style("fill", "#fff")
: circle.style("fill", "#000");
}
});
}
my.toggleState(i) {
// How do I access the `i`th instance of the component here?
}
return my;
}
क्या मैं प्राप्त करने के लिए चाहते हैं फोन करने वाले इस घटक अपने सूचकांक दिया की एक आवृत्ति हेरफेर करने की अनुमति है। उदाहरण के लिए, यदि चयनकर्ता div.chart
उपरोक्त एक चयन देता है जिसमें दो तत्व हैं, तो मैं chart.toggleState(1)
पर कॉल करना चाहता हूं और इसे चयन में दूसरा div अपडेट करना चाहता हूं।
बस इसलिए मैं किसी को भ्रमित नहीं करता हूं कि मैं ऐसा करने का प्रयास क्यों कर रहा हूं, कॉलर को दो प्रकार के घटकों को एक साथ सिंक्रनाइज़ करने की आवश्यकता है। कल्पना कीजिए कि मेरे पास एक घटक है जो एक सर्कल और दूसरे घटक द्वारा दर्शाया गया है जो आयताकार द्वारा दर्शाया जाता है। दो घटक स्वतंत्र होना चाहिए और एक दूसरे से बंधे नहीं होना चाहिए। मुझे 4 मंडल और 4 आयताकार बनाने में सक्षम होना चाहिए, और जब मैं एक आयत पर क्लिक करता हूं, तो मैं इंडेक्स ऑर्डर के आधार पर संबंधित सर्कल को अपडेट करने में सक्षम होना चाहता हूं। मैंने पहले से ही यह पता लगाया है कि किसी घटक से ईवेंट (d3.dispatch) कैसे बढ़ाएं और वर्तमान इंडेक्स को ईवेंट में पैरामीटर के रूप में प्रदान करें, लेकिन मुझे पता नहीं लगा है कि इसके सूचकांक को दिए गए घटक के विशिष्ट उदाहरण में कैसे कॉल किया जाए।
ऐसा लगता है कि ऐसा करने का तरीका केवल उस तत्व का चयन करना होगा जिसे आपको अपडेट करने की आवश्यकता है और फिर घटक को कॉल करें। कुछ भी इस घटक पैटर्न के माध्यम से प्राप्त encapsulation का उल्लंघन करेगा। –
मैंने हाल ही में माइक लेख के आधार पर ओपन सोर्स पुन: प्रयोज्य घटक पर काम पूरा कर लिया है। https://timebandit.github.io/graphSub – timebandit