Shim Configurations এবং Non-AMD স্ক্রিপ্ট ব্যবস্থাপনা

রিকোয়ারজেএস (RequireJS) - Web Development

317

RequireJS-এ Shim Configurations একটি গুরুত্বপূর্ণ কনফিগারেশন পদ্ধতি, যা Non-AMD স্ক্রিপ্টগুলো (যেগুলি Asynchronous Module Definition (AMD) স্টাইল অনুসরণ করে না) সঠিকভাবে লোড এবং ব্যবস্থাপনা করতে সাহায্য করে। এই কনফিগারেশনটি মূলত সেগুলি ব্যবহৃত হয়, যা require.js এর স্ট্যান্ডার্ড মডিউল সিস্টেমের সাথে কম্প্যাটিবল নয়।

Shim Configurations কী?

Shim Configuration হল RequireJS-এ একটি কনফিগারেশন ফিচার, যার মাধ্যমে আপনি এমন স্ক্রিপ্টগুলির জন্য ডিপেনডেন্সি এবং গ্লোবাল এক্সপোর্ট গুলি সংজ্ঞায়িত করতে পারেন, যা AMD মডিউল নয়। এই কনফিগারেশনটি ব্যবহার করে আপনি নিশ্চিত করতে পারেন যে Non-AMD স্ক্রিপ্টটি সঠিকভাবে লোড হয় এবং তার ডিপেনডেন্সি সঠিকভাবে ম্যানেজ হয়।

Shim Configurations এর প্যারামিটারস:

  1. exports: এটি আপনার স্ক্রিপ্টের গ্লোবাল ভ্যারিয়েবল বা অবজেক্টকে RequireJS এর মাধ্যমে এক্সপোর্ট করবে। Non-AMD স্ক্রিপ্টগুলি সাধারণত গ্লোবাল স্কোপে ভ্যারিয়েবল তৈরি করে, এবং এই প্যারামিটারটি সেগুলিকে এক্সপোর্ট হিসেবে নির্ধারণ করতে ব্যবহৃত হয়।
  2. deps: এই প্যারামিটারটি দ্বারা আপনি আপনার স্ক্রিপ্টটির ডিপেনডেন্সি নির্ধারণ করতে পারেন, অর্থাৎ কোন স্ক্রিপ্টটি আগে লোড হতে হবে যাতে পরে এটি সঠিকভাবে কাজ করতে পারে।
  3. init: এটি এমন একটি ফাংশন যা আপনার স্ক্রিপ্ট লোড হওয়ার পর ইন্টারনাল প্রসেসিং অথবা কনফিগারেশন সেটআপ করার জন্য ব্যবহৃত হয়।

Shim Configurations এর মাধ্যমে Non-AMD স্ক্রিপ্ট ব্যবস্থাপনা:

ধরা যাক, আমরা Bootstrap এবং jQuery ব্যবহার করতে চাই, যেখানে Bootstrap একটি Non-AMD স্ক্রিপ্ট এবং এটি jQuery এর উপর নির্ভরশীল। আমরা এই স্ক্রিপ্টগুলির জন্য Shim Configuration ব্যবহার করব।

RequireJS Shim Configuration উদাহরণ:

// config.js
require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'bootstrap': 'https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min'
  },
  shim: {
    'bootstrap': {
      deps: ['jquery'],  // Bootstrap depends on jQuery
      exports: '$.fn.popover'  // Bootstrap attaches methods to jQuery
    }
  }
});

ব্যাখ্যা:

  • paths: এখানে, আমরা jquery এবং bootstrap এর পাথ কনফিগার করেছি। bootstrap নির্দিষ্ট করে দিয়েছে যে এটি jquery এর উপর নির্ভরশীল, এবং jquery এর পাথটি দিয়েছি CDN থেকে।
  • shim: bootstrap মডিউলের জন্য শিম কনফিগারেশনটি ব্যাখ্যা করেছে:
    • deps: ['jquery']: এটি নিশ্চিত করে যে প্রথমে jQuery লোড হবে, তারপর Bootstrap লোড হবে, কারণ Bootstrap jQuery এর উপর নির্ভরশীল।
    • exports: '$.fn.popover': Bootstrap jQuery এর মেথডগুলিকে এক্সপোজ করে, বিশেষ করে $.fn.popover এবং এটি এক্সপোর্ট করা হয়।

Plugin ব্যবহারের উদাহরণ:

<script>
  require(['jquery', 'bootstrap'], function($) {
    // Now you can use Bootstrap methods or jQuery
    $(document).ready(function() {
      $('[data-toggle="tooltip"]').tooltip();
    });
  });
</script>

আরও একটি উদাহরণ: Non-AMD স্ক্রিপ্ট ব্যবস্থাপনা:

ধরা যাক, আপনার কাছে একটি legacy স্ক্রিপ্ট রয়েছে যা AMD-compliant নয়। আপনি shim কনফিগারেশন ব্যবহার করে এটি RequireJS এর সাথে লোড করতে পারেন।

