8.20 Global This

 

জাভাস্ক্রিপ্ট language টি বিভিন্ন environment এ ক্রমবর্ধমানভাবে ব্যবহৃত হচ্ছে। ওয়েব ব্রাউজার ছাড়াও বিভিন্ন হোস্ট যেমন – servers, smartphones, and বিভিন্ন robotic hardware এ আমরা javascript code run করতে পারি। প্রতিটি environment এরই নিজস্ব কিছু object model আছে এবং global object কে access করার জন্য তারা বিভিন্ন syntax provide করে থাকে। উদাহরণস্বরুপ বলা যায় যে – ওয়েব browser এ global object কে আমরা window, self, বা frames এর মাধ্যমে access করে থাকি। আবার node.js এ global object কে access করার জন্য js এ আমাদের window ব্যবহার করতে হয়। তেমনিভাবে Web Workers এ শুধুমাত্র slef দ্বারা global object কে access করা যায়।
এখন আমরা যদি কোন cross platform এর জন্য javscript code লিখতে চাই, তবে আমাদের বারবার if/else দ্বারা check করে global object বের করা লাগবে, যা যথেস্ট কষ্টসাধ্য। es2020 এর আগে আমাদের ঠিক এভাবেই কাজ করতে হতো।
কিন্তু es2020 globalThis কে introduce করার পর, আমাদের এই সমস্যা থেকে অনেকটাই মুক্তি মিলেছে। globalThis একটি standard global property কে define করার মাধ্যমে বিভিন্ন global object কে access করার পদ্ধতিসমূহকে একত্রিত করে। ফলে অতিরিক্ত কোন check/test ছাড়াই জাভাস্ক্রিপ্ট কোডটি বিভিন্ন environment এ কাজ করতে পারে। কারণ প্রতিটি environment এ globalThis সরাসরি সেই environment এর global object কে রেফার করে। আর যখন আমাদের লিখা জাভাস্ক্রিপ্ট কোড টি specifically কোন environment এ use হবে তা নিয়ে surity না থাকে, তখনই আমরা আমাদের জাভাক্রিপ্ট code এ global object কে access করার জন্য globalThis ব্যবহার করব।

Example :

Without globalThis

1. Window

Window property এর মাধ্যমে কারেন্ট document এর global object কে browser environment এ refer করা হয়।

var a = [10, 20];
 
console.log(window.a);          // → [10, 20]
console.log(a === window.a);    // → true

 

2. Self

Web workers এ global object কে access করার জন্য, self property ব্যবহার করা হয়।

// a web worker
console.log(self);    // => DedicatedWorkerGlobalScope {...}
 
var a = 10;
 
console.log(self.a);          // → 10
console.log(a === self.a);    // → true

 

3. Frames
ব্রাউসারে global object access করার জন্য অন্য আরেকটি মাধ্যম হল frame.

// browser environment
console.log(frames);    // => Window {...}

 

4. This
ব্রাউসারে global object কে access করার জন্য জাভাস্ক্রিপ্ট প্রোগ্রামের টপ লেভেলে this keyword ব্যবহার করা হয়।

this.foo = 123;
console.log(this.foo === window.foo);    // => true

With globalThis

// browser environment
console.log(globalThis);    // => Window {...}
 
// node.js environment
console.log(globalThis);    // => Object [global] {...}
 
// web worker environment
console.log(globalThis);    // => DedicatedWorkerGlobalScope {...}