आवश्यकताएँ - अनुकूलक

इस अध्याय में, हम आवश्यकताएँ में अनुकूलन पर चर्चा करेंगे। आवश्यकताएँ में अनुकूलक में निम्नलिखित विशेषताएं हैं -

  • जावा उपयोग के लिए डिफ़ॉल्ट उपयोग या क्लोजर कंपाइलर के लिए UglifyJS की मदद से स्क्रिप्ट फ़ाइलों को एक साथ जोड़ता है

  • CSS फाइलों को एक साथ जोड़ देता है।

आशावादी का एक घटक है r.jsनोड और नैशॉर्न के लिए एडाप्टर । यह एक निर्माण प्रक्रिया का हिस्सा बनने के लिए विकसित किया गया है न कि विकास प्रक्रिया के लिए।

उदाहरण

अपने प्रोजेक्ट फ़ोल्डर में r.js डाउनलोड करने के बाद , फ़ोल्डर की संरचना नीचे दी गई के रूप में दिखनी चाहिए -

projectfolder/
   |-->index.html
   |-->CSS/
      |--->main.css
      |--->other.css
   |-->libs
      |--->require.js
      |--->main.js
         |--->dependent1.js
         |--->dependent2.js
         |--->dependent3.js

आपकी HTML फ़ाइल नीचे दिखाए गए अनुसार दिखाई देगी -

<html>
   <head>
      <script data-main = "libs/main" src = "libs/require.js"></script>
   </head>
   
   <body>
      <h1> RequireJS Sample Page </h1>
   </body>
</html>

आपकी main.js फ़ाइल नीचे दिखाए अनुसार होगी -

require(["dependent1", "dependent2", "dependent3"], function (dependent1, dependent2, 
   dependent3) {
});

आपकी main.css फ़ाइल नीचे दिखाए अनुसार होगी -

@import url("other.css");

.app {
   background: transparent url(../../img/app.png);
}

ऑप्टिमाइज़र का मूल सेटअप

आप प्रोजेक्ट को सेट करने के लिए कमांड लाइन आर्ग्युमेंट्स या प्रोफाइल बिल्डिंग प्रॉपर्टीज का उपयोग कर सकते हैं, दोनों एक दूसरे के साथ विनिमेय हैं।

कमांड लाइन के लिए वाक्य रचना निम्नलिखित है -

node r.js -o baseUrl = . paths.jquery = content/path/jquery 
   name = main out = main-built.js

प्रोफ़ाइल निर्माण के लिए वाक्य रचना निम्नलिखित है -

({
   baseUrl: ".",
  
   paths: {
      jquery: "content/path/jquery"
   },
   
   name: "main",
   out: "main-built.js"
})

इसके बाद, आप कमांड लाइन में ऑप्टिमाइज़र को बिल्ड प्रोफ़ाइल नाम पर पास कर सकते हैं, जैसा कि नीचे दिखाया गया है -

node r.js -o build.js

कमांड लाइन तर्क सिंटैक्स पर कुछ कमियां हैं। कमांड लाइन आर्ग्युमेंट्स या प्रोफाइल बिल्डिंग प्रॉपर्टीज दोनों का संयुक्त उपयोग इन कमियों को दूर कर सकता है।

एक एकल जेएस फ़ाइल का अनुकूलन

एकल जेएस फ़ाइल को अनुकूलित करने के लिए, आपको एक जेएस फ़ाइल बनाने की आवश्यकता है जिसमें इसकी सभी निर्भरता की सामग्री शामिल है। आपकी फ़ाइल नीचे दी गई दिखनी चाहिए -

({
   baseUrl: "js/shop",
   paths: {
      "jquery": "jquery",
      "backbone": "backbone",
      "underscore": "underscore"
   },
   
   shim: {
      "backbone": {
         "department": ["underscore", "jquery"],
         "dependent": "Backbone"  
      },
      
      "underscore": {
         exports: "_" 
      }
   },
   
   name: "../main",
   out: "../built/js/main.js"
})