// config.js
require.config({
  paths: {
    'legacyLibrary': 'path/to/legacyLibrary.js'
  },
  shim: {
    'legacyLibrary': {
      exports: 'LegacyLib'  // Define the global object that will be available
    }
  }
});

ব্যাখ্যা:

  • legacyLibrary: এটি এমন একটি স্ক্রিপ্ট যেটি AMD ফরম্যাটে নয়। আমরা exports প্যারামিটার ব্যবহার করে গ্লোবাল ভ্যারিয়েবল LegacyLib এক্সপোর্ট করেছি, যাতে এটি RequireJS ব্যবস্থাপনায় ব্যবহৃত হতে পারে।
  • exports: 'LegacyLib': এটি নির্দেশ করে যে যখন legacyLibrary.js লোড হবে, তখন এটি LegacyLib নামে গ্লোবাল অবজেক্ট তৈরি করবে, এবং আমরা এই অবজেক্টটি RequireJS এর মাধ্যমে ব্যবহার করতে পারব।

RequireJS Shim কনফিগারেশন এর উপকারিতা:

  1. Non-AMD Scripts কে AMD compatible করা:
    • অনেক পুরনো স্ক্রিপ্ট এবং লাইব্রেরি AMD স্টাইলের নয়, এবং তাদের জন্য শিম কনফিগারেশন ব্যবহার করলে সেগুলিকে RequireJS-এ মডিউল হিসেবে ব্যবহার করা যায়।
  2. ডিপেনডেন্সি ম্যানেজমেন্ট:
    • শিম কনফিগারেশনের মাধ্যমে স্ক্রিপ্টগুলির মধ্যে ডিপেনডেন্সি নির্ধারণ করা সম্ভব হয়, যেমন jquery এর উপর নির্ভরশীল bootstrap এর মতো লাইব্রেরি।
  3. গ্লোবাল এক্সপোর্ট সুনির্দিষ্ট করা:
    • আপনি সহজে গ্লোবাল এক্সপোর্টগুলি সংজ্ঞায়িত করতে পারেন, যেমন LegacyLib বা $.fn.popover, যা পরবর্তী স্ক্রিপ্ট বা কম্পোনেন্ট দ্বারা ব্যবহার করা হবে।
  4. স্ক্রিপ্ট লোডিং অর্ডার ম্যানেজমেন্ট:
    • Shim Configuration ডিপেনডেন্সি লোড অর্ডার নিয়ন্ত্রণে সাহায্য করে। এটি নিশ্চিত করে যে প্রয়োজনীয় স্ক্রিপ্ট প্রথমে লোড হবে, তারপর ডিপেনডেন্ট স্ক্রিপ্ট লোড হবে।

সারসংক্ষেপ:

Shim Configuration হল RequireJS-এর একটি শক্তিশালী বৈশিষ্ট্য যা আপনাকে Non-AMD স্ক্রিপ্ট এবং পুরনো স্ক্রিপ্টগুলিকে RequireJS-এর সাথে একত্রিত এবং পরিচালনা করতে সাহায্য করে। এটি dependencies, exports, এবং init প্যারামিটার ব্যবহারের মাধ্যমে স্ক্রিপ্ট লোড, ডিপেনডেন্সি ম্যানেজমেন্ট, এবং গ্লোবাল এক্সপোর্ট নির্ধারণ করতে সহায়ক। Shim কনফিগারেশন দ্বারা আপনি আপনার অ্যাপ্লিকেশনকে আরও কার্যকরী ও স্থিতিশীল করতে পারেন।

Content added By

RequireJS-এ Shim Configurations হল একটি কনফিগারেশন সেটিং যা আপনাকে নির্দিষ্ট non-AMD (Asynchronous Module Definition) লাইব্রেরি বা স্ক্রিপ্টগুলির জন্য ডিপেনডেন্সি এবং এক্সপোর্ট কার্যকলাপ কাস্টমাইজ করতে সহায়তা করে। যখন আপনি এমন লাইব্রেরি ব্যবহার করেন যেগুলি AMD কম্প্যাটিবল নয়, তখন shim কনফিগারেশন ব্যবহার করে আপনি তাদের RequireJS মডিউলের মতো আচরণ করাতে পারেন।

Shim Configurations এর ভূমিকা:

  1. Non-AMD লাইব্রেরির ইন্টিগ্রেশন: অনেক জনপ্রিয় লাইব্রেরি যেমন jQuery, Backbone.js, Underscore.js, এবং অন্যান্য অনেক লাইব্রেরি AMD স্টাইলের মডিউল নয়। তাদের সাধারণত global variables হিসেবে এক্সপোজ করা হয়, এবং তারা define() ফাংশন ব্যবহার করে মডিউল হিসেবে ডিফাইন করা হয় না।

    Shim configurations ব্যবহার করে, আপনি এমন লাইব্রেরিগুলিকে AMD মডিউলের মতো ব্যবহার করতে পারেন, যার ফলে তাদের ডিপেনডেন্সি এবং এক্সপোর্ট ম্যানেজ করা সহজ হয়ে যায়।

  2. ডিপেনডেন্সি ম্যানেজমেন্ট: Shim configurations আপনি ব্যবহার করতে পারেন এমন স্ক্রিপ্টগুলির জন্য যা অন্যান্য স্ক্রিপ্টের ওপর নির্ভরশীল। আপনি deps কনফিগারেশন সেট করে ডিপেনডেন্সি সংজ্ঞায়িত করতে পারেন এবং exports কনফিগারেশন ব্যবহার করে আপনি লাইব্রেরির এক্সপোর্ট ফাংশন বা অবজেক্টটি নির্ধারণ করতে পারেন।
  3. অ্যাক্সপোর্ট এবং এক্সপোজিং গ্লোবাল ভ্যারিয়েবল: যদি একটি স্ক্রিপ্ট গ্লোবাল ভ্যারিয়েবল হিসেবে একটি অবজেক্ট বা ফাংশন এক্সপোজ করে, তবে আপনি exports কনফিগারেশন ব্যবহার করে ঐ গ্লোবাল ভ্যারিয়েবলকে অ্যাক্সেস করতে পারবেন, যাতে মডিউলটি require() বা define() দিয়ে লোড করার পর সঠিকভাবে এক্সপোজ হয়।

Shim Configurations এর Syntax:

require.config({
  shim: {
    'moduleName': {
      deps: ['dependency1', 'dependency2'],  // Dependencies to be loaded before this module
      exports: 'globalVariable'               // The global variable to be exported
    }
  }
});
  • moduleName: এটি সেই মডিউলের নাম, যার জন্য আপনি shim কনফিগারেশন সেট করবেন।
  • deps: মডিউলটির ডিপেনডেন্সি নির্ধারণ করে। এই ডিপেনডেন্সিগুলি লোড হওয়া উচিত আগে, যাতে মডিউলটি সঠিকভাবে কাজ করতে পারে।
  • exports: এটি সেই গ্লোবাল ভ্যারিয়েবল বা ফাংশনকে নির্দেশ করে, যা মডিউল থেকে এক্সপোজ হবে। উদাহরণস্বরূপ, যদি একটি স্ক্রিপ্ট গ্লোবাল Backbone অবজেক্ট এক্সপোজ করে, তবে আপনি এই অপশনটি ব্যবহার করে তা exports করতে পারেন।

Shim Configurations এর উদাহরণ:

১. Backbone.js এর জন্য Shim Config

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'underscore': 'https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.9.1/underscore-min',
    'backbone': 'https://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.4.0/backbone-min'
  },
  shim: {
    'backbone': {
      deps: ['jquery', 'underscore'],
      exports: 'Backbone'
    }
  }
});

ব্যাখ্যা:

  • এখানে backbone মডিউলটি jquery এবং underscore এর উপর নির্ভরশীল।
  • exports: 'Backbone' ব্যবহার করা হয়েছে কারণ Backbone একটি গ্লোবাল ভ্যারিয়েবল হিসেবে এক্সপোজ হয় এবং এটি মডিউল হিসেবে এক্সপোর্ট হবে।

২. jQuery এর জন্য Shim Config

যদি আপনি কোনো স্ক্রিপ্ট ব্যবহার করছেন যা jQuery কে গ্লোবাল ভ্যারিয়েবল হিসেবে এক্সপোজ করে, তাহলে আপনি shim ব্যবহার করে এটিকে AMD মডিউল হিসেবে ব্যবহার করতে পারেন।

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min'
  },
  shim: {
    'jquery': {
      exports: '$'  // jQuery exports the global `$` variable
    }
  }
});

ব্যাখ্যা:

  • এখানে, exports: '$' দ্বারা jquery মডিউলটি $ গ্লোবাল ভ্যারিয়েবলকে এক্সপোজ করবে, যাতে আপনি require('jquery') ব্যবহার করে এটি অ্যাক্সেস করতে পারেন।

৩. RequireJS-এ Bootstrap এর জন্য Shim Config

Bootstrap সাধারণত jQuery এর ওপর নির্ভরশীল, কিন্তু এটি নিজেই AMD মডিউল নয়। আপনি shim ব্যবহার করে এটিকে AMD মডিউলের মতো ব্যবহার করতে পারেন।

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'bootstrap': 'https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min'
  },
  shim: {
    'bootstrap': {
      deps: ['jquery'],  // Bootstrap depends on jQuery
      exports: 'bootstrap' // Expose bootstrap globally
    }
  }
});

ব্যাখ্যা:

  • এখানে, bootstrap মডিউলটি jquery এর ওপর নির্ভরশীল এবং Bootstrap একটি গ্লোবাল ভ্যারিয়েবল হিসেবে এক্সপোজ হয়।

