ওয়ার্ডপ্রেস থিম ডেভেলাপমেন্ট করতে গেলে প্রথমে যেই সমস্যা হয় সেটা হইতেছে ওয়ার্ডপ্রেসে জেকোয়েরীর ব্যাকডেটেড ভার্সন দেয়া। নানান সমস্যার এটাও একটা মেজর সমস্যা বটে। মোটামুটি সব ফ্রন্টেন্ড ফ্রেমওয়ার্কই ডিপেন্ডেসিতে জেকোয়েরি লেটেস্ট ভার্সন ইউজ করে। এটা মোটামুটি কাটিয়ে উঠা গেলেও একটা জায়গায় প্রবলেম থেকেই যায়। সেটা হচ্ছে ব্রাউজারের কনসোলে
TypeError: $ is not a
function
আহা কনসোলে এমন ম্যাসেজ দেখার পরে কার ইচ্ছে করবে বেঁচে থাকতে বলেন? আপনি ইনস্পেক্ট করলেন নতুবা ভিউ সোর্স দিলেন, জেকোয়েরি পেলো কী না। সেখানেও দেখবেন মহামতি জেকোয়েরি লোড হয়ে বসে আছেন। কীয়েক্টাবস্তা বলেন তো।
গেলেন গুগলের কাছে, গুগল বলে দিবে, মিয়া $ সাইন বাদ দিয়া সেখানে লেখেন jQuery এবার গেলেন জাভাস্ক্রিপ্ট ফাইল এডিট করতে। সেখানে গিয়ে চৌক্ষে সরিষা ফুল দেখতে লাগলেন। সাহসে কোলাইতেছে না। এতো বড়ো ফাইল কেমনে কী করবেন। একবার ভাবলেন এক কমান্ড দিয়ে সব $ সাইন ধরে রিপ্লেস করাই যায়, কিন্তু সেটা করে এবার দেখলেন সবই ঠিক আছে কিন্তু কোড কাজ করতেছে না। কোনো এরর নাই কিন্তু এক্সপেক্টেড আউটপুটও নাই। এইবার কী করবেন? জাভাস্ক্রিপ্টের চৌদ্দগোষ্টি উদ্ধার করাই যায়, সাথে জেকোয়েরি আর ওয়ার্ডপ্রেস টিমের গুলারেও কী বলেন? ভাবা যায়! কতোটা খারাপ হইলে এমন একটা কিউট সমস্যায় ফেলে দিতে পারে এরা?
সে যাই হোক, এবার দেখি কতোভাবে সমাধান করা যায়।
মেথড ১
প্রথমে একটা ফাংশন ডিক্লেয়ার করে নিবেন আর সেটাতে প্যারামিটার হিসাবে $ সাইন বসিয়ে দিবেন। যেমন-
;(
function
($) {
$(window).on(
'load'
,
function
(){
// Code to Execute
});
$(document).ready(
function
(){
// Code to Execute
});
}(jQuery()));
আপাতত আপনার সমস্যা সমাধান হয়ে যাওয়ার কথা। যদি আপনি মড্যুলার কোড লিখে না থাকেন।
মেথড ২
যদি আপনার কোড মড্যুলার হয়ে থাকে, কিংবা কপি পেস্ট করেছেন কোথাও থেকে কিন্তু বেচারা মড্যুলার কোড লিখে বসে আছে। কোড এতক্ষণ কাজ করতেছিলো কিন্তু এখন আর কাজ করে না। এমন পরিস্থিতিতে কী করবেন? খেয়াল করবেন মড্যুলার কোড অবজেক্ট বেসড হয়। সেখানে পুরো অবজেক্টটা ধরে একটা ফাংশনে ঢুকিয়ে দেন। যেমন-
let
data = {
init :
function
(){
},
anotherthing :
function
(){
},
oneanotherthing :
function
(){
},
andanotherone :
function
(){
}
}
data.init();
যদি এমন কোড দেখতে পান তাহলে পুরোটারে ধইরা একটা ফাংশনের চিপায় ফালান আগে। যেমন-
function
my_function(my_value){
let
data = {
init:
function
() {
},
anotherthing:
function
() {
},
oneanotherthing:
function
() {
},
andanotherone:
function
() {
}
}
my_value = data.init();
return
my_value();
}
my_function();
এইবার ফাংশনের ভিতরে একটা ভ্যারিয়েবল কল করেন $ সাইন, আর সেটার ভ্যালু পাস করে দেন jQuery.noConflict(); মানে পুরোটা মিলে হবে
function
my_function(my_value){
let
$ = jQuery.noConflict();
let
data = {
init:
function
() {
},
anotherthing:
function
() {
},
oneanotherthing:
function
() {
},
andanotherone:
function
() {
}
}
my_value = data.init();
return
my_value();
}
my_function();
জেকোয়েরি লেটেস্ট ভার্সন ব্যবহার করা
এইবার আসেন কেমনে জেকোয়েরীর লেটেস্ট ভার্সন ইউজানো যায় সেটা দেখা যাক। ধরি আপনার থিমের /assets/vendor/jquery এই ফোল্ডারে আপনার জেকোয়েরি লেটেস্ট ভার্সনটা রাখা আছে। তো আমরা এবার এটাকে ফ্রন্টেন্ডে পাইয়ে দেব। তারজন্য কষ্টকরে আপনার থিমের ফাংশন ফাইলটা একটু কষ্ট করে অপেন করে নিতে হবে। এবং সেখান থেকে প্রথমে জেকোয়েরী ফাইলটা ডি-রেজিস্টার করে নিতে হবে।
wp_deregister_script(
'jquery'
);
এবার আপনার লোকাল ভার্সনটা রেজিস্টার করে নিতে হবে।
wp_register_script(
'jquery'
, get_template_directory_uri().
"/assets/vendor/jquery/jquery-3.3.1.min.js"
,
array
(),
'3.1.1'
, true);
এবার বলে দিন আপনার থিমে নতুন জেকোয়েরিটা লাগবে। মানে এনকিউ করে নিন। এভাবে
wp_enqueue_script(
'jquery'
);
ব্যস হয়ে গেল লেটেস্ট ভার্সনের জেকোয়েরি। তবে ভাববেন না $ ক্যাচাল থেকে এইটার মাধ্যমে মুক্তি পাইয়া যাইবেন। ওয়ার্ডপ্রেসে অবশ্যই আপনাকে $ সাইনের পরিবর্তে jQuery ব্যবহার করা লাগবে। নতুবা ট্রিক্স কাজে লাগাতে হবে।
অবশ্যই জেকোয়েরী মাইগ্রেটের লেটেস্ট ভার্সনটা ব্যবহার করবেন।
লেটেস্ট ভার্সনের জেকোয়েরি মাইগ্রেট পাবেন এখানে
আশাকরছি ভুলত্রুটি ক্ষমা সুন্দর দৃষ্টিতে দেখবেন, এবং শুধরে দিবেন। ধন্যবাদ।
আমি হাসান মিসবাহ। বিশ্বের সর্ববৃহৎ বিজ্ঞান ও প্রযুক্তির সৌশল নেটওয়ার্ক - টেকটিউনস এ আমি 9 বছর 3 মাস যাবৎ যুক্ত আছি। টেকটিউনস আমি এ পর্যন্ত 1 টি টিউন ও 0 টি টিউমেন্ট করেছি। টেকটিউনসে আমার 2 ফলোয়ার আছে এবং আমি টেকটিউনসে 0 টিউনারকে ফলো করি।
Front-End Developer, WordPress Fanatic, Linux Freak, Tech addicted