गल्प - सम्मिश्रण कार्य

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

gulp.task('task-name', function() {
   //do stuff here
});

जहाँ "कार्य-नाम" एक स्ट्रिंग नाम है और "फ़ंक्शन ()" आपका कार्य करता है। "Gulp.task" फ़ंक्शन को नाम के भीतर एक कार्य के रूप में पंजीकृत करता है और अन्य कार्यों पर निर्भरता को निर्दिष्ट करता है।

प्लगइन्स इंस्टॉल करना

चलो एक प्लगइन बुलाया minify-cssसभी सीएसएस लिपियों को मर्ज और छोटा करना। इसे npm का उपयोग करके स्थापित किया जा सकता है जैसा कि निम्नलिखित कमांड में दिखाया गया है -

npm install gulp-minify-css --save-dev

"Gulp-minify-css plugin" के साथ काम करने के लिए, आपको "gulp-autoprefixer" नामक एक अन्य प्लगइन स्थापित करने की आवश्यकता है जैसा कि निम्नलिखित कमांड में दिखाया गया है -

npm install gulp-autoprefixer --save-dev

CSS फाइलों को संक्षिप्त करने के लिए, निम्न कमांड में दिखाए अनुसार gulp-concat स्थापित करें -

npm install gulp-concat --save-dev

प्लगइन्स की स्थापना के बाद, आपको अपनी कॉन्फ़िगरेशन फ़ाइल में निम्नानुसार निर्भरताएं लिखना होगा -

var autoprefix = require('gulp-autoprefixer');
var minifyCSS = require('gulp-minify-css');
var concat = require('gulp-concat');

टास्क को गुलप फाइल में जोड़ना

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

gulp.task('styles', function() {
   gulp.src(['src/styles/*.css'])
   .pipe(concat('styles.css'))
   .pipe(autoprefix('last 2 versions'))
   .pipe(minifyCSS())
   .pipe(gulp.dest('build/styles/'));
});

'कॉनसैट' प्लगइन सीएसएस फाइलों को समेटता है और 'ऑटोप्रेफिक्स' प्लगइन सभी ब्राउज़रों के वर्तमान और पिछले संस्करणों को इंगित करता है। यह src फ़ोल्डर से सभी CSS स्क्रिप्ट्स को कॉपी करता है और एक तर्क के साथ 'dest' विधि को कॉल करके बिल्ड फ़ोल्डर में कॉपी करता है, जो लक्ष्य निर्देशिका का प्रतिनिधित्व करता है।

कार्य को चलाने के लिए, अपने प्रोजेक्ट डायरेक्टरी में निम्न कमांड का उपयोग करें -

gulp styles

इसी तरह, हम इमेज फाइल को कंप्रेस करने के लिए 'gulp-imagemin' नामक एक अन्य प्लगइन का उपयोग करेंगे, जिसे निम्न कमांड का उपयोग करके इंस्टॉल किया जा सकता है -

npm install gulp-imagemin --save-dev

आप निम्न कमांड का उपयोग करके अपनी कॉन्फ़िगरेशन फ़ाइल में निर्भरता जोड़ सकते हैं -

var imagemin = require('gulp-imagemin');

आप उपरोक्त परिभाषित निर्भरता के लिए कार्य बना सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

gulp.task('imagemin', function() {
   var img_src = 'src/images/**/*', img_dest = 'build/images';
   
   gulp.src(img_src)
   .pipe(changed(img_dest))
   .pipe(imagemin())
   .pipe(gulp.dest(img_dest));
});

चित्र "src / images / ** / *" में स्थित हैं जो img_srcobject में सहेजे गए हैं। यह 'इमेजमिन' कंस्ट्रक्टर द्वारा बनाए गए अन्य कार्यों के लिए पाइप किया गया है। यह src फ़ोल्डर से छवियों को संकुचित करता है और एक तर्क के साथ 'dest' पद्धति को कॉल करके बिल्ड फ़ोल्डर में कॉपी करता है, जो लक्ष्य निर्देशिका का प्रतिनिधित्व करता है।

कार्य को चलाने के लिए, अपने प्रोजेक्ट डायरेक्टरी में निम्न कमांड का उपयोग करें -

gulp imagemin

कई कार्यो को मिलाना

आप निम्न कोड में दिखाए अनुसार कॉन्फ़िगरेशन फ़ाइल में डिफ़ॉल्ट कार्य बनाकर एक समय में कई कार्य चला सकते हैं -

gulp.task('default', ['imagemin', 'styles'], function() {

});

गुलप फ़ाइल स्थापित और निष्पादित करने के लिए तैयार है। उपरोक्त संयुक्त कार्यों को चलाने के लिए अपनी परियोजना निर्देशिका में निम्नलिखित कमांड चलाएँ -

gulp

उपरोक्त कमांड का उपयोग करके कार्य चलाने पर, आपको कमांड प्रॉम्प्ट में निम्नलिखित परिणाम मिलेगा -

C:\work>gulp
[16:08:51] Using gulpfile C:\work\gulpfile.js
[16:08:51] Starting 'imagemin'...
[16:08:51] Finished 'imagemin' after 20 ms
[16:08:51] Starting 'styles'...
[16:08:51] Finished 'styles' after 13 ms
[16:08:51] Starting 'default'...
[16:08:51] Finished 'default' after 6.13 ms
[16:08:51] gulp-imagemin: Minified 0 images