Shim Configurations এর সুবিধা:

  1. Non-AMD লাইব্রেরি এক্সপোজ করা:
    • আপনি non-AMD লাইব্রেরিগুলোকে AMD মডিউল হিসেবে ব্যবহার করতে পারবেন, যেমন jQuery, Backbone.js, Bootstrap ইত্যাদি।
  2. ডিপেনডেন্সি পরিচালনা:
    • shim কনফিগারেশন ব্যবহার করে আপনি স্ক্রিপ্টগুলোর নির্ভরতা সঠিকভাবে পরিচালনা করতে পারবেন এবং ডিপেনডেন্সি মিসিং সমস্যা থেকে মুক্তি পাবেন।
  3. গ্লোবাল ভ্যারিয়েবল এক্সপোজ করা:
    • যেসব স্ক্রিপ্ট গ্লোবাল ভ্যারিয়েবল এক্সপোজ করে, সেগুলির জন্য exports অপশন ব্যবহার করে গ্লোবাল এক্সপোজিশন নিশ্চিত করতে পারবেন।

সারসংক্ষেপ:

Shim Configurations ব্যবহার করে আপনি non-AMD লাইব্রেরিগুলিকে AMD মডিউলের মতো আচরণ করাতে পারবেন, এবং তাদের নির্ভরশীলতা, এক্সপোর্ট এবং ডিপেনডেন্সি সঠিকভাবে পরিচালনা করতে পারবেন। shim অপশনটি এমন স্ক্রিপ্টগুলির জন্য ব্যবহৃত হয় যা সাধারণত AMD প্যাটার্ন অনুসরণ করে না এবং তাদেরকে define() ফাংশনের সাথে সামঞ্জস্যপূর্ণ করে তোলে।

Content added By

RequireJS মূলত AMD (Asynchronous Module Definition) মডিউল সিস্টেমের উপর ভিত্তি করে কাজ করে, তবে এটি Non-AMD স্ক্রিপ্ট বা সিস্টেমের সাথে কাজ করার জন্যও কিছু ফিচার প্রদান করে। অনেক সময় আপনার প্রকল্পে এমন স্ক্রিপ্ট থাকতে পারে যা AMD কম্প্যাটিবল নয়, অর্থাৎ তা define() বা require() ফাংশন ব্যবহার না করে কাজ করে। RequireJS এই ধরনের স্ক্রিপ্ট লোড করার জন্য shim কনফিগারেশন ব্যবহার করে, যা Non-AMD স্ক্রিপ্টের জন্য এক ধরনের ব্রিজ হিসেবে কাজ করে।

Non-AMD স্ক্রিপ্ট ব্যবস্থাপনা এবং লোড করার জন্য RequireJS এর shim কনফিগারেশন

Non-AMD স্ক্রিপ্ট সাধারণত জাভাস্ক্রিপ্ট ফাইল যা কোনও মডিউল সিস্টেম ব্যবহার করে না, যেমন jQuery, Backbone.js, Underscore.js ইত্যাদি। এই ধরনের স্ক্রিপ্টগুলি সাধারণত global অবজেক্টে ডিফাইন করা থাকে এবং তাদের মধ্যে ডিপেনডেন্সি ম্যানেজমেন্ট করতে আপনাকে অতিরিক্ত কনফিগারেশন করতে হয়।

RequireJS এর shim কনফিগারেশন ব্যবহার করে আপনি এই ধরনের স্ক্রিপ্টগুলির ডিপেনডেন্সি এবং এক্সপোর্ট সঠিকভাবে ম্যানেজ করতে পারেন।

1. Shim কনফিগারেশন কী?

shim কনফিগারেশন ব্যবহার করে আপনি Non-AMD স্ক্রিপ্টগুলির জন্য:

  • তাদের ডিপেনডেন্সি নির্ধারণ করতে পারেন
  • তাদের exports প্রদান করতে পারেন (যেটি তাদের global object এ কি এক্সপোর্ট করা হবে তা নির্দেশ করে)

2. Non-AMD স্ক্রিপ্টের জন্য shim কনফিগারেশন সেটআপ

উদাহরণ ১: jQuery এবং Backbone.js লোড করা

ধরা যাক, আপনার প্রজেক্টে jQuery এবং Backbone.js লাইব্রেরি রয়েছে, কিন্তু এই স্ক্রিপ্টগুলো AMD মডিউল নয়। আপনি RequireJS এর মাধ্যমে এগুলো লোড করতে চাইলে, shim কনফিগারেশন ব্যবহার করতে হবে।

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'backbone': 'libs/backbone.min'
  },
  shim: {
    'backbone': {
      deps: ['jquery'],   // Backbone.js jQuery এর উপর নির্ভরশীল
      exports: 'Backbone' // Backbone এর global এক্সপোর্ট নাম
    }
  }
});

require(['backbone'], function(Backbone) {
  console.log('Backbone Loaded');
});

