javascript - Choose file, set image and upload without blocking UI -
समस्या मैं निम्नलिखित चरणों को सफलतापूर्वक प्राप्त कर सकता हूं, लेकिन यूआई 2 एमबी या अधिक की फ़ाइलों के लिए अनुत्तरदायी हो सकता है ये फ़ाइलें उनके कैमरे या डेस्कटॉप से जो अपलोड हो सकती हैं, उनके आकार की सीमा में हैं, इसलिए मुझे उन्हें संभालना होगा। उपयोगकर्ता फ़ाइल को मानक फ़ाइल इनपुट HTML तत्व : क्लाइंट साइड पर मैं फ़ाइल का आकार बदलता हूं ताकि चौड़ाई 500 पिक्स या उससे कम हो (विशेष रूप से बड़ी फ़ाइलों के लिए छवि आकार को कम करने के लिए) और छवि दिखाएं। क्लाइंट साइड पर मैं रीसेट की गई छोटी फ़ाइल अपलोड कर रहा हूं I डेमो देखें। वहां आप देख सकते हैं कि बड़ी फ़ाइलों को अपलोड करते समय अवरुद्ध करने का कारण डेटा यूआरएल img src पर सेट है यह आवश्यक है ताकि छवि का कैनवास में पुनःआकार किया जा सके। जब आईएमजी कैनवास पर लिखा जाता है मैं मानता हूं विकल्प वेब वर्कर में अवरुद्ध क्रियाओं को करना। यह संभव नहीं है क्योंकि वेब वर्कर DOM तत्वों में हेरफेर नहीं कर सकते हैं और ब्लॉकिंग कॉल्स दोनों डोम को जोड़ते समय उत्पन्न करते हैं। एक वेब वर्कर में कच्चे छवि डेटा का आकार बदलना दुर्भाग्य से, मुझे नहीं पता है कि आईएमजी का प्रारूप इतना आकार बदल जाएगा कि सभी छवि प्रकारों को संभाल करने की आवश्यकता होगी। मैं किसी भी जावास्क्रिप्ट लाइब्रेरी से अवगत नहीं हूं जो यह करेंगे और मैं विशेष रूप से अपना क्रॉस-फ़ॉर्मेट छवि संपीड़न पुस्तकालय लिखना नहीं चाहता हूं। आईएमजी को सीधे रीसाइज़ करना, लेकिन यह अंतर्निहित डेटा आकार को नहीं बदलता है जिसे अपलोड करने की आवश्यकता है सर्वर पर साइज़िंग करना एक विकल्प नहीं है क्योंकि मैं अपलोड आकार को कम करना चाहता हूं। क्लाइंट पर रीसाइज करना भी बेहतर है चूंकि बड़ी छवि के लिए स्मृति जल्दी जारी की जाती है और पुनःआकारित छवि तुरंत प्रदर्शित होती है। अन्य विचार < / P> मुझे पता है कि img src सेट करना async है, इसलिए मुझे लगता है कि यह उस डेटा की प्रतिलिपि है जो अवरुद्ध कर रहा है। मुझे आश्चर्य है कि प्रतिलिपि बनाने के बजाय समान डेटा साझा करने का कोई तरीका है? मैं डेटा कोड प्राप्त करने के लिए मुझे क्या लगता है कि आप ऐसा करने की कोशिश कर रहे हैं आप जिस समस्या में चल रहे हैं, आप जावास्क्रिप्ट (ग्राहक) को उन चीजों को करने के लिए मजबूर कर रहे हैं जो सबसे ज्यादा संभवतः सर्वर साइड पर किया जाएगा छवि को कम संकल्प पर प्रदर्शित करने के लिए जो आसानी से उपयोग करके प्राप्त किया जा सकता है। क्लाइंट साइड पर उपयोगकर्ता को वास्तविक कम फ़ाइल तुरंत प्रदर्शित करने का कोई कारण नहीं है। यहां आपके उपयोग के प्रवाह का संस्करण है। मुझे उम्मीद है कि यह मदद करता है !!!
& lt; इनपुट वर्ग = "रद्द करें" प्रकार = "फ़ाइल" नाम = "userFile" id = "userFile" स्वीकार = "छवि / *" />
- चलती रोकता है फ़ायरफ़ॉक्स की तुलना में क्रोम में देरी अधिक महत्वपूर्ण दिखती है, लेकिन यह फ़ायरफ़ॉक्स पर अभी भी ध्यान देने योग्य है।
img.src = e.target.result; // यहाँ अवरुद्ध
ctx.drawImage (आईएमजी, 0, 0, चौड़ाई, ऊंचाई); // यहां अवरुद्ध करने के लिए < / Ol>
FileReader का उपयोग करने के लिए एक मानक दृष्टिकोण के रूप में विश्वास करता हूं, फिर डेटा कोड को
img.src और
canvas.drawImage आकार बदलने के लिए (इस के कई उदाहरण हैं, एक है)। इस दृष्टिकोण या किसी अन्य दृष्टिकोण की प्रतिक्रिया में सुधार करने में कोई सहायता की सराहना की जाएगी।
Comments
Post a Comment