में सिंक्रोनस की आवश्यकता है मैं वेबपैक का उपयोग कर रहा हूं और मैं कुछ पैकेजों को खींचने के लिए उपयोग कर रहा हूं। मेरे पास दो पैकेज हैं: package1.js और package2.js। package1.js बस कुछ गुणों के साथ एक वस्तु बनाता है जिसे pkg1
कहा जाता है। package2 एक जावास्क्रिप्ट फ़ाइल है जिसमें एक स्व निष्पादन कार्य होता है जो पैकेज 1 को बढ़ाता है। जैसेवेबपैक
package2.js:
require('package1')
require('package2')
जब मैं ऐसा करते हैं, मैं एक त्रुटि मिलती है:
!function() {
pkg1.prototype.newFunction = function {return "foo"};
}()
मैं निम्नलिखित तरीके से एक नई स्क्रिप्ट में इन दोनों की आवश्यकता के लिए कोशिश कर रहा हूँ:
Uncaught TypeError: pkg1.newFunction is not a function
मुझे लगता है कि इस Javascripts अतुल्यकालिक लोड हो रहा है की वजह से है: require(package2)
से पहले निष्पादित करता है। इस के लिए मेरे सबूत नहीं है कि जब मैं निम्नलिखित करना मैं एक त्रुटि नहीं मिलता है:
require('package1')
!function() {
pkg1.prototype.newFunction = function {return "foo"};
}()
बहरहाल, यह बहुत गंदा है, और मैं का उपयोग करने की आवश्यकता होती है चाहते हैं। मैं यह काम करने के बारे में कैसे जाऊं?
संपादित करें:,, इसलिए
(function() {
L.HexbinLayer = L.Class.extend({
...
})()
कम से कम मेरी समझ के लिए एक require(leaflet-d3-plugin)
में डाल इस स्क्रिप्ट निष्पादित और L
जो लाया जाता है का विस्तार करने के लिए पैदा करना चाहिए: विशिष्ट उदाहरण
leaflet-d3 plugin साथ शुरू होता है require('leaflet')
इसी प्रकार, d3-hexbin-v0 से शुरू होता है:
!function(){d3.hexbin=function(){
...
}}()
फिर से, जिस तरह से मैं इस पढ़ा है कि इस स्क्रिप्ट बस d3
करने के लिए एक .hexbin
विधि कहते है।
अब अगर मैं सिर्फ एचटीएमएल लिख रहे थे, मैं सिर्फ विभिन्न स्क्रिप्ट टैग में इन अलग अलग चीजें डाल और यह सिर्फ काम करता है:
<script src="http://d3js.org/d3.v3.min.js"></script>
<script src="http://d3js.org/d3.hexbin.v0.min.js"></script>
या
<script src="http://cdn.leafletjs.com/leaflet-0.7/leaflet.js"></script>
<script src="static/leaflet-d3.min.js" charset="utf-8"></script>
लेकिन चूंकि मैं उपयोग कर रहा हूँ webpack , मुझे केवल इन पुस्तकालयों को एनपीएम के साथ स्थापित करने के बाद इन पुस्तकालयों की आवश्यकता और/या आयात करने में सक्षम होना चाहिए या यदि मैं इन स्क्रिप्ट में .js को कुछ निर्देशिका में कॉपी करता हूं और फिर require
उन्हें उस स्थान से कॉपी करता हूं। दुर्भाग्यवश, यह तब तक काम नहीं कर रहा है जब तक कि मैं इन मॉड्यूल में .js को सीधे जो भी स्क्रिप्ट लिख रहा हूं उसे कॉपी नहीं करता। यही वह है जिसे मैं टालने की कोशिश कर रहा हूं।
उदा।
import * as d3 from 'd3'; \\I'm using d3 v4 here.
require('/resources/d3-hexbin.min.js')
परिणामों में:
Uncaught TypeError: d3.hexbin is not a function
* "package1.js बस 'pkg1'' नामक कुछ गुणों के साथ एक ऑब्जेक्ट बनाता है * ठीक है। लेकिन ** परिवर्तनीय ** 'pkg1' कहां से आना चाहिए? * "मुझे एक त्रुटि मिलती है: 'Uncaught TypeError: pkg1.newFunction एक फ़ंक्शन नहीं है' * * आमतौर पर ऐसा होता है जब आप ** ** कॉल करने की कोशिश कर रहे हैं जो एक फ़ंक्शन नहीं है। आप 'pkg1.newFunction' को कॉल करने का प्रयास कहां कर रहे हैं? ऐसा लगता है कि आपका उदाहरण काफी अपूर्ण है, जिससे आपकी मदद करना मुश्किल हो जाता है। कृपया [mcve] पढ़ें। –
'आवश्यकता()' कॉल वास्तव में ब्राउज़र में निष्पादित नहीं की जाती हैं। कोई ब्राउज़र आवश्यकता का समर्थन करता है। वेबपैक एक "बंडल" जावास्क्रिप्ट फ़ाइल बनाता है जिसमें ब्राउज़र संगत होने के लिए सेट अप कोड होता है। आगे पढ़ने: http://blog.andrewray.me/webpack-when-to-use-and-why/ –
आपकी प्रतिक्रिया के लिए @ फ़ेलिक्सक्लिंग धन्यवाद। मुझे नहीं पता कि यह मेरी पूरी वेबपैक परियोजना प्रदान किए बिना यह सत्यापित करने के लिए कैसे है, और मुझे नहीं लगता कि कोई भी इसके माध्यम से जाना चाहता है। मैंने कुछ ठोस उदाहरणों के साथ प्रश्न का विस्तार किया है। उम्मीद है कि वे इसे कम करने में मदद करते हैं। – Logister