ব্যাখ্যা:

  • paths: এখানে আপনি jquery এবং backbone এর পাথ কনফিগার করেছেন। Backbone.js এবং jQuery CDN এর মাধ্যমে লোড হচ্ছে।
  • shim: Backbone.js এর জন্য shim কনফিগারেশন ব্যবহার করা হয়েছে।
    • deps: Backbone মডিউলটি jQuery এর উপর নির্ভরশীল, তাই jQuery প্রথমে লোড হবে।
    • exports: Backbone.js এর গ্লোবাল এক্সপোর্ট Backbone নামক হবে। এইভাবে RequireJS জানবে যে Backbone মডিউলটি কী রিটার্ন করবে।

উদাহরণ ২: jQuery UI লোড করা

ধরা যাক, আপনি jQuery UI লোড করতে চান, যা jQuery এর উপর নির্ভরশীল।

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'jquery-ui': 'https://code.jquery.com/ui/1.12.1/jquery-ui.min'
  },
  shim: {
    'jquery-ui': {
      deps: ['jquery'],  // jQuery UI jQuery এর উপর নির্ভরশীল
      exports: '$.ui'     // jQuery UI এর global এক্সপোর্ট নাম
    }
  }
});

require(['jquery-ui'], function($) {
  console.log('jQuery UI Loaded');
});

এখানে:

  • deps: jquery-ui মডিউলটি jquery মডিউলের উপর নির্ভরশীল।
  • exports: $.ui গ্লোবাল এক্সপোর্ট যা jQuery UI লাইব্রেরি সরবরাহ করবে।

3. shim কনফিগারেশন এর প্রয়োজনীয়তা

যখন আপনি Non-AMD স্ক্রিপ্ট ব্যবহার করেন, তাদের মধ্যে সাধারণত global এক্সপোর্ট থাকে এবং তারা ডিপেনডেন্সি ম্যানেজমেন্টের জন্য define() বা require() ফাংশন ব্যবহার করে না। এর ফলে, আপনি যদি এই স্ক্রিপ্টগুলিকে AMD ফরম্যাটে লোড করতে চান, তবে shim কনফিগারেশন ব্যবহার করে তাদের ডিপেনডেন্সি এবং এক্সপোর্ট ম্যানেজ করতে হয়।

4. shim এর মাধ্যমে বিভিন্ন ধরনের স্ক্রিপ্ট লোড করা

আপনি shim ব্যবহার করে যেকোনো Non-AMD স্ক্রিপ্ট মডিউল লোড করতে পারেন, যেমন:

  • External libraries: যেমন jQuery, Bootstrap, AngularJS, React (যদিও React এখন AMD সমর্থন করে) ইত্যাদি।
  • Custom libraries: যদি আপনি নিজে কোনো স্ক্রিপ্ট তৈরি করে থাকেন এবং সেটি AMD ফরম্যাটে না থাকে, তবে আপনি সেটি shim এর মাধ্যমে লোড করতে পারেন।

5. shim কনফিগারেশন এর পূর্ণ উদাহরণ

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'underscore': 'libs/underscore.min',
    'backbone': 'libs/backbone.min'
  },
  shim: {
    'underscore': {
      exports: '_'  // Underscore.js এর global এক্সপোর্ট
    },
    'backbone': {
      deps: ['jquery', 'underscore'], // Backbone এর জন্য jQuery এবং Underscore নির্ভরশীল
      exports: 'Backbone'  // Backbone.js এর global এক্সপোর্ট
    }
  }
});

require(['backbone'], function(Backbone) {
  console.log('Backbone Loaded');
});

এখানে:

  • underscore এবং backbone মডিউলগুলির জন্য shim কনফিগারেশন দেওয়া হয়েছে।
  • exports এর মাধ্যমে আমরা জানাচ্ছি যে এই মডিউলগুলির গ্লোবাল এক্সপোর্ট কী হবে (_ এবং Backbone)।

সারসংক্ষেপ:

RequireJS Non-AMD স্ক্রিপ্ট লোড এবং ম্যানেজ করতে shim কনফিগারেশন ব্যবহার করে। এটি স্ক্রিপ্টগুলির ডিপেনডেন্সি এবং এক্সপোর্ট সঠিকভাবে ম্যানেজ করে, যাতে আপনি সেগুলোকে AMD স্টাইলে লোড এবং ব্যবহার করতে পারেন। shim কনফিগারেশন নিশ্চিত করে যে প্রতিটি মডিউল তার নির্ভরশীলতা ঠিকমতো লোড হয়ে পরে সঠিকভাবে কাজ করবে।

Content added By

RequireJS সাধারণত AMD (Asynchronous Module Definition) মডিউল লোডিং সিস্টেমে কাজ করে, তবে অনেক পুরনো বা Non-AMD লাইব্রেরি, যেমন jQuery, Bootstrap, ইত্যাদি, AMD এর মতো মডিউল সিস্টেম অনুসরণ করে না। এমন পরিস্থিতিতে, RequireJS-এ এই ধরনের লাইব্রেরি ইন্টিগ্রেট করতে কিছু অতিরিক্ত কৌশল ব্যবহার করতে হয়।

