dev-resources.site
for different kinds of informations.
JavaScript-এর Hidden Secrets: splice() VS slice()
দুই ভাইয়ের গল্প: Splice এবং Slice
এক দেশে ছিলো একটি ছোট্ট গ্রাম, যার নাম "অ্যারে"। এই গ্রামে একদম শান্তিপূর্ণ জীবনযাপন করত অসংখ্য এলিমেন্ট—যারা সংখ্যাও হতে পারে, আবার নামও হতে পারে। তাদের মধ্যে splice
এবং slice
নামে দুই ভাই ছিল। দুই ভাইয়ের কাজ ছিল প্রোগ্রামারদের সাহায্য করা, তবে তারা দুজনের মধ্যে একেবারে আলাদা। তাদের কাজের ধরন আর স্বভাবও পুরোপুরি ভিন্ন।
তবে, যে প্রোগ্রামাররা তাদের সঠিকভাবে ব্যবহার করত, তারা কোডিংয়ের দুনিয়ায় একধরনের ম্যাজিক অনুভব করত। আজ আপনাদের সেই দুই ভাইয়ের গল্প বলব।
splice: দুষ্টু কিন্তু কার্যকর
ছোট ভাই splice
ছিল বেশ দুষ্টু। তার কাজই ছিল যে অ্যারেতে সে যেত, সেটি সম্পূর্ণ বদলে ফেলা। কোনো কিছু কেটে ফেলতে হোক, নতুন কিছু যোগ করতে হোক—splice
সবসময় অ্যারেকে পরিবর্তন করতে পছন্দ করত।
একদিনের গল্প
জনি নামের একজন প্রোগ্রামার তার প্রজেক্টে ব্যস্ত ছিল। তার কাছে একটি অ্যারে ছিল:
let friends = ["Alice", "Bob", "Charlie", "David"];
জনি চেয়েছিল এই অ্যারে থেকে Charlie
এবং David
কে সরিয়ে দিতে। সে splice
-কে ডেকে বলল,
“হে splice, তুমি কি ২ নম্বর ইন্ডেক্স থেকে ২টি এলিমেন্ট সরিয়ে দিতে পারবে?”
splice
সঙ্গে সঙ্গে উত্তর দিল, “অবশ্যই! তবে মনে রেখো, আমি যখন কাজ করব, তখন তোমার অ্যারে বদলে যাবে।”
জনি রাজি হলো। আর splice
ম্যাজিক শুরু করল:
friends.splice(2, 2); // ইন্ডেক্স ২ থেকে ২টি এলিমেন্ট সরাও
console.log(friends); // ["Alice", "Bob"]
জনি খুব খুশি। কিন্তু সে লক্ষ করল, splice
তার অ্যারেটিকে বদলে দিয়েছে। ছোট ভাইয়ের এমন দুষ্টুমি দেখে জনি একটু অবাক হলেও মুগ্ধ হলো।
splice-এর আরো দুষ্টুমি
splice
শুধু মুছে ফেলাতেই সীমাবদ্ধ নয়। সে নতুন কিছু যোগ করতেও ভালোবাসে।
জনি আবার তাকে ডেকে বলল, “তুমি কি আমার অ্যারেতে নতুন বন্ধু Eve
আর Frank
যোগ করতে পারো?”
splice
বলল, “কোন ইন্ডেক্সে?”
জনি বলল, “২ নম্বর ইন্ডেক্সে।”
friends.splice(2, 0, "Eve", "Frank"); // নতুন দুটি এলিমেন্ট যোগ
console.log(friends); // ["Alice", "Bob", "Eve", "Frank"]
splice
ছিল জনির ভরসার জায়গা যখনই তাকে অ্যারে সম্পূর্ণ বদলে ফেলতে হতো।
slice: শান্ত ও নিরীহ
এবার আসি বড় ভাই slice
-এর গল্পে। slice
ছিল একেবারে শান্ত স্বভাবের। সে কখনোই অ্যারের মূল অংশে হাত দিত না। তার একটাই কাজ—অ্যারের নির্দিষ্ট অংশ কপি করে একটি নতুন অ্যারে তৈরি করা। তার সততার কারণে প্রোগ্রামাররা তাকে খুব পছন্দ করত।
আরেকদিনের গল্প
জনি তার অ্যারে নিয়ে আবার বসেছিল। এবার তার চাওয়া, শুধু Bob
এবং Eve
এর একটি আলাদা কপি বানানো।
slice
বলল, “আমি তোমার কাজ করব, কিন্তু আমি তোমার মূল অ্যারেটিকে একটুও বদলাব না।”
let newFriends = friends.slice(1, 3); // ইন্ডেক্স ১ থেকে ৩ পর্যন্ত কপি (৩ বাদ)
console.log(newFriends); // ["Bob", "Eve"]
console.log(friends); // ["Alice", "Bob", "Eve", "Frank"] (মূল অ্যারে একই আছে)
slice
-এর কাজ দেখে জনি মুগ্ধ হলো। সে ভাবল, যখন অ্যারে কপি করতে হবে, তখন slice
-এর বিকল্প নেই।
splice আর slice-এর মূল পার্থক্য
একদিন জনি দুই ভাইকে নিয়ে বসে তাদের কাজের মধ্যে পার্থক্য খুঁজে বের করার চেষ্টা করল। আর সে একটা টেবিল বানাল:
বৈশিষ্ট্য | splice | slice |
---|---|---|
মূল অ্যারে পরিবর্তন | হ্যাঁ, মূল অ্যারে সরাসরি বদলে যায়। | না, মূল অ্যারে অপরিবর্তিত থাকে। |
কাজের ধরন | এলিমেন্ট যোগ করা, মুছে ফেলা, বা উভয়ই। | নির্দিষ্ট অংশ কপি করা। |
রিটার্ন ভ্যালু | সরানো হওয়া এলিমেন্টের একটি নতুন অ্যারে। | কপি করা অংশের একটি নতুন অ্যারে। |
পরিবর্তনের ক্ষমতা | অ্যারের গঠন পুরোপুরি বদলে দিতে পারে। | শুধু একটি নির্দিষ্ট অংশ কপি করতে পারে। |
একটি বাস্তব উদাহরণ
যেন splice আর slice-এর পার্থক্য আরও পরিষ্কার বোঝা যায়, জনি নিচের উদাহরণ লিখে রাখল:
splice দিয়ে কাজ:
let fruits = ["Apple", "Banana", "Cherry", "Date"];
fruits.splice(1, 2, "Blueberry", "Coconut"); // ১ থেকে ২টি সরিয়ে নতুন যোগ
console.log(fruits); // ["Apple", "Blueberry", "Coconut", "Date"]
slice দিয়ে কাজ:
let fruits = ["Apple", "Banana", "Cherry", "Date"];
let newFruits = fruits.slice(1, 3); // ১ থেকে ৩ পর্যন্ত কপি (৩ বাদ)
console.log(newFruits); // ["Banana", "Cherry"]
console.log(fruits); // ["Apple", "Banana", "Cherry", "Date"] (মূল অ্যারে অপরিবর্তিত)
শেষ কথা
splice
এবং slice
দুই ভাইয়ের গল্প থেকে একটি বিষয় পরিষ্কার: তাদের ভূমিকা আলাদা।
- যদি তুমি অ্যারেকে সরাসরি পরিবর্তন করতে চাও, তবে
splice
-কে ডাকো। - আর যদি তুমি অ্যারের নির্দিষ্ট অংশ কপি করতে চাও, তবে
slice
তোমার বিশ্বস্ত সঙ্গী।
তাদেরকে সঠিকভাবে ব্যবহার করতে পারলে তোমার কোড আরও পরিষ্কার, কার্যকর এবং দক্ষ হবে। গল্প শেষ, এবার কোডিং শুরু! 😊
Featured ones: