मैं वर्तमान में एक समस्या का काम कर रहा हूं जिसके लिए मेरे वेब एप्लिकेशन को एक चार्ट उत्पन्न करने की आवश्यकता है जो डेटा के लगभग 50k से 60k अंक का प्रतिनिधित्व करता है। यह काफी तेज़ी से लोड होता है (~ 6 सेकंड), लेकिन मैं क्या सोच रहा हूं कि वेब वर्कर में आलेख उत्पन्न करने के लिए D3.js का उपयोग करना संभव है और फिर पृष्ठ में लोड होने के लिए एसवीजी को वापस पास करना संभव है।वेब वर्कर और D3.js का उपयोग अतुल्यकालिक रूप से ग्राफ उत्पन्न करने के लिए करें?
उत्तर
वेब श्रमिकों के पास कोई डोम एक्सेस नहीं है, इसलिए आप उस तरफ से ऐसा कुछ भी कर सकते हैं जिसका उपयोग जल्दी से डीओएम बनाने के लिए किया जा सके। कार्यकर्ता (उदाहरण) डेटासेट को संसाधित कर सकता है और सभी भारी गणना कर सकता है, फिर परिणाम को वापस सरणी के सेट के रूप में पास कर सकता है।
https://github.com/mbostock/d3/commit/43d38773623b52209d2667287a1ae626fb95b0d9
हाल ही में एक जेसन डेविस द्वारा प्रतिबद्ध। माइक Bostock का कहना है कि भविष्य में डीओएम आश्रित कोड d3.core से अलग किया जाएगा और इस तरह आप कस्टम डी 3 बिल्ड कर सकते हैं जो वेब-वर्कर्स एपीआई के साथ काम करता है।
मुझे वही समस्या थी जहां मेरे पास बड़ी संख्या में नोड्स के साथ एक बल निर्देशित ग्राफ़ था। यह बहुत आलसी लगता है। मैं किसी भी तरह से प्रदर्शन में सुधार करना चाहता हूं। मुझे लगता है कि एक नोड सर्वर पर phantomJS के साथ अंतिम धागा एक अच्छा विचार है, लेकिन दृष्टिकोण में शामिल नेटवर्क विलंबता चिकनी बल निर्देशित भावना को बर्बाद कर देगा। निम्नलिखित
तो आप वर्च निर्भरताओं के बिना पट्टी डी 3 कहां पाते हैं? –
मैं ऐसा करके एक वेब कार्यकर्ता का उपयोग कर chords और एक तार लेआउट के समूहों की गणना करने में कामयाब रहे:
कि दस्तावेज़ वस्तु पर एक निर्भरता नहीं है डी 3 की एक कस्टम निर्माण बना सकते हैं या डोम (देखें: https://github.com/mbostock/smash/wiki)
एक वेब कार्यकर्ता फ़ाइल बनाने और
importScripts
का उपयोग कस्टम निर्माण d3अपने प्रतिपादन कोड में अपने कार्यकर्ता को सक्रिय लोड करने के लिए।
calculateChords = (padding, matrix) -> deferred = $.Deferred() worker = new Worker("worker.js") worker.onmessage = (e) -> deferred.resolve(e.data.groups, e.data.chords); worker.postMessage { matrix: matrix } deferred.promise()
बाद में, प्रतिपादन समारोह में:: मैं कार्यकर्ता के साथ संचार संपुटित करने के लिए एक वादा इस्तेमाल किया
calculateChords(matrix).then (groups, chords) -> ...
यदि आप डी 3 को अपने बूटिंग के रूप में प्ले करने के लिए आस-पास झूठ बोलने वाले दाएं (नकली) ऑब्जेक्ट्स छोड़ते हैं तो आप वास्तव में एक वेब वर्कर में मानक डी 3 चला सकते हैं। हालांकि मुख्य समस्या (वेब श्रमिकों के साथ डी 3 का उपयोग करने में) संदेश भेजने और प्राप्त करने में धारावाहिक उपरि है। मुझे यह जानने में बहुत दिलचस्पी होगी कि क्या कोई भी धारावाहिकता को कम करने के लिए हस्तांतरणीय वस्तुओं का उपयोग करने के लिए एक अच्छी विधि के साथ आया है। –
- 1. d3.js ग्राफ आउटपुट?
- 2. d3.js
- 3. d3.js और svgs
- 4. d3.js
- 5. d3.js और document.onReady
- 6. D3.js
- 7. d3.js
- 8. d3.js
- 9. श्रेणीबद्ध बल D3.js
- 10. d3.js
- 11. d3.js d3.geo.path
- 12. D3.js
- 13. D3.js
- 14. $ d3.js
- 15. d3.js
- 16. d3.js
- 17. d3.js
- 18. स्केलिंग d3.js अनुमानों
- 19. d3.js
- 20. d3.js - ट्रांसफॉर्म और संक्रमण, एकाधिक लाइन
- 21. का मेल जनक और d3.js
- 22. d3.js कैनवास को
- 23. d3.js: जब मैन्युअल रूप से बल लेआउट
- 24. डेटाबेस से बाह्य डेटा को गतिशील रूप से d3.js
- 25. d3.js अक्ष कार्यक्षमता
- 26. बल-निर्देशित ग्राफ के लिए D3.js क्या एल्गोरिदम उपयोग करता है?
- 27. एक "slopegraph" d3.js
- 28. d3.js और nvd3.js अक्ष और लेबल परिशुद्धता स्वरूपण
- 29. केवल d3.js
- 30. d3.js select.text() विधि
धन्यवाद। मुझे डर था कि यह जवाब होगा। – user1449496
यह पहले से ही एक पुराना सवाल है, लेकिन .... phantomJS के बारे में क्या? – meetamit
@meetamit जो मुझे लगता है कि एक विकल्प हो सकता है, सर्वर पर DOM उत्पन्न phantomJS के साथ उत्पन्न करें और फिर इसे क्लाइंट को पास करें? लेकिन यह वेब श्रमिकों का उपयोग नहीं कर रहा है, जो सवाल था। –