तेज़ी से पेज लोड करने के लिए, मॉडर्न ब्राउज़र पर मॉडर्न कोड इस्तेमाल करें

इस कोडलैब में, इस सामान्य ऐप्लिकेशन की परफ़ॉर्मेंस को बेहतर बनाएं. इस ऐप्लिकेशन की मदद से, लोग अलग-अलग बिल्लियों को रेटिंग दे सकते हैं. ट्रांसपाइल किए गए कोड की मात्रा को कम करके, JavaScript बंडल को ऑप्टिमाइज़ करने का तरीका जानें.

ऐप्लिकेशन का स्क्रीनशॉट

सैंपल ऐप्लिकेशन में, किसी शब्द या इमोजी को चुनकर यह बताया जा सकता है कि आपको हर बिल्ली कितनी पसंद है. किसी बटन पर क्लिक करने पर, ऐप्लिकेशन, बिल्ली की मौजूदा इमेज के नीचे बटन की वैल्यू दिखाता है.

मापें

किसी भी तरह का ऑप्टिमाइज़ेशन जोड़ने से पहले, वेबसाइट की जांच करना हमेशा एक अच्छा तरीका होता है:

  1. साइट की झलक देखने के लिए, ऐप्लिकेशन देखें दबाएं. इसके बाद, फ़ुलस्क्रीन फ़ुलस्क्रीन दबाएं.
  2. DevTools खोलने के लिए, `Control+Shift+J` (या Mac पर `Command+Option+J`) दबाएं.
  3. नेटवर्क टैब पर क्लिक करें.
  4. कैश मेमोरी बंद करें चेकबॉक्स को चुनें.
  5. ऐप्लिकेशन को फिर से लोड करें.

बंडल के मूल साइज़ का अनुरोध

इस ऐप्लिकेशन के लिए 80 केबी से ज़्यादा जगह का इस्तेमाल किया गया है! यह पता लगाएं कि बंडल के कुछ हिस्सों का इस्तेमाल नहीं किया जा रहा है या नहीं:

  1. कमांड मेन्यू खोलने के लिए, Control+Shift+P (या Mac पर Command+Shift+P) दबाएं. कमांड मेन्यू

  2. Show Coverage डालें और Enter दबाकर कवरेज टैब दिखाएं.

  3. कवरेज टैब में, कवरेज कैप्चर करते समय ऐप्लिकेशन को फिर से लोड करने के लिए, फिर से लोड करें पर क्लिक करें.

    कोड कवरेज के साथ ऐप्लिकेशन को फिर से लोड करें

  4. देखें कि मुख्य बंडल के लिए, कितना कोड इस्तेमाल किया गया और कितना कोड लोड किया गया:

    बंडल का कोड कवरेज

बंडल का आधा हिस्सा (44 केबी) भी इस्तेमाल नहीं किया गया है. ऐसा इसलिए है, क्योंकि इसमें मौजूद ज़्यादातर कोड में पॉलीफ़िल शामिल होते हैं. इससे यह पक्का किया जाता है कि ऐप्लिकेशन पुराने ब्राउज़र में काम करे.

@babel/preset-env का इस्तेमाल करना

JavaScript भाषा का सिंटैक्स, ECMAScript या ECMA-262 के नाम से जाने जाने वाले स्टैंडर्ड के मुताबिक होता है. हर साल, स्पेसिफ़िकेशन के नए वर्शन रिलीज़ किए जाते हैं. इनमें नई सुविधाएं शामिल होती हैं. ये सुविधाएं, प्रस्ताव की प्रोसेस को पूरा कर चुकी होती हैं. हर मुख्य ब्राउज़र, इन सुविधाओं को अलग-अलग चरणों में सपोर्ट करता है.

इस ऐप्लिकेशन में ES2015 की इन सुविधाओं का इस्तेमाल किया गया है:

ES2017 की इस सुविधा का भी इस्तेमाल किया जाता है:

src/index.js में जाकर सोर्स कोड देखें और जानें कि इन सभी का इस्तेमाल कैसे किया जाता है.

ये सभी सुविधाएं, Chrome के नए वर्शन में काम करती हैं. हालांकि, उन ब्राउज़र का क्या होगा जिनमें ये सुविधाएं काम नहीं करती हैं? Babel, ऐप्लिकेशन में शामिल सबसे लोकप्रिय लाइब्रेरी है. इसका इस्तेमाल, नए सिंटैक्स वाले कोड को ऐसे कोड में कंपाइल करने के लिए किया जाता है जिसे पुराने ब्राउज़र और एनवायरमेंट समझ सकें. यह दो तरीकों से ऐसा करता है:

  • Polyfills को ES2015+ के नए फ़ंक्शन की नकल करने के लिए शामिल किया जाता है, ताकि उनके एपीआई का इस्तेमाल तब भी किया जा सके, जब ब्राउज़र उन्हें सपोर्ट न करता हो. यहां Array.includes तरीके के पॉलीफ़िल का एक उदाहरण दिया गया है.
  • प्लगिन का इस्तेमाल, ES2015 कोड (या बाद के वर्शन) को पुराने ES5 सिंटैक्स में बदलने के लिए किया जाता है. ये सिंटैक्स से जुड़े बदलाव हैं. जैसे, ऐरो फ़ंक्शन. इसलिए, इन्हें पॉलीफ़िल के साथ नहीं बदला जा सकता.

यह देखने के लिए कि Babel की कौनसी लाइब्रेरी शामिल हैं, package.json पर जाएं:

"dependencies": {
  "@babel/polyfill": "^7.0.0"
},
"devDependencies": {
  //...
  "babel-loader": "^8.0.2",
  "@babel/core": "^7.1.0",
  "@babel/preset-env": "^7.1.0",
  //...
}
  • @babel/core, Babel का मुख्य कंपाइलर है. इससे, सभी Babel कॉन्फ़िगरेशन को प्रोजेक्ट के रूट में मौजूद .babelrc में तय किया जाता है.
  • babel-loader इसमें webpack की बिल्ड प्रोसेस में Babel शामिल होता है.

अब webpack.config.js देखें. इसमें बताया गया है कि babel-loader को नियम के तौर पर कैसे शामिल किया गया है:

module: {
  rules: [
    //...
    {
      test: /\.js$/,
      exclude: /node_modules/,
      loader: "babel-loader"
    }
  ]
},
  • @babel/polyfill, ECMAScript की नई सुविधाओं के लिए ज़रूरी सभी पॉलीफ़िल उपलब्ध कराता है, ताकि वे उन एनवायरमेंट में काम कर सकें जिनमें ये सुविधाएं काम नहीं करती हैं. इसे src/index.js. में सबसे ऊपर पहले ही इंपोर्ट किया जा चुका है
import "./style.css";
import "@babel/polyfill";
  • @babel/preset-env यह पता लगाता है कि टारगेट के तौर पर चुने गए किसी भी ब्राउज़र या एनवायरमेंट के लिए, कौनसा ट्रांसफ़ॉर्म और पॉलीफ़िल ज़रूरी है.

Babel कॉन्फ़िगरेशन फ़ाइल, .babelrc देखें. इससे आपको पता चलेगा कि इसे कैसे शामिल किया गया है:

{
  "presets": [
    [
      "@babel/preset-env",
      {
        "targets": "last 2 versions"
      }
    ]
  ]
}

यह Babel और webpack सेटअप है. अगर webpack के अलावा किसी दूसरे मॉड्यूल बंडलर का इस्तेमाल किया जा रहा है, तो अपने ऐप्लिकेशन में Babel को शामिल करने का तरीका जानें.