নিচে Non-AMD লাইব্রেরি যেমন jQuery, Bootstrap ইত্যাদির RequireJS-এ ইন্টিগ্রেশন এর জন্য কৌশল এবং উদাহরণ দেওয়া হলো।

1. jQuery এবং Bootstrap এর RequireJS-এ ইন্টিগ্রেশন

jQuery ইন্টিগ্রেশন:

যেহেতু jQuery একটি Non-AMD লাইব্রেরি, এটি সাধারণত RequireJS এর মধ্যে direct script tag দিয়ে লোড করা হয়। কিন্তু, আপনি RequireJS এর shim কনফিগারেশন ব্যবহার করে jQuery মডিউলকে AMD মডিউল হিসেবে লোড করতে পারবেন।

jQuery এর জন্য shim কনফিগারেশন ব্যবহার:
require.config({
  paths: {
    'jquery': 'https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min'  // jQuery এর পাথ
  },
  shim: {
    'jquery': {
      exports: '$'  // jQuery global export করে $ নামে
    }
  }
});

require(['jquery'], function($) {
  // jQuery এখনো লোড হয়ে গেছে
  $(document).ready(function() {
    console.log("jQuery is loaded!");
  });
});
  • shim কনফিগারেশন: এটি Non-AMD লাইব্রেরি (যেমন jQuery) কে AMD-এ রূপান্তর করতে সাহায্য করে।
  • exports: '$': এটি নির্দেশ করে যে jQuery $ নামে একটি গ্লোবাল এক্সপোর্ট করবে, যা অন্য মডিউলগুলির জন্য অ্যাক্সেসযোগ্য হবে।

Bootstrap ইন্টিগ্রেশন:

Bootstrap নিজে Non-AMD লাইব্রেরি হলেও, আপনি jQuery এর সাথে এটি একত্রে ব্যবহার করতে পারেন। Bootstrap সাধারণত jQuery-এর উপর নির্ভরশীল, তাই RequireJS-এ Bootstrap কে ইন্টিগ্রেট করতে jQuery আগে লোড করতে হবে।

Bootstrap এর জন্য shim কনফিগারেশন ব্যবহার:
require.config({
  paths: {
    'jquery': 'https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min',
    'bootstrap': 'https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min'
  },
  shim: {
    'bootstrap': {
      deps: ['jquery'],  // Bootstrap এর জন্য jQuery ডিপেনডেন্সি
      exports: 'bootstrap'  // Bootstrap গ্লোবালি এক্সপোর্ট হবে
    },
    'jquery': {
      exports: '$'  // jQuery গ্লোবালি $ হিসেবে এক্সপোর্ট হবে
    }
  }
});

require(['jquery', 'bootstrap'], function($, bootstrap) {
  // jQuery এবং Bootstrap এখনো লোড হয়ে গেছে
  console.log("jQuery and Bootstrap are loaded!");
});
  • deps: ['jquery']: এটি নিশ্চিত করে যে Bootstrap মডিউলটি লোড হওয়ার আগে jQuery প্রথমে লোড হবে।
  • exports: 'bootstrap': এটি নির্দেশ করে যে Bootstrap গ্লোবাল এক্সপোর্ট হিসেবে কাজ করবে।

2. Non-AMD লাইব্রেরি ইন্টিগ্রেশন (General Approach)

এমন লাইব্রেরি যা Non-AMD ফর্ম্যাটে আসে, সেগুলো shim কনফিগারেশন ব্যবহার করে AMD মডিউলে রূপান্তর করা যায়। shim কনফিগারেশন দিয়ে আপনি নির্দিষ্ট লাইব্রেরির ডিপেনডেন্সি, এক্সপোর্টস এবং অন্যান্য বৈশিষ্ট্য কনফিগার করতে পারেন।

General shim Configuration Example:

require.config({
  paths: {
    'someNonAMDLibrary': 'path/to/someNonAMDLibrary'
  },
  shim: {
    'someNonAMDLibrary': {
      deps: ['dependency1', 'dependency2'],  // Dependencies
      exports: 'SomeGlobalObject'  // Global object exported by the library
    }
  }
});

require(['someNonAMDLibrary'], function(SomeGlobalObject) {
  console.log('Library is now available:', SomeGlobalObject);
});
  • deps: আপনি এখানে লাইব্রেরির জন্য যেসব ডিপেনডেন্সি প্রয়োজন তা উল্লেখ করতে পারেন।
  • exports: লাইব্রেরি যদি একটি গ্লোবাল অবজেক্ট এক্সপোর্ট করে, তবে আপনি এটি উল্লেখ করতে পারেন, যাতে তা RequireJS এর মধ্যে অ্যাক্সেসযোগ্য হয়।

3. shim কনফিগারেশন এর সাধারণ প্রয়োগ

যখন আপনি কোনো Non-AMD লাইব্রেরি (যেমন jQuery, Bootstrap, অথবা অন্য যেকোনো থার্ড-পার্টি স্ক্রিপ্ট) লোড করতে চান, তখন আপনি নিচের মতো কনফিগারেশন ব্যবহার করতে পারেন:

require.config({
  paths: {
    'jquery': 'https://code.jquery.com/jquery-3.6.0.min',
    'underscore': 'https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.9.1/underscore-min',
    'bootstrap': 'https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min'
  },
  shim: {
    'underscore': {
      exports: '_' // Exports the underscore library to the global `_` object
    },
    'bootstrap': {
      deps: ['jquery'], // Ensure jQuery is loaded before Bootstrap
      exports: 'Bootstrap' // Bootstrap global export
    }
  }
});

require(['jquery', 'underscore', 'bootstrap'], function($, _, Bootstrap) {
  console.log('All libraries are loaded!');
});

4. Non-AMD স্ক্রিপ্ট লোড করার পদ্ধতি

RequireJS এর shim কনফিগারেশন দিয়ে Non-AMD লাইব্রেরিগুলিকে AMD মডিউল হিসেবে ইন্টিগ্রেট করা হয়, এবং তাদের নির্ভরশীলতা এবং এক্সপোর্টগুলি পরিচালনা করা হয়। এইভাবে আপনি jQuery, Bootstrap, অথবা অন্য যেকোনো লাইব্রেরি অ্যাসিঙ্ক্রোনাসভাবে লোড করতে এবং ব্যবহারের জন্য প্রস্তুত করতে পারেন।

সারসংক্ষেপ:

RequireJS-এ Non-AMD লাইব্রেরি যেমন jQuery এবং Bootstrap ইন্টিগ্রেট করতে, shim কনফিগারেশন ব্যবহার করা হয়। এই কনফিগারেশন লাইব্রেরির ডিপেনডেন্সি ম্যানেজ করতে এবং এক্সপোর্টস ঠিকভাবে পরিচালনা করতে সাহায্য করে। RequireJS আপনাকে Non-AMD স্ক্রিপ্টগুলোকে AMD মডিউল হিসেবে ব্যবহার করার সুযোগ দেয়, যাতে কোডটি আরও মডুলার এবং রক্ষণাবেক্ষণযোগ্য হয়ে ওঠে।

Content added By

RequireJS একটি মডিউল লোডার যা AMD (Asynchronous Module Definition) স্ট্যান্ডার্ড অনুসরণ করে, তবে অনেক পুরনো লাইব্রেরি বা স্ক্রিপ্ট Non-AMD ফরম্যাটে লেখা হয়ে থাকে (যেমন CommonJS বা সাধারণ স্ক্রিপ্ট ফাইল)। এ ধরনের লাইব্রেরি এবং স্ক্রিপ্টগুলির সাথে কাজ করতে গেলে AMD এবং Non-AMD এর মধ্যে compatibility নিশ্চিত করতে কিছু পদক্ষেপ নিতে হয়।

AMD এবং Non-AMD এর মধ্যে Compatibility

RequireJS এ, AMD এবং Non-AMD কোডের মধ্যে compatibility বজায় রাখার জন্য shim configuration এবং exports অপশন ব্যবহার করা যেতে পারে। এর মাধ্যমে আপনি Non-AMD স্ক্রিপ্টগুলিকে AMD মডিউল হিসেবে রূপান্তর করতে পারেন এবং তার সাথেই ব্যবহার করতে পারেন।

১. Shim Configuration

Shim configuration ব্যবহার করে আপনি Non-AMD স্ক্রিপ্টগুলি AMD স্টাইলে রূপান্তর করতে পারেন। এর মাধ্যমে আপনি সরাসরি Non-AMD স্ক্রিপ্টের dependencies এবং exports ফাংশনালিটি কনফিগার করতে পারেন।

Shim Configuration Syntax:

require.config({
  shim: {
    'non-amd-library': {
      deps: ['dependency1', 'dependency2'], // dependencies
      exports: 'NonAMDLibrary' // Global object exported by the non-AMD library
    }
  }
});

এটি কীভাবে কাজ করে?

  • deps: Non-AMD লাইব্রেরির জন্য নির্ভরশীল অন্যান্য মডিউলগুলি আগে লোড হবে।
  • exports: Non-AMD লাইব্রেরি একটি গ্লোবাল অবজেক্ট তৈরি করে (যেমন window.NonAMDLibrary) এবং আপনাকে তা AMD মডিউল হিসেবে ব্যবহারের জন্য exports করতে হবে।

এটি কিভাবে ব্যবহার করবেন:

ধরা যাক, আপনি একটি Non-AMD লাইব্রেরি যেমন jQuery ব্যবহার করছেন, যা গ্লোবাল window.$ অথবা window.jQuery এ এক্সপোর্ট করে। এই ক্ষেত্রে আপনি shim configuration ব্যবহার করে jQuery-কে AMD ফরম্যাটে ইনক্লুড এবং ব্যবহারের জন্য কনফিগার করতে পারেন।

require.config({
  paths: {
    'jquery': 'libs/jquery-3.6.0.min' // Path to the jQuery script
  },
  shim: {
    'jquery': {
      exports: '$'  // Exports the global $ object as the jQuery module
    }
  }
});

// Now you can use jQuery as an AMD module
require(['jquery'], function($) {
  console.log($);  // jQuery will work as expected
});

এখানে, shim কনফিগারেশনের মাধ্যমে আপনি jQuery-কে AMD module হিসেবে ব্যবহার করছেন, যদিও এটি Non-AMD (গ্লোবাল স্ক্রিপ্ট) হিসেবে তৈরি হয়েছিল।

২. AMD to Non-AMD Compatibility with requirejs

আপনি যদি একটি AMD স্টাইল মডিউলকে Non-AMD স্ক্রিপ্ট হিসেবে ব্যবহার করতে চান (যেমন একটি পুরনো লাইব্রেরি), তবে আপনাকে requirejs অথবা define এর মাধ্যমে সেই মডিউলকে ইমপোর্ট করতে হবে।

Non-AMD library usage in AMD application:

এখানে আপনি দেখতে পারেন কিভাবে একটি AMD মডিউলকে Non-AMD অ্যাপ্লিকেশন থেকে লোড করা যায়।

// Non-AMD example using RequireJS
define(['require', 'jquery'], function(require, $) {
  console.log('Using AMD module in a Non-AMD context');
});

এটি কিভাবে কাজ করে?

এখানে, আমরা Non-AMD ফরম্যাটে jQuery ইনপোর্ট করছি কিন্তু তা AMD ফরম্যাটে ব্যবহার করছি। require এবং define ফাংশনালিটি ব্যবহার করে আপনি AMD এবং Non-AMD এর মধ্যে ব্রিজ তৈরি করতে পারেন।

৩. Converting Non-AMD Scripts to AMD

অনেক পুরনো স্ক্রিপ্ট যেমন libraries বা plugins যেগুলো Non-AMD ফরম্যাটে লেখা, সেগুলিকে AMD মডিউলে রূপান্তর করতে shim কনফিগারেশন ব্যবহার করতে হয়। এতে আপনি সহজেই Non-AMD লাইব্রেরিকে আপনার অ্যাপ্লিকেশনে যোগ করতে পারবেন এবং ডিপেনডেন্সি ও এক্সপোর্ট সেটআপ করতে পারবেন।

Non-AMD Script Example (External library)

<script src="path/to/non-amd-library.js"></script>

এটি সাধারণভাবে Non-AMD স্ক্রিপ্ট হিসেবে কাজ করবে। তবে RequireJS এর মাধ্যমে আপনি এটি AMD ফরম্যাটে রূপান্তর করতে পারেন।

Converting the Non-AMD script to AMD module:

require.config({
  shim: {
    'non-amd-lib': {
      deps: ['jquery'], // Dependent on jQuery
      exports: 'NonAMDLib'  // Exports the NonAMDLib global object
    }
  }
});

require(['non-amd-lib'], function(NonAMDLib) {
  console.log(NonAMDLib);  // You can now use it as an AMD module
});

এখানে, shim কনফিগারেশনের মাধ্যমে Non-AMD লাইব্রেরি NonAMDLib কে AMD মডিউলে রূপান্তর করা হয়েছে।

৪. Handling Global Variables in Non-AMD Scripts

অনেক পুরনো স্ক্রিপ্ট গ্লোবাল ভ্যারিয়েবল তৈরি করে থাকে, যেগুলো Non-AMD স্ক্রিপ্ট হিসেবে ব্যবহার হয়। এসব স্ক্রিপ্টগুলোর ক্ষেত্রে আপনি global variables কে AMD মডিউল হিসেবে ইনপোর্ট করতে পারবেন shim কনফিগারেশন ব্যবহারের মাধ্যমে।

Example with Global Variables:

require.config({
  shim: {
    'oldLibrary': {
      exports: 'GlobalLibraryObject' // Exports a global object
    }
  }
});

require(['oldLibrary'], function(GlobalLibraryObject) {
  console.log(GlobalLibraryObject);  // You can now use it as an AMD module
});
  1. AMD এবং Non-AMD স্ক্রিপ্টগুলির মধ্যে compatibility নিশ্চিত করতে RequireJS এর shim configuration ব্যবহৃত হয়। এর মাধ্যমে আপনি Non-AMD স্ক্রিপ্টগুলিকে AMD modules হিসেবে ব্যবহৃত করতে পারেন।
  2. Shim configuration সাহায্যে আপনি Non-AMD স্ক্রিপ্টগুলির dependencies এবং exports সঠিকভাবে কনফিগার করে তাদের AMD মডিউল হিসেবে ব্যবহার করতে পারেন।
  3. RequireJS আপনাকে AMD এবং Non-AMD স্ক্রিপ্টের মধ্যে compatibility বজায় রেখে কার্যকরী কোড তৈরি করতে সহায়তা করে।
Content added By
Promotion

Are you sure to start over?

Loading...