अब, आप main.js फ़ाइल बना सकते हैं जिसमें ऐप के लिए सभी निर्भरताएँ हैं। यह फ़ाइल HTML फ़ाइल में एक अनुरोध के साथ सभी जेएस फ़ाइलों को लोड करने के लिए उपयोग की जाती है। ध्यान दें, कि बनाई गई फ़ाइलें स्रोत कोड निर्देशिका में नहीं होनी चाहिए; फाइलें परियोजना की प्रति में होनी चाहिए।

सीडीएन संसाधनों का उपयोग

ऑप्टिमाइज़र नेटवर्क संसाधनों / CDN (सामग्री वितरण नेटवर्क) का उपयोग करके स्क्रिप्ट लोड नहीं करता है। मामले में, स्क्रिप्ट को एक सीडीएन का उपयोग करके लोड करने की आवश्यकता होती है फिर आपको इन फ़ाइलों को एक मॉड्यूल नाम पर मैप करने और फ़ाइलों को अपनी फ़ाइल फ़ाइल पथ पर डाउनलोड करने की आवश्यकता है। आप निम्न प्रोफ़ाइल के पथ विन्यास में विशेष शब्द "खाली" का उपयोग कर सकते हैं जैसा कि निम्नलिखित वाक्यविन्यास में दिखाया गया है -

({
   baseUrl: "js",
   name: "mainCDN",
   out: "js/mainCDN-built.js",
   
   paths: {
      jquery: "empty:"
   }
   
})

मुख्य फ़ाइल नीचे दिखाए गए अनुसार दिखाई देगी -

requirejs.config({
   paths: {
      'jquery': 'https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min'
   }
});

require(['jquery'], function ($) {
});

एकल सीएसएस फ़ाइल का अनुकूलन

सीएसएस फाइलें कमांड लाइन में सीधे निम्नलिखित मापदंडों का उपयोग करके अनुकूलित की जाती हैं जैसा कि नीचे दिखाया गया है -

node ../../r.js -o cssIn = main.css out = main-built.css

CSS फाइलों को बिल्ड फाइल में भी अनुकूलित किया जा सकता है, जैसा नीचे दिखाया गया है।

...
cssIn:"main.css",
out:"main-built.css"
...

उपरोक्त दोनों विधियों की अनुमति है और एक फाइल बनाएगी जिसे प्रोजेक्टफॉल्डर / css / mainbuild.css कहा जाएगा । इस फ़ाइल में main.css की सामग्री होगी, url () पथ ठीक से समायोजित किया गया है, और टिप्पणियां हटा दी गई हैं।

संपूर्ण परियोजना का अनुकूलन

ऑप्टिमाइज़र सभी का अनुकूलन करने के लिए बिल्ड प्रोफ़ाइल का उपयोग करता है css तथा jsफ़ाइलें। निम्न उदाहरण में, build.js फ़ाइल बनाई गई है।

({
   baseUrl: "js/shop",
   appDir: '.',
   paths: {
      "jquery": "jquery",
      "backbone": "backbone",
      "underscore": "underscore"
   },
   
   shim: {
      "backbone": {
         "deps": ["underscore", "jquery"],
         "exports": "Backbone"  
      },
      
      "underscore": {
         exports: "_" 
      }
   },
   
   optimizeCss: "standard.keepLines",
   modules: [
      {
         name: "app"
      }
   ],
   
   dir: "../built"
})

Build.js फ़ाइल RequireJS का निर्देश उत्पादन का निर्माण (dir पैरामीटर) फ़ोल्डर में सभी एप्लिकेशन फ़ोल्डर (appDir पैरामीटर) की प्रतिलिपि और आउटपुट फ़ोल्डर में स्थित फ़ाइलों के लिए सभी अनुकूलन लागू करने के लिए। एप्लिकेशन फ़ोल्डर में प्रोफ़ाइल बनाने के लिए निम्नलिखित कमांड चलाएँ -

node r.js -o build.js