targets एट्रिब्यूट में मौजूद .babelrc से पता चलता है कि किन ब्राउज़र को टारगेट किया जा रहा है. @babel/preset-env यह browserslist के साथ इंटिग्रेट होता है. इसका मतलब है कि इस फ़ील्ड में इस्तेमाल की जा सकने वाली, काम करने वाली क्वेरी की पूरी सूची browserlist के दस्तावेज़ में देखी जा सकती है.

"last 2 versions" वैल्यू, ऐप्लिकेशन में कोड को ट्रांसपाइल करती है. यह कोड, हर ब्राउज़र के पिछले दो वर्शन के लिए होता है.

डीबग करना

ब्राउज़र के सभी Babel टारगेट के साथ-साथ, शामिल किए गए सभी ट्रांसफ़ॉर्म और पॉलीफ़िल को पूरी तरह से देखने के लिए, .babelrc: में debug फ़ील्ड जोड़ें

{
  "presets": [
    [
      "@babel/preset-env",
      {
        "targets": "last 2 versions",
        "debug": true
      }
    ]
  ]
}
  • टूल पर क्लिक करें.
  • लॉग पर क्लिक करें.

ऐप्लिकेशन को फिर से लोड करें और एडिटर में सबसे नीचे, गड़बड़ी की स्थिति के लॉग देखें.

टारगेट किए गए ब्राउज़र

Babel, कंपाइल करने की प्रोसेस के बारे में कई तरह की जानकारी को कंसोल में लॉग करता है. इसमें, उन सभी टारगेट एनवायरमेंट की जानकारी भी शामिल होती है जिनके लिए कोड कंपाइल किया गया है.

टारगेट किए गए ब्राउज़र

ध्यान दें कि इस सूची में, बंद हो चुके ब्राउज़र जैसे कि Internet Explorer भी शामिल हैं. यह एक समस्या है, क्योंकि जिन ब्राउज़र पर Babel काम नहीं करता उनमें नई सुविधाएं नहीं जोड़ी जाएंगी. साथ ही, Babel उनके लिए खास सिंटैक्स को ट्रांसपाइल करता रहेगा. अगर उपयोगकर्ता आपकी साइट को ऐक्सेस करने के लिए इस ब्राउज़र का इस्तेमाल नहीं कर रहे हैं, तो इससे आपके बंडल का साइज़ बेवजह बढ़ जाता है.

Babel, इस्तेमाल किए गए ट्रांसफ़ॉर्म प्लगिन की सूची को भी लॉग करता है:

इस्तेमाल किए गए प्लगिन की सूची

यह तो काफ़ी लंबी सूची है! ये ऐसे सभी प्लगिन हैं जिनका इस्तेमाल Babel को करना होता है, ताकि टारगेट किए गए सभी ब्राउज़र के लिए, ES2015+ सिंटैक्स को पुराने सिंटैक्स में बदला जा सके.

हालांकि, Babel इस्तेमाल किए गए किसी भी पॉलीफ़िल को नहीं दिखाता:

कोई पॉलीफ़िल नहीं जोड़ा गया

ऐसा इसलिए है, क्योंकि पूरे @babel/polyfill को सीधे तौर पर इंपोर्ट किया जा रहा है.

एक-एक करके पॉलीफ़िल लोड करना

डिफ़ॉल्ट रूप से, Babel में ES2015+ एनवायरमेंट के लिए ज़रूरी हर पॉलीफ़िल शामिल होता है. ऐसा तब होता है, जब @babel/polyfill को किसी फ़ाइल में इंपोर्ट किया जाता है. अगर टारगेट किए गए ब्राउज़र के लिए ज़रूरी पॉलीफ़िल इंपोर्ट करने हैं, तो कॉन्फ़िगरेशन में useBuiltIns: 'entry' जोड़ें.

{
  "presets": [
    [
      "@babel/preset-env",
      {
        "targets": "last 2 versions",
        "debug": true
        "useBuiltIns": "entry"
      }
    ]
  ]
}

ऐप्लिकेशन को फिर से लोड करें. अब आपको शामिल किए गए सभी पॉलीफ़िल दिखेंगे:

