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 ফিচারগুলোকে নিয়ন্ত্রণ করতে পারেন এবং ব্যবহারকারীর ইন্টারঅ্যাকশন আরও কার্যকরী করে তুলতে পারেন।

SurveyJS custom survey software

Build Your Own Forms without Manual Coding

SurveyJS UI libraries let you build a JSON-based form management system that integrates with any backend, giving you full control over your data with no user limits. Includes support for custom question types, skip logic, an integrated CSS editor, PDF export, real-time analytics, and more.

Learn more

Top comments (0)

Billboard image

Create up to 10 Postgres Databases on Neon's free plan.

If you're starting a new project, Neon has got your databases covered. No credit cards. No trials. No getting in your way.

Try Neon for Free →

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay