मैंने एक डी 3 प्रतीकात्मक मानचित्र बनाया है और उपयोगकर्ता को 'टाइप' नामक एक विशेषता द्वारा अंक फ़िल्टर करने में सक्षम होना चाहिए। तीन प्रकार हैं: ए, बी, सी, जिनमें से प्रत्येक में एक संबंधित एचटीएमएल चेकबॉक्स है, जब चेक किया जाता है तो टाइप के बिंदु प्रदर्शित करना चाहिए, और जब अन-चेक किया गया तो उन बिंदुओं को हटा देना चाहिए। मैं सोच रहा था कि चेक/अनचेक घटना को डी 3 में पास करने का सबसे अच्छा तरीका क्या है? मैं सोच रहा हूं कि चेक किए गए प्रकारों को select.filter() में पास करने का कोई तरीका था, तो यह जाने का सबसे अच्छा तरीका होगा।d3 मानचित्र चेकबॉक्स फ़िल्टरिंग
एचटीएमएल
<div class="filter_options">
<input class="filter_button" id="a_button" type="checkbox">a</input><br>
<input class="filter_button" id="b_button" type="checkbox">b</input><br>
<input class="filter_button" id="c_button" type="checkbox">c</input><br>
</div>
js
queue()
.defer(d3.json, "basemap.json")
.defer(d3.json, "points.json")
.await(ready);
function ready(error, base, points) {
var button =
svg.append("path")
.attr("class", "polys")
.datum(topojson.object(us, base.objects.polys))
.attr("d", path);
svg.selectAll(".symbol")
.data(points.features)
.enter().append("path")
.filter(function(d) { return d.properties.type != null ? this : null; })
.attr("class", "symbol")
.attr("d", path.pointRadius(function(d) { return radius(d.properties.frequency * 50000); }))
.style("fill", function(d) { return color(d.properties.type); });;
वर्तमान में, फिल्टर सभी बिंदुओं को पकड़ने के लिए सेट कर दिया जाता:
.filter(function(d) { return d.properties.type != null ? this : null; })
मैं उपयोगकर्ता चाहते हैं होने के लिए यहाँ कोड है इसे बदलने में सक्षम
चीयर्स
अद्भुत। धन्यवाद। बक्से की जांच होने पर आकर्षण की तरह काम करता है, लेकिन अनचेकिंग अंक को नहीं हटाती है। इस पर कोई विचार क्यों होगा? – rysloan
जीवन बचतकर्ता। धन्यवाद। – rysloan
निश्चित बात। क्या आप काम करने के लिए अनचेक हो गए थे? –