इंपोर्ट किए गए पॉलीफ़िल की सूची

हालांकि, अब सिर्फ़ "last 2 versions" के लिए ज़रूरी पॉलीफ़िल शामिल किए गए हैं, लेकिन यह अब भी बहुत लंबी सूची है! ऐसा इसलिए है, क्योंकि हर नई सुविधा के लिए, टारगेट ब्राउज़र के लिए ज़रूरी पॉलीफ़िल अब भी शामिल हैं. एट्रिब्यूट की वैल्यू को usage में बदलें, ताकि सिर्फ़ उन सुविधाओं को शामिल किया जा सके जिनका इस्तेमाल कोड में किया जा रहा है.

{
  "presets": [
    [
      "@babel/preset-env",
      {
        "targets": "last 2 versions",
        "debug": true,
        "useBuiltIns": "entry"
        "useBuiltIns": "usage"
      }
    ]
  ]
}

इससे, जहां ज़रूरी हो वहां पॉलीफ़िल अपने-आप शामिल हो जाते हैं. इसका मतलब है कि src/index.js. में जाकर, @babel/polyfill का इंपोर्ट हटाया जा सकता है

import "./style.css";
import "@babel/polyfill";

अब सिर्फ़ वे ज़रूरी पॉलीफ़िल शामिल किए जाते हैं जिनकी ऐप्लिकेशन के लिए ज़रूरत होती है.

अपने-आप शामिल होने वाले पॉलीफ़िल की सूची

ऐप्लिकेशन बंडल का साइज़ काफ़ी कम हो गया है.

बंडल का साइज़ 30.1 केबी तक कम हो गया

साथ काम करने वाले ब्राउज़र की सूची को छोटा करना

इसमें अब भी काफ़ी ज़्यादा ब्राउज़र टारगेट शामिल हैं. साथ ही, Internet Explorer जैसे बंद हो चुके ब्राउज़र का इस्तेमाल बहुत कम लोग करते हैं. कॉन्फ़िगरेशन को इस तरह अपडेट करें:

{
  "presets": [
    [
      "@babel/preset-env",
      {
        "targets": "last 2 versions",
        "targets": [">0.25%", "not ie 11"],
        "debug": true,
        "useBuiltIns": "usage",
      }
    ]
  ]
}

फ़ेच किए गए बंडल की जानकारी देखें.

बंडल का साइज़ 30.0 केबी

ऐप्लिकेशन का साइज़ छोटा होने की वजह से, इन बदलावों से कोई खास फ़र्क़ नहीं पड़ता. हालांकि, हमारा सुझाव है कि आप ब्राउज़र के मार्केट शेयर के प्रतिशत (जैसे कि ">0.25%") का इस्तेमाल करें. साथ ही, उन ब्राउज़र को बाहर रखें जिनका इस्तेमाल आपके उपयोगकर्ता नहीं कर रहे हैं. इस बारे में ज़्यादा जानने के लिए, जेम्स काइल का यह लेख पढ़ें: "पिछले दो वर्शन" को नुकसान पहुंचाने वाला माना जाता है.

<script type="module"> का इस्तेमाल करें

इसमें अब भी सुधार किया जा सकता है. हालांकि, इस्तेमाल नहीं किए गए कई पॉलीफ़िल हटा दिए गए हैं, लेकिन अब भी कई ऐसे पॉलीफ़िल हैं जिन्हें शिप किया जा रहा है. हालांकि, कुछ ब्राउज़र के लिए इनकी ज़रूरत नहीं है. मॉड्यूल का इस्तेमाल करके, नए सिंटैक्स लिखे जा सकते हैं. साथ ही, उन्हें सीधे तौर पर ब्राउज़र पर भेजा जा सकता है. इसके लिए, किसी भी गैर-ज़रूरी पॉलीफ़िल का इस्तेमाल नहीं करना पड़ता.

