JavaScript ও Web Development এর Eco System গভিরভাবে জানার জন্য ও ইন্টারভিউ জিজ্ঞাসা করার মত গুরুত্বপূর্ণ সব প্রশ্ন ও উত্তর সমূহ একত্রে । আশা করি প্রতিটি Developer উপকৃত হবেন ।
এই রিপোটি Learn With Sumit , Anisul Islam , Stack Learner সব অন্য সকল বাংলাদেশী প্রোগ্রামিং রিলেটেড কন্টেন্ট ক্রিয়েটর ও লেখকদের উৎসর্গ করা হল ।
-
কোনো সাজেসন্স,রিকুয়েস্ট থাকলেঃ Issue ক্রিয়েট করুন
-
কোনো প্রশ্ন না বুঝলে বা বিস্তারিত জানতে চাইলেঃ Discussion এ জিজ্ঞাসা করুন ।
-
Contribute করতে চাইলেঃ Contributions Guideline পড়ুন ।
১. Local storage ও session এর মধ্যে পার্থক্য কি ?
পার্থক্য | Local Storage | Session Storage |
---|---|---|
স্থায়ীত্ব | মা্যানুয়ালি বা প্রোগ্রামিক্যালি ব্রাউজার ডাটা ক্লিয়ার না করা পর্যন্ত | ট্যাব ক্লোস করার সাথে সাথে |
এভাইলেবল | সকল window তেই | নির্দিষ্ট ট্যাবেই |
উপযোগী | দীর্ঘ সময় ডাটা রাখায় | আল্প সময় ডাটা রাখায় |
২. DOM ও BOM এর মধ্যে পার্থক্য কি ?
BOM ও DOM ব্রাউজারের JavaScript এর Window Object এর উপাদান । ব্রাউজারে সকল কিছু window নামের একটা master object এর থেকে একসেস করা যায়
BOM ও DOM এর মধ্যে পার্থক্য হলোঃ
বিষয় | DOM | BOM |
---|---|---|
পূর্ননাম | Document Object Model | Browser Object Model |
ব্যখ্যা | HTML ও XML documents যার মাধ্যমে হোস্ট এনভাইরমেন্ট এর স্ট্রাকচার | ব্রাউজার স্পেসিফিক ফাংশনালিটি |
উপাদান | Elements, Attributes, Text, etc. | Window, Screen, Location, History, Navigator, etc. |
নিয়ন্ত্রনকারী | W3C | প্রতিটি ব্রাউজারে ভিন্ন ভিন্নভাবে ইম্প্লিমেন্ট করে |
৩. Pure Function কাকে বলে ?
Computer Science এর ভাষায় যে সকল function ইন্টার্নাল লজিক নিয়ে থাকে ও একই Input এর জন্য একই Output দিয়ে থাকে তাকে Pure Function বলে ।
এর ২টা বৈশিষ্ট থাকে
- নিজের বিজনেস লজিক নিয়ে কনসার্ন ।
- Same Input এর জন্য Same output দিয়ে থাকে ।
Pure Function এর উদাহরণঃ
এখানে pureFn কে Input হিসেবে যতবারই ২ দেয়া হবে এটি প্রতিবার ৪ রিটার্ন করবে ।
এখানে Pure function নীতি ২টি সঠিকভাবে ফলো করা হয়েছে ।
১. প্রতিবার same input এর জন্য same output দিবে ।
২. বাহিরের কোনো প্রকার স্টেট বা কিছু প্ররিরর্তন করে নাই
অপরদিকে,
impureFn এর ক্ষেত্রে Pure function নীতি ২টি সঠিকভাবে ফলো করা হয়নি ।
১. প্রতিবার same input দিলেও আলাদা আলাদা output দিচ্ছে ।
২. এটি বাহিরের count variable পরিবর্তন করছে, অর্থাৎ শুধুমাত্র নিজের লজিক নিয়ে কনসার্ন না , function টি নিজের body এর বাহিরের কিছু পরিবর্তন করে ফেলেছে ।
তাই এটি pure function না ।
৫. falsy ও nullish ভ্যালু এর মধ্যে পার্থক্য কি ?
Falsy value বলতে 0, "", null, undefined, NaN, false কে বুঝায় এবং nullish value বলতে null, undefined কে বুঝায় ।
nullish value মুলত falsy value এর সাবসেট ।
- falsy value এর জন্য || দিয়ে চেক করা যায়
- nullish value ডিটেক্ট করতে ?? ব্যবহার করা হয়
৬. Shallow Copy ও Deep Copy বলতে কি বুঝায়?
কোনো Object বা Array ১ লেভেল ডিপ কপি করতে গেলে তাকে Shallow Copy বলে । আর ২ লেভেল বা ততোধিক ডিপ কপি করতে গেলে তাকে Deep Copy বলে ।
১. Shallow Copy
এখানে, original array কে Spread Oparetor দিয়ে কপি করা হয় । যেহেতু origianl array এর মাঝে অবজেক্ট আছে তাই এখানে অবজেক্ট এর ক্ষেত্রে একই রেফারেন্স দিয়ে কপি হয়েছে । তাই যখন আমরা original array এর অবজেক্ট এর কোনো প্রপার্টি চেঞ্জ করবো তখন কপি করা array এর অবজেক্ট এর কোনো প্রপার্টি চেঞ্জ হয়ে যাবে ।
২. Deep Copy
এখানে, original object কে Spread Oparetor দিয়ে কপি করা হয় এবং তার পাশাপাশি এর ভিতরের Object কেউ আবার Spread Oparetor দিয়ে কপি করা হয়েছে । তাই এডি ২ লেভেল নেস্টেড হবার পরো সম্পুর্ন Deeply Copy হয়ে
Tips: অনেক লেভেলের ডিপ কোনো Object/Array যদি Immutadly পরিবর্তন
৭. Deep Copy এর ক্ষেত্রে JSON.stringify ও পরে আবার JSON.parse করে করলে এই পদ্ধতি কি ব্যবহার করা উচিত?
যেমনঃ
কারনঃ
-
যদি কোনো
Object
এর মধ্যে কোনোfuntion
থাকে তাহলে সেটিJSON.stringify
করলে সেটিString
হয়ে যায় । এবং সেটি পরে আবারJSON.parse
করলে সেটিString
থেকে অবজেক্ট হয়ে যায় । কিন্তু সেটিfuntion
হওয়া সত্ত্বেও সেটিfuntion
হিসেবে কাজ করবে না । কারন সেটিString
হয়ে গেছে । তাই এই পদ্ধতি ব্যবহার করা উচিত না । -
Object
হলোJavaScript
এর বিশেষ ডাটা টাইপ , এক্ষেত্রে এর ফলে এটিString
হয়ে যাবে এবং সেটি পরে আবারObject
হিসেবে কাজ করবে না অনেক ক্ষেত্রে কারন এর Prototype কে সেটি হারিয়ে যাবে ।
৮. Event Propagation ও Event Delations কাকে বলে?
JavaScript-এ Event Propagation হলো একটি ইভেন্ট হ্যান্ডলিং প্রক্রিয়া যা তিনটি ফেজে ঘটে: Capturing Phase, Target Phase, এবং Bubbling Phase. এই তিনটি ফেজে ঘটে একটি ইভেন্ট হ্যান্ডলিং প্রক্রিয়া।
প্যারেন্ট এলিমেন্ট এর উপর একটি ইভেন্ট হ্যান্ডলার সেট করে এবং এই ইভেন্ট হ্যান্ডলার এর মাধ্যমে চাইল্ড এলিমেন্ট এর উপর ইভেন্ট হ্যান্ডলার সেট করা হয় তাকে Event Delations বলে ।
৯. Event Bubbling বনাম Event Delegations এর মধ্যে পার্থক্য কি?
Ans:১০. event.target ও event.currentTarget ও this.target এর মধ্যে পার্থক্য কী ?
Ans:১১. Single Responsible principal কাকে বলে?
Ans:১২. primitive ও non-primitive data types এর মধ্যে পার্থক্য কি? উভয়ের একটী করে উদাহরণ দেও
Ans:
১৩. JavaScript এ null and Undefined এর মধ্যে পার্থক্য কি ?
- নাল এর সাধারণ ব্যবহার একটি ফাংশন প্যারামিটার হিসাবে, এর অর্থ হল যে ফাংশন প্যারামিটার কোনও অবজেক্ট নয়
function myFn(obj) {
if (null == obj) {
// code
}
}
- অবজেক্ট প্রোটোটাইপ চেইন শেষ হিসাবে
Object.getPrototypeOf(Object.prototype);
- ভেরিয়েবলটি মুক্ত করার সময়, ভেরিয়েবলটিকে নাল বরাদ্দ করুন
let o = {
code: 'abc'
};
o = null;
- অপরিশোধিত এর সাধারণ ব্যবহার ভেরিয়েবল ঘোষিত হলেও নির্ধারিত নয়, ভেরিয়েবলের মান নির্ধারিত হয়
let o;
console.log(o); //undefined
- ফাংশনটি সরবরাহ করা উচিত যে পরামিতি কল করার সময় সরবরাহ করা হয় না, তারপরে প্যারামিটারের মান সরবরাহ করা হয় না
function myFn(o) {
console.log(o);
}
myFn(); //undefined
- বৈশিষ্ট্য যা অবজেক্টটি ধারণ করে না, মানটি সংজ্ঞায়িত
let o = {
code: 'abc'
};
console.log(o.name); //undefined
- যখন ফাংশনটি কোনও মান ফেরত দেয় না, এটি ডিফল্টরূপে অপরিবর্তিত থাকে
function myFn(obj) {
obj = 'a';
}
console.log(myFn()); //undefined
- নাল এবং undefined মধ্যে মিল বুলিয়ান রূপান্তরিত হলে মিথ্যা
console.log(Boolean(null)); // false
console.log(Boolean(undefined)); // false
নাল এবং undefined মধ্যে পার্থক্য কোনও সংখ্যায় রূপান্তরিত করার সময় ফলাফলটি পৃথক। নাল রূপান্তরকরণের ফলাফলটি 0 এর একটি বৈধ সংখ্যা মান এবং অপরিবর্তিত রূপান্তরের ফলাফল NaN হয়।
console.log(Number(null)); // 0
console.log(Number(undefined)); // NaN
- দুটি প্রকারের ধরন পৃথক, নাল প্রকারের অবজেক্ট এবং undefined প্রকারটি undefined।
console.log(typeof null); //object
console.log(typeof undefined); //undefined
- নাল এবং undefined তুলনা করুন নাল এবং undefined মধ্যে পার্থক্য করার জন্য, শুধুমাত্র একত্রিত হতে পারে cong একত্রিত করে, এটি দুটি প্রকারের সমান কিনা তা কঠোরভাবে তুলনা করবে।
console.log(Boolean(null == undefined)); // true
console.log(Boolean(null === undefined)); // false
- যোগফল
উপরের তুলনার পরে, আমাদের এই দুটি প্রকারের একটি স্পষ্ট ধারণা রয়েছে। সাধারণত যখন কোডটি লেখার সময় কোনও ভেরিয়েবলের একটি কার্যকর মান আছে কিনা তা আমরা বিচার করি তখন আমাদের দুজনের মধ্যে পার্থক্য করার প্রয়োজন হয় না, কেবল এটি বুলিয়ান টাইপ হিসাবে ব্যবহার করুন। কিন্তু যখন সম্পত্তিটি রয়েছে কিনা তা বিচার করার দরকার রয়েছে, আমাদের অবশ্যই টাইপটি কঠোরভাবে অবধারিত হিসাবে বিচার করতে হবে। অবশেষে, আমরা যদি একটি সংখ্যাসূচক মান পাস করি তবে অবশ্যই আমাদের প্রথমে রায় দিতে হবে, এবং সরাসরি একটি সংখ্যার ধরণের কাছে সরাসরি কাস্ট করা যাবে না, অন্যথায় নাল আমাদের অস্বাভাবিক ফলাফল পেতে বাধ্য করবে এবং অপরিবর্তিত সরাসরি অবৈধ ফলাফলের এনএএন গণনা করবে।
১৪. “ Array, Objects are mutable and string, number, Boolean are immutable “ এখানে mutable ও immutable দ্বারা কি বুঝানো হয়েছে ।
structuredClone কিভাবে কাজ করে ?
উঃকোনো একটী Object/Array কে Copy করতে হলে আমরা সাধারনত spread operator
বা Slice
ব্যবহার করি ।
যেমন
const skill = ['html', 'css', 'js'];
const cloneWithSlice = skill.slice();
const cloneSpread = [...skill];
কিন্তু যদি এটি আরও ভিতর আরও আবার কোনো Array/Object থাকত তখন সেই পার্ট নিজেদের আবার Spread দিয়ে করা প্রয়োজন Deep Copy করতে হলে ।
সহজে করতে আমরা সবাই Immer ব্যবহার করি যা একটি থার্ড পার্টি লাইব্রেরি । তবে বর্তমানে JavaScript এর বিল্ড ইন মেথদ আছে যা দিয়ে সহজে এটি করা যেতে পারে ।
const person = {
name: 'yeasin',
skill: ['typeScript', 'react']
};
const cloneWithStructured = structuredClone(person);
structuredClone(value);
structuredClone(value, options);
- এটি
ES2022
এর ফিচার তাই Node 17+ ও লেটেস্ট ব্রাউজারে সাপোর্ট করে শুধু । এক্ষেত্রেTypeScript
ব্যবহার করা হলেPerser
হিসেবে ব্যবহার করলে তখন এটি চাইলে আগের কোনোJS Verson
এ কনভার্ট করতে পারেন । - কোনো Object এর ক্ষেত্রে যদি
functions
থাকে তাহলে সেটির ক্ষেত্রে এটি Deep Copy করতে পারে না
১. any ও unknown এর মাঝে কি পার্থক্য কি ?
উঃ any এবং unknown উভয়ই TypeScript এর বিশেষ ধরনের টাইপ যা যে কোন variable এ ডিক্লেয়ার করা যায় , তবে এগুলি বিভিন্ন পরিস্থিতিতে ব্যবহার করা হয়:
-
any
: এই টাইপটি TypeScript Officially নিজেরা Recommend করে না । আপনি একটিany
টাইপে যে কোন মান নির্ধারণ করতে পারেন এবং কোন কম্পাইল সময় চেক ছাড়াই একটিany
টাইপের যে কোন বৈশিষ্ট্য অ্যাক্সেস করতে পারেন। এটি একটি ভেরিয়েবলের জন্য টাইপ চেকিং থেকে বাদ দেওয়ার মতো। -
unknown
: এই টাইপটিany
এর টাইপ-নিরাপদ বিকল্প । একটিunknown
টাইপে যে কোন মান নির্ধারণ করতে পারা যাবে , তবে আপনি কোন প্রকার টাইপ চেকিং না করলে একটিunknown
টাইপের যে কোন বৈশিষ্ট্য অ্যাক্সেস করতে, তাদের কল করতে / বানাতে করতে বা যে কোন expresstions ব্যবহার করতে পারবেন না (সমানতা চেক ছাড়া)।
১. React ও React-DOM কী? Website বানাতে ২টি আলাদা আলাদা ইন্সটল কেন করতে হয়?
React.js বলতে React ও React-DOM এর সমন্বয়ে একটা প্যাকেজ বুঝায় । যদিও ২টি আলাদা আলদা ভূমিকা রাখে ।
কিভাবে রিয়েক্ট কাজ করবে তার নির্ধারণ করে ।
React-DOM : Browser DOM এর একটি কপি বা শেডো ডম । মূলত React এ কোনো State পরিবর্তন হলে সেটি আগে Virtual-DOM (V-DOM) এ সেটি পরিবর্তন করে এবং তা ডিফিং বা রি- কনসালেসশন এলগোরিদম এর মাধ্যমে কোন component এ পরিবর্তন হয়েছে সেটি এই খসড়া ডমে পরিবর্তনের এরপর সারর্জিক্যাল অপারেশনের এর মাধ্যমে মূল ডমে পরিরর্তন করে
২. “React is Reactive ” এইটি দ্বারা React কি বুঝাতে চাচ্ছে?
৩. HTML,CSS এর রেন্ডারিং প্রোসেস কি কি?
Ans:৪. React State Update এর ক্ষেত্রে Batch Update বলতে কি বুঝায় ?
React এর কোনো State Update হলে তা সাথে সাথে মূল ডমে পরিবর্তন রিফলেক্ট করে না । অর্থাৎ, একত্রে পরিবর্তিত Sate সমূহ মূল ডমে Update করে ।
অনেক State একত্রে গ্রুপ আকারে update করাকেই Batch Update বলা হয় ।
৫. একাধিক DOM Operations এর ক্ষেত্রে Browser DOM কি আসলেই Slow? এক্ষেত্রে React কিভাবে DOM Operations Optimize করতে পারে ।
৬. ডিফিং বা রি- কনসালেসশন এলগোরিদম কাকে বলে? এবং React-DOM এটিকে কোন ক্ষেত্রে ব্যবহার করে ?
Application এর কোনো State পরিবর্তন হলে সেটি রেন্ডার ট্রি এর মাঝে খুজঝে তা মূল ডমে তা update করতে Diffing Algorithm ব্যবহার করা হয় ।৭. React Component এর নাম Capital Letter দিয়া শুরু কেন করতে হয় ?
Application এর function JSX রিটার্ন করতে পারে আবার অন্য যেকোনো ভ্যালু ।এক্ষেত্রে কোনটি JSX রিটার্ন করে এমন , অর্থাৎ কোনটী কোম্পোনেন্ট আর কোনটি সাধারণ function তার নির্নয়ের জন্য Component এর নামে Capital Letter দিয়ে শুরু করতে হয় ।
৮. “Props are Immutable” এর মানে কি ?
Immutable এর মানে অপরিবর্তনযোগ্য । সাধারনত modifications করা যাবে না এমন বুঝায় তবে Replace করা যাবে এমন । React Components এর Props হিসেবে একটি Object পেয়ে থাকি ।
যেমনঃ
**export const ReactComponentsDemo = (props) => {
const {name,id} = props;
return <div >index</div>;
};**
এই Props নামের Object a আমরা name, id পাচ্ছি ।
উদাহরণ হিসেবে এমন ধরতে পারি,
{
id: 1,
name: "yeasin",
}
এক্ষেত্রে কোনো কারনে বা কোনো event এর মাধ্যমে state পরিবর্তন হয়ে name = “md kawsar islam yeasin ” হয়ে গেল ।
এক্ষেত্রে, মনে হতে পারে update হবার কারনে name এর ভ্যালু পরিবর্তন করবে props এর, কিন্তু Props are immutable এর মানে বুঝায় এর কোনো ভ্যালু পরিবর্তন হলে পরবরর্তী রেন্ডারে আবার নতুন একট object পাবে । শুধুমাত্র updated value টা নয়
অর্থাৎ, এর পরবর্তীতে রি রেন্ডারে props হবে
{
id: 1,
name: "md kawar islam yeasin",
}
৯. JSX Components কে কেন কোনো প্যারেন্ট কম্পোনেন্ট বা Fragment দিয়ে Wrap করতে হয় ?
React Component JSX রিটার্ন করে । JSX মূলত একটি Object । প্রতিটী html tag Object হিসেবে শেষে কম্পাইল করে ।
আমরা জানি, কোনো function যেকোনো একটি মাত্র ভ্যালু রিটার্ন করে ।
তাই যদি একটি মাত্র element বা Fragment দিয়া Wrap করা থাকে তাহলে একটি Object এর মধ্যে বাকি সব element গুলো nested object আকারে থাকে ও তা রিটার্ন করে ।
১০. React এ List রেন্ডার করতে হলে Array.prototype.map ব্যবহার করা হয়। map ব্যাতিত forEach,for loop,while loop এর মাধ্যমেও কি List রেন্ডার করা যায় ? হ্যা হলে কিভাবে?
### List Render এর ক্ষেত্রে আমরা map ব্যবহার করে থাকি ।যেমনঃ
import { Fragment } from "react";
import { Component1, Component2, Component3 } from "./Components";
const App = () => {
const list = [Component1, Component2, Component3];
return (
<div>
<h1>App</h1>
{list.map((Val, index) => {
return (
<Fragment key={index}>
<Val /> {/* প্রতিটি JSX Component এখানে Call হচ্ছে */}
</Fragment>
);
})}
</div>
);
React এর রেন্ডারের জন্য চাই JSX Return করে এমন function বা React কম্পোনেন্ট ।
এক্ষেত্রে map একটি নতুন modified array রিটার্ন করে । যা সরাসরি UI এর মাঝে ব্যবহার করতে পারে । উপরের Examples এর ক্ষেত্রে Array.prototype.map ব্যবহার করায় list এর modified একটি Array of Components আমরা পাই যা React তা সরাসরি UI তে রেন্ডার করতে পারছে ।
এক্ষেত্রে একটু অতিরিক্ত কাজ করতে হবে । UI তে সরাসরি রেন্ডার করতে পারবে না । তাই একটি অতিরিক্ত Array বা List এর মধ্যে সব Component গুলো রাখতে হবে । এবং এক্ষেত্রে কোনো key দিতে হবে ।
উদাহরণঃ
export const App = () => {
const data = ['Item 1', 'Item 2', 'Item 3'];
const items = [];
data.forEach((item, index) => {
items.push(<li key={index}>{item}</li>);
});
return <ul>{items}</ul>;
};
export default MyComponent;
১১. List রেন্ডার এর ক্ষেত্রে প্রতিটি element কে কেন আলাদা আলাদা key দিতে হয় ? যদি key না দেয়া হয় তাহলে default ভাবে কি কী হিসেবে নেয়?
React এ List Render করার ক্ষেত্রে প্রতিটি element কে আলাদা আলাদা key দিতে হয় । যদি প্রোগ্রামার key না দেয় তাহলে এটি Default ভাবে Index কে key হিসেবে নিয়ে থাকে ।
index কে যদি key হিসেবে দেই তাহলে এক্ষেত্রে কিছু সমস্যা হতে পারে । যেমনঃ
ধরি,
- List of Components যা map করে UI তে দেখানো হল । এখানে প্রতিটি elements এর key তাদের index কে দেয়া হল ।
- onClick কোনো event এ ১ম index এর Component কে remove করা হল ।
- এখন ২য় element টি হয়ে যাবে ১ম element । যেহেতু array এর ১ম elements টি remove করা হয়েছে তাই ২য়টির index হবে ১ম টির index অর্থাৎ 1 .
- রিয়েক্ট মূলত index দিয়ে ট্রাক রাখে । এক্ষেত্রে React সঠিকভাবে ট্রাক রাখাতে পারবে না । কারন তার অনুযায়ী 1 index ওলা Component টি remove করা হয়েছে কিন্তু এখন আবার আবার দেখা যাচ্ছে যে আবার 1 index এর কোনো component আছে । এক্ষেত্রে React কনফিউসড হয়ে যাবে ।
- এসল ক্ষেত্রে Wired Behave করতে পারে ।
১২. React Component কিভাবে Pure Component হিসেবে কাজ করে ?
Ans:১৩. React Dev Mood এ State পরিবর্তন এর সাথে সাথে ২ ভার রি-রেন্ডার করে কেন ?
React Development mood এ কোনো পরিবর্তন হলে সেই component ও এর সকল Child components কে re-render করে ।
তবে Dev Mood এ এটি ২ বার করে ।
ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<App />
</React.StrictMode>
);
মূলত main.jsx আমরা React.StrictMode ব্যবহার এর জন্য এই Behavior পেয়ে থাকি।
এক্ষেত্রে React প্রটিতি component ও এর সকল Child components কে ২ বার re-render করার মাধ্যমে Module Dependency Tree এর কোথায় কোন Error হয়েছে তা চেক করে ।
এর ফলে কোনো error হলে উক্ত file ও কত নাম্বার লাইনে হয়েছে তা show করতে পারে ।
তবে এটি Production Deployment এর পর আর কাজ করে না ।
১৪. Local ও Global Component Mutation বলতে কি বুঝায় ?
React Development mood এ কোনো পরিবর্তন হলে সেই component ও এর সকল Child components কে re-render করে ।
তবে Dev Mood এ এটি ২ বার করে ।
ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<App />
</React.StrictMode>
);
মূলত main.jsx আমরা React.StrictMode ব্যবহার এর জন্য এই Behavior পেয়ে থাকি।
এক্ষেত্রে React প্রটিতি component ও এর সকল Child components কে ২ বার re-render করার মাধ্যমে Module Dependency Tree এর কোথায় কোন Error হয়েছে তা চেক করে ।
এর ফলে কোনো error হলে উক্ত file ও কত নাম্বার লাইনে হয়েছে তা show করতে পারে ।
তবে এটি Production Deployment এর পর আর কাজ করে না ।
১৫. Components Hydration বলতে কি বুঝায় ?
Ans:১৬. React Side Effect কি? Side Effect হ্যান্ডেল করার মাধ্যম কি কি হতে পারে?
React Development mood এ কোনো পরিবর্তন হলে সেই component ও এর সকল Child components কে re-render করে ।
তবে Dev Mood এ এটি ২ বার করে ।
ReactDOM.createRoot(document.getElementById('root')).render(
<React.StrictMode>
<App />
</React.StrictMode>
);
মূলত main.jsx আমরা React.StrictMode ব্যবহার এর জন্য এই Behavior পেয়ে থাকি।
এক্ষেত্রে React প্রটিতি component ও এর সকল Child components কে ২ বার re-render করার মাধ্যমে Module Dependency Tree এর কোথায় কোন Error হয়েছে তা চেক করে ।
এর ফলে কোনো error হলে উক্ত file ও কত নাম্বার লাইনে হয়েছে তা show করতে পারে ।
তবে এটি Production Deployment এর পর আর কাজ করে না ।
১৭. Immutably কোনো Array/Object of State এর কোনো element Add, delete and update করা যায় ?
ধরি,
কোনো একট Array Of Object নেয়া হল।
যার initial value { id: 1, name: "yeasin"}
const [arr, setArr] = useState([{ id: 1, name: 'yeasin' }]);
const newArr = [...arr, { id: 2, name: 'kawsar' }];
setArr(newArr);
ধাপসমূহ,
- arr এর সকল element গুলো newArr এর spread Operator এর মাধ্যমে Copy করে নেয়া হলো
- এবং কপি করার সাথেই নতুন একটি element যোগ করা হল ।
- setArr এর caller function এ নতুন Array টি দিয়ে দেয়া হল ।
- এক্ষেত্রে আগের ভ্যালু রেমুভ হবে ও নতুন newArr এর ভ্যালুটি বর্তমান state হবে ।
const deletedArr = arr.filter(val => val.id !== 1);
setArr(deletedArr);
ধরি, ১ নং ID element কে Delete করতে চাই ,
ধাপসমূহ,
- বর্তমান state অর্থাৎ arr এর উপর filter ব্যবহার করি ।
- যে element এর id ১ সেট ছাড়া বাকি element গুলো Array এর মধ্যে পাবো
- setArr এ deletedArr টি দিয়ে দেই। এক্ষেত্রে আগের State এর পরিবর্তে নতুন এই deletedArr টি arr value হিসেবে গন্য হবে ।
১৯. Declarative ও Imperative syntax এর মাঝে পার্থক্য কী? React কোন ধরণের উপায় ব্যবহার করে UI ম্যানুপুলেট করে ?
Declarative বলতে বর্ননামূলক বুঝায় এবং Imperative এর মানে বিস্তারিত নির্দেশনামূলক বুঝায় ।
উদাহরণঃ
আপনি মিরপুর থেকে শাহবাগ যাবেন ।
এক্ষেত্রে আপনি গাড়িতে উঠলেন ও ড্রাইভারকে বললেন যে আপনাকে শাহবাগ নিয়ে যেতে এখন সে তার নিজের মত রাস্তা দিয়ে নিয়ে যাবে ।
এই উপায় হচ্ছে Declarative ।
আবার,
আপনি গাড়িতে উঠে প্রতি রাস্তায় রাস্তায় বলে দিলেন এবার বামে এর পর ডানে যেতে এভাবে সম্পুর্ন রাস্তা তাকে দেখিইয়ে দেখিয়ে নিয়ে গেলেন, এই উপায় হলো Imperative
React.js মূলত Declarative উপায় ফলো করে UI ম্যানুপুলেট করে থাকে । এখানে আমরা নির্দিষ্ট state define করি ও তা setState দিয়ে পরিবর্তন করি কিন্তু ম্যানুয়ালি কোনো DOM এলিমেন্ট পরিবর্তন করতে হয় না । React নিজে তা নিজের মত করে আমাদের তা বিস্তারিত বলে দিতে হয় না ।
আবার Raw JavaScript এর ক্ষেত্রে কোনো State পরিবর্তন করে সেটা আবার ম্যানুয়ালি DOM এ Update করে দিতে হত । তাই এক্ষেত্রে এটি Imperative উপায় ফলো করতে হয়
২০. Derived বা Calculated State কাকে বলে ?
বর্তমানের কোনো State সমূহের সমন্বয়ে অন্য কোনো State বানানো কে Derived বা Calculated State বলে ।
যেমনঃ
const [firstName, setFirstName] = useState('');
const [firstName, setLastName] = useState('');
const [fullName, setFullName] = useState('');
এখানে, firstName and lastName আছে আবার fullName এর State আছে । এখন আমাদের যদি firstName বা lastName পরিবর্তন করতে হয় তাহলে প্রতিবার event Handler এর থেকে fullName পরিবর্তন করত হবে ।
কিন্তু,
const [firstName, setFirstName] = useState('');
const [lastName, setLastName] = useState('');
const fullName = firstName + lastName;
এখানে fullName firstName ও lastName এর ভ্যালু নিয়ে আমরা fullName এর একটা ভ্যালু পাচ্ছি
এখানে যেহেতু বর্তমানের State এর firstName ও lastName দিয়ে fullName বানানো হয়েছে তাই এক্ষেত্রে fullName Derived বা Calculated State বলা হয় ।
২১. Mirror Props কী? কোন ক্ষেত্রে এটি অসুবিধা করে ?
useState এর Initial Value যদি Parent Component এর থেকে Props এর মাধ্যমে নিয়ে সেটি তা ব্যবহার করা হয় তখন সেটী Mirror Props বলা হয় ,
যেমন ,
import { useState } from 'react';
export const DeriveState = ({ initialCategory }) => {
const [category, setCategory] = useState(initialCategory);
return <div>Mirror Props</div>;
};
এখানে, অসুবিধা হলোঃ
- Parent Component এর এই ভ্যলু যদি State এর ভ্যালু হয় ও পরে তা পরিবর্তন হবে তা এই Child Component এর Value পরিবরর্তন হবে না ।
- এটি ১ম এই Initial Values হিসেবে থাকবে ও এর মাঝে Setter Function এর মাধ্যমেই পরিবর্তন করানো যাবে । Parents এর কোনো setter Function দিয়া পরিবর্তন করলে তা Child এর value পরিবর্তন হবে না
২২. Props Drilling কাকে বলে ?
উঃ২৩. Stae Lifting up মেথড কি ও কেন ফলো করা হয় ?
উঃ২৪. useEffect এর Component life cycle methods ব্যাখা কর ।
উঃ
কোনো এক প্রাচীনকালে Class Component
এর ক্ষেত্রে Component life cycle নামের একটা Topic ছিল । বর্তমানে functional component এর জন্য তা হয়ত নেই । কিন্তু তার ২/৩ টা কন্সেপ্ট এখনও প্রয়োজন যা useEffect
এর ক্ষেত্রে প্রয়োজ্য ।
useEffect
হলো React.js
এর সাইড ইফেক্ট হ্যান্ডেল করার জন্য একটি হুক ।
React
এর কোম্পোনেন্ট রেন্ডার হবার প্রতিটি পর্যায়কে life cycle Methods
বলা হয় ।
Class Component এর ক্ষেত্রে এ সকল method আমাদের নিজেদের function হিসেবে লেখা প্রয়োজন হত তবে বর্তমানে তা করতে হয় না । useEffect দিয়া সব হ্যাডেল করা যায় । তাই এ methods না থাকলেও তার কনসেপ্ট আছে এখনও ।
মুলত class syntax এর এই আলাদা আলাদা ঝামেলা থেকে মুক্তি পাবার জন্য একটি মাত্র hook আনা হয় ।
Mount
: Render Phase বা Commit এর পরবর্তী অবস্থাকে বলেUnMount
: Render Phase বা Commit এর পরবর্তী অবস্থা বা render tree থেকে remove করা হলে তাকে বলে unmount ।
componentDidMount()
componentDidUpdate()
componentWillUnmount()
উক্ত সকল method এর Concepts একও আমরাদের জানা লাগে ।
কম্পোনেন্ট কি মাউন্ট হয়েছে? যদি হয় তাহলে এর ভিতরের কোড রান করবে ।
সহজে বুঝা যাচ্ছে , component যখন mount হবে মানে render phrase শেষ হবে সেটার পর এই effect টি ফায়ার হবে । বর্তমানে এটী useEffect দিয়া আমরা যেভাবে করি ।
useEffect(() => {
// rander phase এর পর এটি রান করবে ।
}, []);
এখানে [ ] দেয়ার মাধ্যমে বুঝানো হল এর কোনো Dependency নেই তাই এটি Render phase শেষ হবার পর একবার রান করবে ।
কোম্পোনেন্ট এর নির্দিষ্ট কিছু কি update হয়েছে? যদি হয় তাহলে এটি আবার রান করা হবে। যেমন ধরি কোনো একটা state আছে আমাদের কোডে এবং সেটা আপডেট হলে এই এফেক্ট টি রান করবে নিজে থেকেই ।
useEffect(() => {
// name পরিবর্তন হলে এটি আবার রান করবে
}, [name]);
কোনো components যদি react render tree এর থেকে রিমুভ করা হয় তখন এটি রান হবে । বর্তমানে আমরা এটি useEffect এর Cleanup function নামে চিনি । যদি useEffect কোনো functions return করে তাহলে সেটি unmount এর সময় তা ফারায় করবে নিজে থেকে ।
useEffect(() => {
return () => {
// unmount এর সময় এটি রান হবে ।
};
}, []);
১. Server Side Rendering এর সুবিধা কি ?
উঃ সার্ভার সাইড রেন্ডারিং এ ইনিশিয়াল এইচটিএমএল সার্ভারেই রেন্ডার হয়ে ক্লায়েন্ট এ আসে বিধায় ক্লায়েন্ট এর নতুন করে রেন্ডার করা লাগে না। এতে করে ওয়েব পেজ এর ইনিশিয়াল লোডিং টাইম কমে যায়। এছাড়া সার্চ ইঞ্জিন এই ইনিশিয়াল এইচটিএমএল কন্টেন্ট থেকেই ইন্ডেক্সিং করে বিধায় ওয়েবসাইট এর SEO র্যাংক বৃদ্ধি পায়।২. Client Components এর মধ্যেও কিভাবে Server Components রেন্ডার করা যায় ?
উঃ১. Node এ REPL Context বলতে কি বুঝায়
উঃ Node.js REPL (Read-Eval-Print Loop) হল একটি ইন্টারেক্টিভ রানটাইম এনভায়রনমেন্ট যেখানে Node.js কোড লিখে তা তারপরেই রান করা যায় ও Output দেখা যায়।
যেমন Terminal এ node লিখে এন্টার দিলে একটি REPL এনভায়রনমেন্ট শুরু হয়। এখানে আমরা যেকোনো ধরনের জাভাস্ক্রিপ্ট কোড লিখতে পারি এবং তা রান করতে পারি।
উদাহরণঃ
১. SQL ও No-SQL এর মধ্যে মূল পার্থক্য কি ?
উঃউঃ Yeasin
১ম এ আমরা এটি লক্ষ করিঃ
const takeInput = (input ) => {
console.log(input);
};
takeinput()
আগে এটি লক্ষ করি, এখানে যদি takeInput কে call করা হয় তাহলে input এর value By default হিসেবে undefined হিসেবে থাকবে । এখানে আমরা কোনো ভ্যালু পাস করিনি । তাই এখানে input এর ভ্যালু হিসেবে undefined হিসেবে থাকবে ।
কিন্তু এক্ষেত্রে এটির default value দিয়ে দিলে এর পর যদি যদি ওই paramitar এর ভ্যালু undefined হয় তাহলে এটি ওই default value টি নিয়ে দেখাবে ।
তাই যেহেতু আমাদের input এর default value দেয়া ছিল এই জন্য এখানে আমরা takeInput কে call করলে এটি undefined না হয়ে Yeasin দেখাবে ।