कोड स्प्लिट करने और स्मार्ट लोडिंग की रणनीतियों की मदद से, Next.js ऐप्लिकेशन को तेज़ी से लोड करने का तरीका.
आप क्या सीखेंगे?
इस पोस्ट में कोड के अलग-अलग टाइप के बारे में बताया गया है बांटें और कैसे इस्तेमाल करें डाइनैमिक इंपोर्ट की सुविधा का इस्तेमाल करती हैं.
रूट और कॉम्पोनेंट के आधार पर कोड का बंटवारा
डिफ़ॉल्ट रूप से, Next.js हर रूट के लिए आपकी JavaScript को अलग-अलग हिस्सों में बांट देता है. जब उपयोगकर्ता आपका ऐप्लिकेशन लोड करते हैं, तो Next.js सिर्फ़ वही कोड भेजता है जो शुरुआती रास्ता. जब उपयोगकर्ता किसी ऐप्लिकेशन पर नेविगेट करते हैं, तो वे हिस्से फ़ेच करते हैं दूसरे रास्तों से जुड़े होते हैं. रूट के आधार पर कोड को बांटने की सुविधा, स्क्रिप्ट की संख्या जिसे एक साथ पार्स और कंपाइल करने की ज़रूरत होती है, जिससे पेज लोड होने की अवधि कम हो जाती है.
वैसे तो रूट के आधार पर कोड का बंटवारा करना एक अच्छा डिफ़ॉल्ट तरीका है, लेकिन आप कॉम्पोनेंट लेवल पर कोड को बांटने की प्रोसेस के साथ लोड होने की प्रोसेस. अगर आपके पास कॉम्पोनेंट को अलग-अलग हिस्सों में बांटना चाहिए. इस तरह, ऐसे कोई भी बड़े कॉम्पोनेंट जो ज़रूरी नहीं हैं या सिर्फ़ कुछ खास कॉम्पोनेंट पर ही रेंडर होते हैं उपयोगकर्ता के इंटरैक्शन (जैसे, बटन पर क्लिक करना) लेज़ी लोड हो सकते हैं.
Next.js, डाइनैमिक import()
के साथ काम करता है,
इसकी मदद से, JavaScript मॉड्यूल इंपोर्ट किए जा सकते हैं. इन मॉड्यूल में, React के कॉम्पोनेंट भी शामिल हैं.
साथ ही, हर इंपोर्ट को एक अलग डेटा ग्रुप के तौर पर लोड करें. इससे आपको
यह कॉम्पोनेंट लेवल पर कोड को बांटना होता है. इससे रिसॉर्स लोड होने की प्रोसेस को कंट्रोल किया जा सकता है
कि उपयोगकर्ता सिर्फ़ उस साइट के लिए कोड डाउनलोड करें जिसकी उन्हें ज़रूरत है
वे देख रहे हैं. Next.js में ये कॉम्पोनेंट सर्वर-साइड रेंडर किए जाते हैं
(SSR)
डिफ़ॉल्ट रूप से.
डाइनैमिक इंपोर्ट का इस्तेमाल
इस पोस्ट में एक नमूना ऐप्लिकेशन के कई वर्शन शामिल हैं, जिसमें एक आसान वाला एक बटन है. बटन पर क्लिक करने पर, आपको एक प्यारा सा पपी दिखेगा. जैसे ऐप के हर वर्शन पर जाने पर, आपको डाइनैमिक इंपोर्ट की जानकारी दिखेगी यह स्टैटिक वैल्यू से अलग है इंपोर्ट साथ ही, उनके साथ काम करने का तरीका भी बताया गया है.
ऐप्लिकेशन के पहले वर्शन में बताया गया है कि पिल्ला components/Puppy.js
में रहता है. यहां की यात्रा पर हूं
पेज पर पपी दिखाएं, तो ऐप्लिकेशन Puppy
कॉम्पोनेंट को
स्टैटिक इंपोर्ट स्टेटमेंट के साथ index.js
:
import Puppy from "../components/Puppy";
यह देखने के लिए कि Next.js ऐप्लिकेशन को कैसे बंडल करता है, DevTools में नेटवर्क ट्रेस की जांच करें:
साइट की झलक देखने के लिए, ऐप्लिकेशन देखें दबाएं. इसके बाद, फ़ुलस्क्रीन
.
DevTools खोलने के लिए, `Control+Shift+J` (या Mac पर `Command+Option+J`) दबाएं.
नेटवर्क टैब पर क्लिक करें.
कैश मेमोरी बंद करें चेकबॉक्स चुनें.
पेज को फिर से लोड करें.
पेज लोड करने पर, सभी ज़रूरी कोड, जिनमें Puppy.js
भी शामिल है
इस कॉम्पोनेंट को index.js
में बंडल किया गया है:
![DevTools नेटवर्क टैब में छह JavaScript फ़ाइलें दिख रही हैं: index.js, app.js, webpack.js, Main.js, 0.js, और dll (डाइनैमिक लिंक लाइब्रेरी) फ़ाइल.](https://web.dev/static/articles/code-splitting-with-dynamic-imports-in-nextjs/image/devtools-network-tab-show-c3449cc648185.png?authuser=0&hl=hi)
जब आप क्लिक करें बटन दबाते हैं, तो केवल पिल्ले के लिए JPEG अनुरोध ही होता है को नेटवर्क टैब में जोड़ा गया:
![बटन पर क्लिक करने के बाद, DevTools नेटवर्क टैब में, वही छह JavaScript फ़ाइलें और एक इमेज दिख रही है.](https://web.dev/static/articles/code-splitting-with-dynamic-imports-in-nextjs/image/devtools-network-tab-the-94b209c5e4e56.png?authuser=0&hl=hi)
इस तरीके का नकारात्मक पहलू यह है कि भले ही उपयोगकर्ता
पिल्ले को देखें, तो उन्हें Puppy
कॉम्पोनेंट लोड करना होगा, क्योंकि यह कॉम्पोनेंट में शामिल है
index.js
. इस छोटे से उदाहरण में, यह कोई बड़ी बात नहीं है, लेकिन असल दुनिया में यह कोई बड़ी बात नहीं है
बड़े कॉम्पोनेंट को लोड करना बहुत ज़्यादा खास होता है. हालांकि, ऐसा सिर्फ़ तब होता है, जब
ज़रूरी है.
अब ऐप्लिकेशन का दूसरा वर्शन देखें, जिसमें स्टैटिक इंपोर्ट
को डाइनैमिक इंपोर्ट से बदला गया. Next.js में next/dynamic
शामिल है, जो इसे
अगले पेज में किसी भी कॉम्पोनेंट के लिए डाइनैमिक इंपोर्ट का इस्तेमाल किया जा सकता है:
import Puppy from "../components/Puppy";
import dynamic from "next/dynamic";
// ...
const Puppy = dynamic(import("../components/Puppy"));
नेटवर्क ट्रेस की जांच करने के लिए, पहले उदाहरण में दिए गए निर्देशों का पालन करें.
जब पहली बार ऐप्लिकेशन लोड किया जाता है, तो सिर्फ़ index.js
डाउनलोड होता है. इस बार ऐसा है
0.5 केबी छोटी है (यह 37.9 केबी से घटकर 37.4 केबी हो गई है) क्योंकि यह
में Puppy
कॉम्पोनेंट का कोड शामिल नहीं होता:
![DevTools नेटवर्क वही छह JavaScript फ़ाइलें दिखा रहा है, लेकिन index.js अब 0.5 केबी छोटी हो गई है.](https://web.dev/static/articles/code-splitting-with-dynamic-imports-in-nextjs/image/devtools-network-showing-8cbd4309d29c5.png?authuser=0&hl=hi)
Puppy
कॉम्पोनेंट अब एक अलग हिस्से 1.js
में है, जिसे सिर्फ़ लोड किया जाता है
जब आप बटन दबाते हैं:
![बटन पर क्लिक करने के बाद, DevTools नेटवर्क टैब में, 1.js फ़ाइल दिखती है. साथ ही, फ़ाइल की सूची के नीचे जोड़ी गई इमेज भी दिखती है.](https://web.dev/static/articles/code-splitting-with-dynamic-imports-in-nextjs/image/devtools-network-tab-the-e42cc1846b47f.png?authuser=0&hl=hi)
असल दुनिया में इस्तेमाल होने वाले कॉम्पोनेंट में, अक्सर काफ़ी कॉम्पोनेंट बड़ा हो और उन्हें लेज़ी लोड न हो आपके शुरुआती JavaScript पेलोड को सैकड़ों किलोबाइट तक कम कर सकता है.
कस्टम लोडिंग इंडिकेटर के साथ डाइनैमिक इंपोर्ट
जब रिसॉर्स को लेज़ी-लोड किया जाता है, तो लोड होने की जानकारी देने वाला इंडिकेटर देना बेहतर होता है
देरी हो सकती है. Next.js में, ऐसा करने के लिए
dynamic()
फ़ंक्शन का अतिरिक्त आर्ग्युमेंट:
const Puppy = dynamic(() => import("../components/Puppy"), {
loading: () => <p>Loading...</p>
});
लोड होने वाले इंडिकेटर को देखने के लिए, DevTools:
साइट की झलक देखने के लिए, ऐप्लिकेशन देखें दबाएं. इसके बाद, फ़ुलस्क्रीन
.
DevTools खोलने के लिए, `Control+Shift+J` (या Mac पर `Command+Option+J`) दबाएं.
नेटवर्क टैब पर क्लिक करें.
कैश मेमोरी बंद करें चेकबॉक्स चुनें.
थ्रॉटलिंग ड्रॉप-डाउन सूची में से, फ़ास्ट 3G चुनें.
मुझे क्लिक करें बटन दबाएं.
अब इस बटन पर क्लिक करने से, कॉम्पोनेंट और ऐप्लिकेशन को लोड होने में कुछ समय लगता है "लोड हो रहा है..." दिखाता है इस दौरान आपका मैसेज दिख रहा है.
![टेक्स्ट वाली गहरे रंग की स्क्रीन](https://web.dev/static/articles/code-splitting-with-dynamic-imports-in-nextjs/image/a-dark-screen-the-text-914039a8f2589.png?authuser=0&hl=hi)
एसएसआर के बिना डाइनैमिक इंपोर्ट
अगर आपको किसी कॉम्पोनेंट को सिर्फ़ क्लाइंट साइड पर रेंडर करना है (उदाहरण के लिए, चैट
विजेट) से कोई फ़र्क़ नहीं पड़ता है, तो ssr
विकल्प को false
पर सेट करके ऐसा किया जा सकता है:
const Puppy = dynamic(() => import("../components/Puppy"), {
ssr: false,
});
नतीजा
डाइनैमिक इंपोर्ट के साथ काम करने से, Next.js आपको कॉम्पोनेंट-लेवल का कोड देता है अलग-अलग हिस्सों में बांटें. इससे आपके JavaScript पेलोड को कम किया जा सकता है और ऐप्लिकेशन को बेहतर बनाया जा सकता है लोड होने में लगने वाला समय तय करें. सभी कॉम्पोनेंट, डिफ़ॉल्ट रूप से सर्वर साइड पर रेंडर होते हैं. इस विकल्प को ज़रूरत पड़ने पर बंद कर दें.