में JSON डेटा का उपयोग करना मैं जावास्क्रिप्ट डी 3 विज़ुअलाइजेशन टूल (http://mbostock.github.com/d3/) के साथ किए गए कुछ चार्ट ड्राइव करने के लिए JSON डेटा के उपयोग के माध्यम से काम कर रहा हूं। मैं सेटअप मेरे WCF सेवा है, और jQuery में इस कोड को ठीक काम करता है:डी 3 जावास्क्रिप्ट विज़ुअलाइजेशन
$('#getDataItems').click(function() {
var $DataList = $('#DataList');
$DataList.empty().appendLi('Loading...');
// Get the JsonP data
$.getJSON('http://localhost:65025/CustomersService.svc/GetMyDataItems?callback=?', null, function (somedata) {
alert('Received ' + somedata.length + ' Items');
$DataList.empty();
$.each(somedata, function() {
$DataList.appendLi(this.ID + " - " + this.Value);
}); // end each dataitem function
}); // end success function
}); // end #getDataItems.click
डी 3 भी JSON डेटा का उपयोग कर के लिए एक समारोह है, लेकिन मैं अभी तक सफलता मिली नहीं किया है। यह इस तरह दिखता है:
// this works
//var data = [4, 8, 15, 16, 23, 42];
// this doesn't
var data = function() {
d3.json('http://localhost:65025/CustomersService.svc/GetMyDataItems?callback=?',
function (data) } })
}
//.. rest of the example is known working code so its here only for reference
// create the chart class as an append to the body element.
var chart = d3.select("body")
.append("svg:svg")
.attr("class", "chart")
.attr("width", 420)
.attr("height", 20 * data.length);
// Set the width relative to max data value
var x = d3.scale.linear()
.domain([0, d3.max(data)])
.range([0, 420]);
var y = d3.scale.ordinal()
.domain(data)
.rangeBands([0, 120]);
chart.selectAll("rect")
.data(data)
.enter().append("svg:rect")
.attr("y", y)
.attr("width", x)
.attr("height", y.rangeBand());
chart.selectAll("text")
.data(data)
.enter().append("svg:text")
.attr("x", x)
.attr("y", function (d) { return y(d) + y.rangeBand()/2; })
.attr("dx", -3) // padding-right
.attr("dy", ".35em") // vertical-align: middle
.attr("text-anchor", "end") // text-align: right
.text(String);
सुंदर बहुत सारे कोड डी 3 डाउनलोड, जो ठीक काम करता है में 'बार चार्ट' उदाहरण से है। यदि मैं मैन्युअल रूप से डेटा घोषित करता हूं (उपरोक्त पूर्णांक की सरणी के अनुसार) यह काम करता है, लेकिन JSON कमांड के साथ नहीं। मैंने लौटाए गए डेटा को भी सरल बनाया ताकि इसमें केवल पूर्णांक शामिल हो। आखिरकार, मैं एक 'आईडी फ़ील्ड', 'वैल्यू फ़ील्ड' आदि के साथ JSON डेटा तक पहुंचने में सक्षम होना चाहता हूं और इन्हें कोड में संदर्भित करना चाहता हूं।
किसी के पास कोई विचार है कि मेरा वाक्यविन्यास गलत है या नहीं? मुझे एहसास है कि फ़ंक्शन (डेटा) का उपयोग चार्ट में डेटा जोड़ने के लिए किया जाना है, लेकिन इस उदाहरण में कोड काम करता है इसलिए मैं उस बिंदु से शुरू करना पसंद करूंगा।
हाय! उसके लिए धन्यवाद। अगर मैं jquery संस्करण (पहले स्निपेट में) का उपयोग करना चाहता था, तो 'somedata' चर के साथ समाप्त होता है - मैं 'var data = [1, 2, 3] के समान सरणी में मान कैसे प्राप्त करूं? ऐसा हो सकता है कि JSON में दो फ़ील्ड प्रति 'रिकॉर्ड' - नाम और मान शामिल हैं। तो मैं प्लॉट को पूरा करने के लिए JSON मानों को 'डेटा' के समान स्वरूप में कैसे डालूं? क्षमा करें, मुझे आशा है कि यह समझ में आता है, मैं इसे समझाने के लिए संघर्ष कर रहा हूं! :) – Glinkot
यदि आपकी वेब सेवा '[1, 2, 3]' जैसी कुछ लौट रही है, तो आपके पास उस जानकारी को 'डेटा' वैरिएबल में उस तरह होना चाहिए। फ़ायरबग और 'console.log (डेटा) 'का उपयोग करें ताकि आप यह देख सकें कि आप क्या प्राप्त कर रहे हैं। – rmarimon
आपके jquery उदाहरण से डेटा को 'आईडी' और 'वैल्यू' जोड़ी के रूप में पुनर्प्राप्त किया जा रहा है। मैंने जवाब को अद्यतन किया है कि इस डेटा को कैसे प्राप्त किया जाए। – rmarimon