JavaScript मॉड्यूल एक नई सुविधा है. यह सभी मुख्य ब्राउज़र पर काम करती है. type="module" एट्रिब्यूट का इस्तेमाल करके मॉड्यूल बनाए जा सकते हैं. इससे उन स्क्रिप्ट को तय किया जा सकता है जो दूसरे मॉड्यूल से इंपोर्ट और एक्सपोर्ट करती हैं. उदाहरण के लिए:

// math.mjs
export const add = (x, y) => x + y;

<!-- index.html -->
<script type="module">
  import { add } from './math.mjs';

  add(5, 2); // 7
</script>

ECMAScript की कई नई सुविधाएं, उन एनवायरमेंट में पहले से ही काम करती हैं जिनमें JavaScript मॉड्यूल काम करते हैं. इसके लिए, Babel की ज़रूरत नहीं होती. इसका मतलब है कि Babel कॉन्फ़िगरेशन में बदलाव करके, ब्राउज़र को आपके ऐप्लिकेशन के दो अलग-अलग वर्शन भेजे जा सकते हैं:

  • ऐसा वर्शन जो मॉड्यूल के साथ काम करने वाले नए ब्राउज़र में काम करेगा. इसमें ऐसा मॉड्यूल शामिल होगा जिसे ज़्यादातर ट्रांसपाइल नहीं किया गया है, लेकिन इसकी फ़ाइल का साइज़ छोटा है
  • ऐसा वर्शन जिसमें बड़ी, ट्रांसपाइल की गई स्क्रिप्ट शामिल होती है. यह किसी भी लेगसी ब्राउज़र में काम करती है

Babel के साथ ES Modules का इस्तेमाल करना

ऐप्लिकेशन के दोनों वर्शन के लिए अलग-अलग @babel/preset-env सेटिंग रखने के लिए, .babelrc फ़ाइल हटाएं. ऐप्लिकेशन के हर वर्शन के लिए, दो अलग-अलग कंपाइलेशन फ़ॉर्मैट तय करके, Babel की सेटिंग को webpack कॉन्फ़िगरेशन में जोड़ा जा सकता है.

लेगसी स्क्रिप्ट के लिए, webpack.config.js में कॉन्फ़िगरेशन जोड़ें:

const legacyConfig = {
  entry,
  output: {
    path: path.resolve(__dirname, "public"),
    filename: "[name].bundle.js"
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        loader: "babel-loader",
        options: {
          presets: [
            ["@babel/preset-env", {
              useBuiltIns: "usage",
              targets: {
                esmodules: false
              }
            }]
          ]
        }
      },
      cssRule
    ]
  },
  plugins
}

ध्यान दें कि "@babel/preset-env" के लिए targets वैल्यू का इस्तेमाल करने के बजाय, esmodules का इस्तेमाल किया गया है. इसकी वैल्यू false है. इसका मतलब है कि Babel में, ES मॉड्यूल के साथ काम न करने वाले हर ब्राउज़र को टारगेट करने के लिए, सभी ज़रूरी ट्रांसफ़ॉर्म और पॉलीफ़िल शामिल हैं.

webpack.config.js फ़ाइल की शुरुआत में entry, cssRule, और corePlugins ऑब्जेक्ट जोड़ें. ये सभी, ब्राउज़र को दिखाई जाने वाली मॉड्यूल और लेगसी स्क्रिप्ट, दोनों के बीच शेयर किए जाते हैं.

const entry = {
  main: "./src"
};

const cssRule = {
  test: /\.css$/,
  use: ExtractTextPlugin.extract({
    fallback: "style-loader",
    use: "css-loader"
  })
};

const plugins = [
  new ExtractTextPlugin({filename: "[name].css", allChunks: true}),
  new HtmlWebpackPlugin({template: "./src/index.html"})
];

अब इसी तरह, मॉड्यूल स्क्रिप्ट के लिए एक कॉन्फ़िगरेशन ऑब्जेक्ट बनाएं. यह ऑब्जेक्ट, legacyConfig के नीचे बनाया जाना चाहिए:

const moduleConfig = {
  entry,
  output: {
    path: path.resolve(__dirname, "public"),
    filename: "[name].mjs"
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        loader: "babel-loader",
        options: {
          presets: [
            ["@babel/preset-env", {
              useBuiltIns: "usage",
              targets: {
                esmodules: true
              }
            }]
          ]
        }
      },
      cssRule
    ]
  },
  plugins
}

यहां मुख्य अंतर यह है कि आउटपुट फ़ाइल के नाम के लिए, .mjs फ़ाइल एक्सटेंशन का इस्तेमाल किया जाता है. यहां esmodules की वैल्यू को सही पर सेट किया गया है. इसका मतलब है कि इस मॉड्यूल में आउटपुट किया गया कोड, छोटी और कम कंपाइल की गई स्क्रिप्ट है. इस उदाहरण में, इसमें कोई बदलाव नहीं किया गया है, क्योंकि इस्तेमाल की गई सभी सुविधाएं उन ब्राउज़र में पहले से ही काम करती हैं जो मॉड्यूल के साथ काम करते हैं.

फ़ाइल के आखिर में, दोनों कॉन्फ़िगरेशन को एक ही ऐरे में एक्सपोर्ट करें.

module.exports = [
  legacyConfig, moduleConfig
];

अब यह उन ब्राउज़र के लिए छोटा मॉड्यूल बनाता है जो इसका इस्तेमाल कर सकते हैं. साथ ही, यह पुराने ब्राउज़र के लिए ट्रांसपाइल की गई बड़ी स्क्रिप्ट बनाता है.

मॉड्यूल के साथ काम करने वाले ब्राउज़र, nomodule एट्रिब्यूट वाली स्क्रिप्ट को अनदेखा करते हैं. इसके उलट, जिन ब्राउज़र पर मॉड्यूल काम नहीं करते वे type="module" वाले स्क्रिप्ट एलिमेंट को अनदेखा कर देते हैं. इसका मतलब है कि आपके पास मॉड्यूल के साथ-साथ कंपाइल किया गया फ़ॉलबैक शामिल करने का विकल्प होता है. आदर्श रूप से, ऐप्लिकेशन के दोनों वर्शन index.html इस तरह होने चाहिए:

<script type="module" src="main.mjs"></script>
<script nomodule src="main.bundle.js"></script>

मॉड्यूल के साथ काम करने वाले ब्राउज़र, main.mjs को फ़ेच और एक्ज़ीक्यूट करते हैं. साथ ही, main.bundle.js. को अनदेखा करते हैं. मॉड्यूल के साथ काम न करने वाले ब्राउज़र, इसके उलट काम करते हैं.

यह ध्यान रखना ज़रूरी है कि सामान्य स्क्रिप्ट के उलट, मॉड्यूल स्क्रिप्ट डिफ़ॉल्ट रूप से हमेशा पोस्टपोन की जाती हैं. अगर आपको nomodule स्क्रिप्ट को भी तब तक के लिए रोकना है, जब तक उसे पार्स नहीं कर लिया जाता, तो आपको defer एट्रिब्यूट जोड़ना होगा:

<script type="module" src="main.mjs"></script>
<script nomodule src="main.bundle.js" defer></script>

यहां आखिरी काम यह करना है कि मॉड्यूल और लेगसी स्क्रिप्ट में, module और nomodule एट्रिब्यूट जोड़ें. साथ ही, webpack.config.js के सबसे ऊपर ScriptExtHtmlWebpackPlugin इंपोर्ट करें:

const path = require("path");

const webpack = require("webpack");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const ScriptExtHtmlWebpackPlugin = require("script-ext-html-webpack-plugin");

अब कॉन्फ़िगरेशन में मौजूद plugins ऐरे को अपडेट करें, ताकि इस प्लगिन को शामिल किया जा सके:

