BabelJS - Babel और JSX के साथ कार्य करना

इस अध्याय में, हम JSX और बेबेल के साथ काम करने के बारे में समझेंगे। इससे पहले कि हम विवरण में आएं, हमें समझ लें कि JSX क्या है।

JSX क्या है?

JSX एक जावास्क्रिप्ट कोड है जिसमें xml सिंटैक्स का संयोजन है। JSX टैग में टैग का नाम, विशेषताएँ और बच्चे हैं जो इसे xml की तरह बनाते हैं।

प्रतिक्रिया नियमित जावास्क्रिप्ट के बजाय templating के लिए JSX का उपयोग करता है। इसका उपयोग करना आवश्यक नहीं है, हालांकि, निम्नलिखित कुछ पेशेवरों हैं जो इसके साथ आते हैं।

  • यह तेजी से है क्योंकि यह जावास्क्रिप्ट कोड को संकलित करते समय अनुकूलन करता है।

  • यह टाइप-सुरक्षित भी है और अधिकांश त्रुटियों को संकलन के दौरान पकड़ा जा सकता है।

  • यदि आप HTML से परिचित हैं, तो टेम्प्लेट लिखना आसान और तेज़ हो जाता है।

हमने प्रोजेक्ट सेटअप में बैबल 6 का उपयोग किया है। यदि आप बाबेल 7 पर स्विच करना चाहते हैं, तो बाबेल के आवश्यक पैकेजों का उपयोग करके स्थापित करें@babel/babel-package-name

हम प्रोजेक्ट सेटअप बनाएंगे और बेबेल का उपयोग करके सामान्य जावास्क्रिप्ट पर प्रतिक्रिया के साथ jsx संकलित करने के लिए वेबपैक का उपयोग करेंगे।

प्रोजेक्ट सेटअप शुरू करने के लिए, नीचे दिए गए कमांड को बेबल, रिएक्शन और वेबपैक इंस्टालेशन के लिए चलाएं।

आदेश

npm init

अब, हम उन आवश्यक पैकेजों को स्थापित करेंगे जिनके साथ हमें काम करने की आवश्यकता है - बेबल, वेबपैक और jsx -

npm install --save-dev webpack
npm install --save-dev webpack-cli
npm install --save-dev webpack-dev-server
npm install --save-dev babel-core
npm install --save-dev babel-loader
npm install --save-dev babel-preset-es2015
npm install --save-dev babel-preset-react
npm install --save-dev react
npm install --save-dev react-dom

यहाँ स्थापना के बाद package.json है -

अब एक webpack.config.js फ़ाइल बनाएगा, जिसमें js फ़ाइलों को बंडल करने और इसे bab5 का उपयोग करके es5 में संकलित करने के लिए सभी विवरण होंगे।

सर्वर का उपयोग करके वेबपैक चलाने के लिए, वेबपैक-सर्वर नामक कुछ है। हमने कमांड को पब्लिश कहा है; यह कमांड वेबपैक-देव-सर्वर शुरू करेगा और उस पथ को अपडेट करेगा जहां अंतिम फाइलें संग्रहीत हैं। अभी हम अंतिम फ़ाइलों को अपडेट करने के लिए जिस पथ का उपयोग करने जा रहे हैं वह / dev फ़ोल्डर है।

वेबपैक का उपयोग करने के लिए हमें निम्नलिखित कमांड चलाने की आवश्यकता है -

npm run publish

हम पैदा करेंगे webpack.config.js फाइलें, जिनके पास काम करने के लिए वेबपैक का विन्यास विवरण है।

फाइल का विवरण इस प्रकार है -

var path = require('path');

module.exports = {
   entry: {
      app: './src/main.js'
   },
   output: {
      path: path.resolve(__dirname, 'dev'),
      filename: 'main_bundle.js'
   },
   mode:'development',
   module: {
      rules: [
         {
            test:/\.(js|jsx)$/,
            include: path.resolve(__dirname, 'src'),
            loader: 'babel-loader',
            query: {
               presets: ['es2015','react']
            }
         }
      ]
   }
};

फ़ाइल की संरचना ऊपर बताई गई है। यह पथ से शुरू होता है, जो वर्तमान पथ का विवरण देता है।

var path = require('path'); //gives the current path

अगला मॉड्यूल.एक्सपोर्ट ऑब्जेक्ट है, जिसमें गुण प्रविष्टि, आउटपुट और मॉड्यूल हैं।

प्रवेश प्रारंभ बिंदु है। यहां हमें उन मुख्य js फ़ाइलों को देने की आवश्यकता है जिन्हें हम संकलित करना चाहते हैं।

entry: {
   app: './src/main.js'
},

path.resolve(_dirname, ‘src/main.js’) - निर्देशिका में src फ़ोल्डर के लिए दिखेगा और main.js उस फ़ोल्डर में।

उत्पादन

output: {
   path: path.resolve(__dirname, 'dev'),
   filename: 'main_bundle.js'
},

आउटपुट पथ और फ़ाइल नाम के विवरण के साथ एक वस्तु है। पथ उस फ़ोल्डर को रखेगा जिसमें संकलित फ़ाइल रखी जाएगी और फ़ाइल नाम आपके द्वारा उपयोग की जाने वाली अंतिम फ़ाइल का नाम बताएगा.html फ़ाइल।

मापांक

module: {
   rules: [
      {
         test:/\.(js|jsx)$/,
         include: path.resolve(__dirname, 'src'),
         loader: 'babel-loader',
         query: {
            presets: ['es2015','react']
         }
      }
   ]
}
  • मॉड्यूल नियमों के विवरण के साथ वस्तु है जिसमें गुण हैं अर्थात परीक्षण, शामिल, लोडर, क्वेरी।

  • टेस्ट .js और .jsx के साथ समाप्त होने वाली सभी js फ़ाइल का विवरण रखेगा। इसमें पैटर्न है जो दिए गए प्रविष्टि बिंदु पर अंत में .js और .jsx की तलाश करेगा।

  • फ़ाइलों को देखने के लिए उपयोग किए जाने वाले फ़ोल्डर को शामिल करें

  • लोडर कोड संकलन के लिए बैबल- लोडर का उपयोग करता है।

  • क्वेरी में प्रॉपर्टी प्रीसेट्स हैं, जो कि एएनवी मान के साथ है - es5 या es6 या es7। हमने es2015 का उपयोग किया है और प्रीसेट के रूप में प्रतिक्रिया करते हैं।

फोल्डर बनाएं src/. जोड़ना main.js तथा App.jsx इस में।

App.jsx

import React from 'react';

class App extends React.Component {
   render() {
         var style = {
         color: 'red',
         fontSize: 50
      };
      return (
         <div style={style}>
            Hello World!!!
         </div>
      );
   }
}
export default App;

main.js

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App.jsx';

ReactDOM.render(
      , document.getElementById('app'));

.Js फ़ाइल को बंडल करने और प्रीसेट का उपयोग करके इसे परिवर्तित करने के लिए निम्न कमांड चलाएँ es2015 तथा react

आदेश

npm run pack

जोड़ना main_bundle.js देव फ़ोल्डर से index.html -

<!DOCTYPE html>
<html lang = "en">
   <head>
      <meta charset = "UTF-8">
      <title>React App</title>
   </head>
   <body>
      <div id = "app"></div>
      <script src = "dev/main_bundle.js"></script>
   </body>
</html>

आदेश

npm run publish

उत्पादन