DEV Community

Cover image for Web History API Explained with Examples
RSM Academy BD
RSM Academy BD

Posted on

Web History API Explained with Examples

Web History API: বিস্তারিত আলোচনা

Web History API হলো একটি ব্রাউজার API, যা জাভাস্ক্রিপ্ট ব্যবহার করে ব্রাউজারের history stack-এর সাথে ইন্টারঅ্যাক্ট করার সুযোগ দেয়। History API-এর মাধ্যমে আপনি ব্রাউজারের ব্যাক (back) এবং ফরওয়ার্ড (forward) নেভিগেশনকে নিয়ন্ত্রণ করতে পারেন এবং কোনও পেজ রিলোড ছাড়াই URL পরিবর্তন করতে পারেন। এটি Single Page Application (SPA)-এ বিশেষভাবে গুরুত্বপূর্ণ যেখানে পুরো পেজ রিলোড না করে URL পরিবর্তন করে ব্যবহারকারীর অভিজ্ঞতাকে উন্নত করা হয়।

Web History API-এর কাজ

History API মূলত ব্রাউজারের history stack কে নিয়ন্ত্রণ করে। history stack হচ্ছে একটি স্ট্যাক যা ব্যবহারকারীর বিভিন্ন পেজ নেভিগেশন (যেমন, back বা forward করা) ট্র্যাক করে। সাধারণত history stack-এর তিনটি প্রধান কাজ থাকে:

  1. back: আগের পেজে ফিরে যাওয়া।
  2. forward: পরের পেজে যাওয়া, যদি ব্যবহারকারী পূর্বে back করেছেন।
  3. push: নতুন পেজ যোগ করা (যেমন, নতুন URL push করা)।

History API-এর প্রধান মেথড ও প্রোপার্টিজ

Web History API কিছু গুরুত্বপূর্ণ মেথড ও প্রোপার্টি প্রদান করে যা history stack পরিচালনার জন্য ব্যবহৃত হয়। প্রধান মেথডগুলো নিম্নরূপ:

1. history.pushState()

history.pushState() মেথড ব্যবহার করে আপনি নতুন state (অবস্থা) এবং URL history stack-এ push করতে পারেন, যা পেজ রিলোড ছাড়াই URL পরিবর্তন করে। এটি Single Page Applications (SPA)-এ খুবই সাধারণ, যেখানে কোনো পেজ পুনরায় লোড না করে নেভিগেশন করা হয়।

history.pushState(state, title, url);
Enter fullscreen mode Exit fullscreen mode
  • state: এটি একটি অবজেক্ট যা নতুন history entry-এর সাথে সংযুক্ত থাকে। যখন সেই entry পুনরায় active হয়, তখন সেই state অবজেক্টটি ফিরিয়ে আনা হয়।
  • title: এটি একটি string, যা সাধারণত ব্রাউজারের টাইটেল বার পরিবর্তনের জন্য ব্যবহৃত হয় (যদিও অধিকাংশ ব্রাউজার এটি ব্যবহার করে না)।
  • url: এটি একটি নতুন URL, যা বর্তমান URL-এর মতোই হতে পারে অথবা আলাদা হতে পারে। তবে URL-টি অবশ্যই একই origin-এ থাকতে হবে।

উদাহরণ:

// URL পরিবর্তন না করে state push করা
history.pushState({page: 1}, "Title 1", "/page1");
Enter fullscreen mode Exit fullscreen mode

উপরের উদাহরণে, /page1 নামক নতুন URL history stack-এ push করা হয়েছে, তবে এটি পেজ রিলোড না করে কাজ করবে। ব্যবহারকারীরা ব্রাউজারের back বোতাম ব্যবহার করে আগের অবস্থানে ফিরে যেতে পারবে।

2. history.replaceState()

history.replaceState() মেথডটি pushState() এর মতোই কাজ করে, তবে এটি history stack-এ নতুন entry যোগ না করে বর্তমান entry-টি পরিবর্তন করে। যখন আপনি বর্তমান পেজের URL বা state পরিবর্তন করতে চান কিন্তু history stack-এ নতুন entry তৈরি করতে চান না, তখন এটি ব্যবহৃত হয়।

history.replaceState(state, title, url);
Enter fullscreen mode Exit fullscreen mode

উদাহরণ:

history.replaceState({page: 2}, "Title 2", "/page2");
Enter fullscreen mode Exit fullscreen mode

এই মেথডটি pushState() এর মতোই কাজ করে, তবে এটি বর্তমান history entry-কে প্রতিস্থাপন করে, নতুন entry যোগ করে না।

3. history.back(), history.forward(), এবং history.go()

এই মেথডগুলো ব্যবহার করে আপনি history stack-এ back এবং forward মুভ করতে পারেন।

  • history.back(): history stack-এ আগের পেজে চলে যায়। এটি ব্রাউজারের back বোতামের মতো কাজ করে।
  history.back(); // আগের পেজে নেয়
Enter fullscreen mode Exit fullscreen mode
  • history.forward(): পরবর্তী history entry-তে চলে যায়। এটি ব্রাউজারের forward বোতামের মতো কাজ করে।
  history.forward(); // পরবর্তী পেজে নেয়
Enter fullscreen mode Exit fullscreen mode
  • history.go(n): history stack-এ নির্দিষ্ট সংখ্যা অনুসারে নেভিগেট করে। যদি n পজিটিভ হয়, তবে এটি ফরওয়ার্ড যায়, আর নেগেটিভ হলে ব্যাক যায়।
  history.go(-1); // আগের পেজে যায়
  history.go(1); // পরবর্তী পেজে যায়
Enter fullscreen mode Exit fullscreen mode

4. popstate Event

popstate ইভেন্টটি তখন ঘটে যখন ব্যবহারকারী back বা forward নেভিগেশন করে এবং state পরিবর্তন হয়। এটি আপনাকে history stack থেকে state পরিবর্তনের সময় পেজে নির্দিষ্ট অ্যাকশন নিতে সাহায্য করে।

window.addEventListener('popstate', function(event) {
  console.log("State: ", event.state);
});
Enter fullscreen mode Exit fullscreen mode

ব্যবহারিক উদাহরণ:

// স্টেট পুশ করা হচ্ছে
history.pushState({page: 1}, "Page 1", "/page1");
history.pushState({page: 2}, "Page 2", "/page2");

// পপস্টেট ইভেন্ট হ্যান্ডলিং
window.addEventListener('popstate', function(event) {
  console.log("State changed: ", event.state);
});
Enter fullscreen mode Exit fullscreen mode

যখন ব্যবহারকারী ব্রাউজারের back বা forward বোতাম ব্যবহার করে, তখন popstate ইভেন্টটি ট্রিগার হবে এবং state পরিবর্তনের সাথে সাথে event.state এর মাধ্যমে পরিবর্তিত state অবজেক্টটি পাওয়া যাবে।

কেন Web History API ব্যবহার করবেন?

1. Single Page Application (SPA) তৈরিতে সাহায্য করে

Single Page Application (SPA) এমন একটি অ্যাপ্লিকেশন যেখানে পুরো পেজটি পুনরায় লোড না করেই কন্টেন্ট পরিবর্তন করা হয়। History API ব্যবহার করে নতুন পেজের মতো URL যোগ করা যায়, কিন্তু আসলে পেজ লোড করা হয় না। এটি ব্যবহারকারীর অভিজ্ঞতাকে আরো উন্নত করে, কারণ প্রতিটি নেভিগেশনে সম্পূর্ণ পেজ পুনরায় লোড হয় না।

2. SEO ও Social Media Integration সহজ হয়

যেহেতু History API ব্যবহার করে URL পরিবর্তন করা যায়, এটি সার্চ ইঞ্জিন অপ্টিমাইজেশন (SEO) এবং সোশ্যাল মিডিয়া শেয়ারিংকে সহজ করে। যখন কোন পেজ বা তার অংশ URL-এর মাধ্যমে অ্যাক্সেস করা হয়, তখন তা সোশ্যাল মিডিয়ায় সহজে শেয়ার বা সার্চ ইঞ্জিনে সূচিকৃত করা যায়।

3. ব্যাক-ফরওয়ার্ড নেভিগেশন নিয়ন্ত্রণ করা

History API ব্যবহার করে আপনি সহজেই ব্রাউজারের ব্যাক এবং ফরওয়ার্ড নেভিগেশন নিয়ন্ত্রণ করতে পারেন। এর ফলে ব্যবহারকারীরা একটি পেজের মধ্যে বিভিন্ন state-এর মধ্যে নেভিগেট করতে পারেন, যেটা সাধারণত মোবাইল বা ওয়েব অ্যাপ্লিকেশনগুলিতে দরকার হয়।

4. উন্নত ব্যবহারকারীর অভিজ্ঞতা প্রদান

কোনও পেজ পুনরায় লোড না করে URL পরিবর্তনের মাধ্যমে history stack পরিচালনা করা যায়, যার ফলে ব্যবহারকারী seamless নেভিগেশনের অভিজ্ঞতা পায়।

Web History API ব্যবহারের চ্যালেঞ্জ

  1. Browser Support: যদিও আধুনিক ব্রাউজারগুলো History API সাপোর্ট করে, তবে কিছু পুরানো ব্রাউজার, যেমন Internet Explorer 9-এর আগে, এটি সাপোর্ট করে না। তাই পুরানো ব্রাউজারের জন্য ফিচার ডিটেকশন বা ফিলব্যাক প্রয়োজন।

  2. Security Issues: History API ব্যবহার করে URL পরিবর্তন করা যায়, তবে এটি cross-origin URL-এ কাজ করবে না। এটি নিরাপত্তার কারণে প্রয়োগ করা হয়, যাতে malicious scripts কোনো বহিরাগত পেজে নেভিগেট করতে না পারে।

উপসংহার

Web History API জাভাস্ক্রিপ্টের একটি শক্তিশালী এবং কার্যকরী টুল, যা ব্রাউজারের history stack নিয়ন্ত্রণের জন্য ব্যবহৃত হয়। এটি ব্যাক-ফরওয়ার্ড নেভিগেশন এবং পেজ রিলোড ছাড়াই URL পরিবর্তন করতে সাহায্য করে। বিশেষ করে Single Page Applications (SPA)-এ এর ভূমিকা অপরিসীম, কারণ এটি seamless নেভিগেশন এবং উন্নত ব্যবহারকারীর অভিজ্ঞতা প্রদান করে। History API ব্যবহার করে আপনি ব্রাউজারের native back/forward ফিচারগুলোকে নিয়ন্ত্রণ করতে পারেন এবং ব্যবহারকারীর ইন্টারঅ্যাকশন আরও কার্যকরী করে তুলতে পারেন।

Top comments (0)