const plugins = [
  new ExtractTextPlugin({filename: "[name].css", allChunks: true}),
  new HtmlWebpackPlugin({template: "./src/index.html"}),
  new ScriptExtHtmlWebpackPlugin({
    module: /\.mjs$/,
    custom: [
      {
        test: /\.js$/,
        attribute: 'nomodule',
        value: ''
    },
    ]
  })
];

ये प्लगिन सेटिंग, सभी .mjs स्क्रिप्ट एलिमेंट के लिए type="module" एट्रिब्यूट और सभी .js स्क्रिप्ट मॉड्यूल के लिए nomodule एट्रिब्यूट जोड़ती हैं.

एचटीएमएल दस्तावेज़ में मॉड्यूल दिखाना

आखिरी काम यह है कि लेगसी और मॉडर्न, दोनों स्क्रिप्ट एलिमेंट को एचटीएमएल फ़ाइल में आउटपुट किया जाए. माफ़ करें, फ़ाइनल एचटीएमएल फ़ाइल बनाने वाला प्लगिन, HTMLWebpackPlugin, फ़िलहाल मॉड्यूल और नोमॉड्यूल, दोनों स्क्रिप्ट के आउटपुट के साथ काम नहीं करता है. इस समस्या को हल करने के लिए, BabelMultiTargetPlugin और HTMLWebpackMultiBuildPlugin जैसे अलग-अलग प्लगिन बनाए गए हैं. हालांकि, इस ट्यूटोरियल में मॉड्यूल स्क्रिप्ट एलिमेंट को मैन्युअल तरीके से जोड़ने का आसान तरीका इस्तेमाल किया गया है.

फ़ाइल के आखिर में, src/index.js में यह जानकारी जोड़ें:

    ...
    </form>
    <script type="module" src="main.mjs"></script>
  </body>
</html>

अब ऐप्लिकेशन को ऐसे ब्राउज़र में लोड करें जो मॉड्यूल के साथ काम करता हो. जैसे, Chrome का नया वर्शन.

नए ब्राउज़र के लिए, नेटवर्क पर फ़ेच किया गया 5.2 केबी का मॉड्यूल

सिर्फ़ मॉड्यूल को फ़ेच किया जाता है. साथ ही, बंडल का साइज़ भी बहुत कम होता है, क्योंकि इसे ज़्यादातर ट्रांसपाइल नहीं किया जाता! दूसरे स्क्रिप्ट एलिमेंट को ब्राउज़र पूरी तरह से अनदेखा कर देता है.

अगर ऐप्लिकेशन को किसी पुराने ब्राउज़र पर लोड किया जाता है, तो सिर्फ़ बड़ी, ट्रांसपाइल की गई स्क्रिप्ट को फ़ेच किया जाएगा. इसमें सभी ज़रूरी पॉलीफ़िल और ट्रांसफ़ॉर्म शामिल होंगे. यहां Chrome के पुराने वर्शन (वर्शन 38) पर किए गए सभी अनुरोधों का स्क्रीनशॉट दिया गया है.

पुराने ब्राउज़र के लिए फ़ेच की गई 30 केबी की स्क्रिप्ट

नतीजा

अब आपको यह समझ आ गया है कि टारगेट किए गए ब्राउज़र के लिए, सिर्फ़ ज़रूरी पॉलीफ़िल उपलब्ध कराने के लिए @babel/preset-env का इस्तेमाल कैसे किया जाता है. आपको यह भी पता है कि JavaScript मॉड्यूल, किसी ऐप्लिकेशन के दो अलग-अलग ट्रांसपाइल किए गए वर्शन को शिप करके, परफ़ॉर्मेंस को और बेहतर कैसे बना सकते हैं. इन दोनों तकनीकों के बारे में जानने के बाद, अब आप अपने बंडल के साइज़ को काफ़ी हद तक कम कर सकते हैं. इसलिए, आगे बढ़ें और ऑप्टिमाइज़ करें!