ডায়ালগ

ডায়ালগ এলিমেন্ট হল এইচটিএমএল-এ যেকোনো ধরনের ডায়ালগ উপস্থাপনের জন্য একটি দরকারী উপাদান, এটি কীভাবে কাজ করে তা খুঁজে বের করুন।

একটি মডেল ডায়ালগ হল একটি ওয়েব পৃষ্ঠার একটি বিশেষ ধরনের পপ-আপ বক্স, যা ব্যবহারকারীকে নিজের দিকে ফোকাস করতে বাধা দেয়। একটি ডায়ালগ পপ আপ করার জন্য কিছু বৈধ ব্যবহারের ক্ষেত্রে আছে, কিন্তু এটি করার আগে খুব বিবেচনা করা উচিত। মডেল ডায়ালগগুলি ব্যবহারকারীদের নির্দিষ্ট বিষয়বস্তুর উপর ফোকাস করতে বাধ্য করে, এবং, অস্থায়ীভাবে অন্তত, পৃষ্ঠার বাকি অংশটিকে উপেক্ষা করে৷

ডায়ালগগুলি হয় মডেল হতে পারে (শুধুমাত্র ডায়ালগের বিষয়বস্তুর সাথে ইন্টারঅ্যাক্ট করা যেতে পারে) অথবা নন-মোডাল (এটি এখনও ডায়ালগের বাইরের বিষয়বস্তুর সাথে ইন্টারঅ্যাক্ট করা সম্ভব)। মোডাল ডায়ালগগুলি পৃষ্ঠার বাকি বিষয়বস্তুর উপরে প্রদর্শিত হয়। পৃষ্ঠার বাকি অংশ নিষ্ক্রিয় এবং, ডিফল্টরূপে, একটি আধা-স্বচ্ছ ব্যাকড্রপ দ্বারা অস্পষ্ট।

একটি ডায়ালগ তৈরি করার জন্য শব্দার্থিক HTML <dialog> উপাদানটি শব্দার্থবিদ্যা, কীবোর্ড মিথস্ক্রিয়া এবং HTMLDialogElement ইন্টারফেসের সমস্ত বৈশিষ্ট্য এবং পদ্ধতির সাথে আসে।

এখানে একটি মডেল <dialog> এর একটি উদাহরণ। "ওপেন মডেল ডায়ালগ" বোতাম দিয়ে ডায়ালগটি খুলুন। একবার খোলা হলে, ডায়ালগটি বন্ধ করার তিনটি উপায় রয়েছে: এস্কেপ কী, formmethod="dialog" সেট আছে এমন একটি বোতামের সাহায্যে একটি ফর্ম জমা দেওয়া (অথবা যদি ফর্মটিতে নিজেই method="dialog" সেট থাকে), এবং HTMLDialogElement.close() পদ্ধতি৷

HTMLDialogElement তিনটি প্রধান পদ্ধতি রয়েছে, সাথে HTMLElement থেকে উত্তরাধিকারসূত্রে প্রাপ্ত সমস্ত পদ্ধতি।

dialog.show() /* opens the dialog */
dialog.showModal() /* opens the dialog as a modal */
dialog.close() /* closes the dialog */

কারণ এই <dialog> HTMLDialogElement.showModal() পদ্ধতিতে খোলা হয়েছে, এটি একটি মডেল ডায়ালগ। একটি মোডাল ডায়ালগ খোলার ফলে ডায়ালগ ব্যতীত অন্য সবকিছু নিষ্ক্রিয় এবং অস্পষ্ট হয়ে যায়। আপনি যদি ডায়ালগের বাইরে UI-এর উপর হোভার করেন, আপনি লক্ষ্য করবেন যে সমস্ত উপাদান এমনভাবে আচরণ করছে যেন pointer-events: none; সেট করা হয়েছিল; এমনকি যে বোতামটি ডায়ালগ খোলে সেটিও মিথস্ক্রিয়ায় প্রতিক্রিয়া দেখায় না।

ডায়ালগ খোলা হলে, ফোকাস ডায়ালগে চলে যায়। ফোকাস সেই ডায়ালগের মধ্যে ক্রমিক কীবোর্ড নেভিগেশন ক্রমে প্রথম উপাদানটিতে সেট করা হয়েছে। আপনি যদি tab কী বারবার আঘাত করেন, মোডাল ডায়ালগ খোলা থাকা অবস্থায় শুধুমাত্র ডায়ালগের মধ্যে থাকা বিষয়বস্তু ফোকাস পেতে পারে। যতক্ষণ ডায়ালগ খোলা থাকে ততক্ষণ মডেল ডায়ালগের বাইরের সমস্ত কিছুই জড় থাকে।

যখন একটি ডায়ালগ বন্ধ করা হয়, মোডাল হোক বা না হোক, ফোকাস সেই উপাদানটিতে ফেরত দেওয়া হয় যা ডায়ালগটি খুলেছে। ব্যবহারকারীর ক্রিয়া ছাড়াই প্রোগ্রাম্যাটিকভাবে একটি ডায়ালগ খোলা এড়িয়ে চলুন। যদি আপনার প্রয়োজন হয়, নিশ্চিত করুন যে ফোকাসটি ডায়ালগ খোলার আগে যেখানে ছিল সেখানে ফিরিয়ে দেওয়া হয়েছে, বিশেষ করে যদি ব্যবহারকারী এটির সাথে ইন্টারঅ্যাক্ট না করে ডায়ালগটি বাতিল করে দেয়।

একটি বিশ্বব্যাপী inert বৈশিষ্ট্য রয়েছে যা যেকোনো সক্রিয় ডায়ালগ ব্যতীত একটি উপাদান এবং তার সমস্ত বংশধরকে নিষ্ক্রিয় করতে ব্যবহার করা যেতে পারে। showModal() ব্যবহার করে একটি মোডাল ডায়ালগ খোলা হলে, জড়তা বা নিষ্ক্রিয়তা এর সাথে আসে; বৈশিষ্ট্য স্পষ্টভাবে সেট করা হয় না.

ব্যাকড্রপ যা ডায়ালগ ছাড়া অন্য সবকিছুকে অস্পষ্ট করে ::backdrop সিউডো-এলিমেন্ট ব্যবহার করে স্টাইল করা যেতে পারে। ব্যাকড্রপ শুধুমাত্র তখনই প্রদর্শিত হয় যখন একটি <dialog> .showModal() পদ্ধতিতে প্রদর্শিত হয়। এই ছদ্ম-উপাদানটি সমস্ত ব্যাকড্রপের সাথে মেলে, ফুলস্ক্রিন API ব্যবহার করার সময় প্রদর্শিত একটি সহ, যেমন পূর্ণ-স্ক্রীন মোডে একটি ভিডিও দেখার সময় যার স্ক্রীন বা মনিটরের অনুপাতের অনুপাত নেই।

নন-মোডাল ডায়ালগ

HTMLDialogElement.show() একইভাবে একটি ডায়ালগ খোলে, কিন্তু কোনো ব্যাকড্রপ যোগ না করে বা কোনো কিছুকে নিষ্ক্রিয় না করে। এস্কেপ কী নন-মোডাল ডায়ালগ বন্ধ করে না। এই কারণে, নন-মোডাল ডায়ালগ বন্ধ করার একটি পদ্ধতি অন্তর্ভুক্ত করা আরও গুরুত্বপূর্ণ। এটি করার সময়, যদি ক্লোজার ডায়ালগের বাইরে থাকে, তাহলে বুঝতে হবে ফোকাস সেই উপাদানে যাবে যা ডায়ালগটি খুলেছে, যা ব্যবহারকারীর সেরা অভিজ্ঞতা নাও হতে পারে।

ডায়ালগ বন্ধ করার জন্য একটি বোতাম স্পেসিফিকেশন দ্বারা আনুষ্ঠানিকভাবে প্রয়োজন হয় না, এটি প্রয়োজনীয় হিসাবে বিবেচনা করুন। এস্কেপ কী একটি মোডাল ডায়ালগ বন্ধ করবে, কিন্তু নন-মোডাল নয়। ফোকাস গ্রহণ করতে সক্ষম একটি দৃশ্যমান বোতাম অ্যাক্সেসযোগ্যতা এবং ব্যবহারকারীর অভিজ্ঞতা উন্নত করে।

একটি ডায়ালগ বন্ধ করা হচ্ছে

একটি ডায়ালগ বন্ধ করতে আপনার HTMLDialogElement.close() পদ্ধতির প্রয়োজন নেই। আপনার জাভাস্ক্রিপ্টের প্রয়োজন নেই। জাভাস্ক্রিপ্ট ছাড়াই <dialog> বন্ধ করতে, বোতামে <form> অথবা formmethod="dialog" method="dialog" করে একটি ডায়ালগ পদ্ধতি সহ একটি ফর্ম অন্তর্ভুক্ত করুন।

যখন একজন ব্যবহারকারী dialog পদ্ধতির সাথে জমা দেয়, তখন ব্যবহারকারীর প্রবেশ করা ডেটার অবস্থা বজায় থাকে। একটি জমা দেওয়ার ইভেন্ট থাকাকালীন — ফর্মটি সীমাবদ্ধতা যাচাইয়ের মধ্য দিয়ে যায় (যদি না novalidate সেট করা হয়) — ব্যবহারকারীর ডেটা সাফ বা জমা দেওয়া হয় না। জাভাস্ক্রিপ্ট ছাড়া একটি বন্ধ বোতাম এভাবে লেখা যেতে পারে:

<dialog open>
  <form method="dialog">
    <button type="submit" autofocus>close</button>
  </form>
</dialog>

আপনি এই উদাহরণে ক্লোজ <button> -এ autofocus অ্যাট্রিবিউট সেটটি লক্ষ্য করেছেন। <dialog> এর মধ্যে autofocus অ্যাট্রিবিউট সেট করা উপাদানগুলি পৃষ্ঠা লোডের উপর ফোকাস পাবে না (যদি না পৃষ্ঠাটি দৃশ্যমান ডায়ালগের সাথে লোড হয়)। ডায়ালগ খোলা হলে তারা ফোকাস পাবে।

ডিফল্টরূপে, যখন একটি ডায়ালগ খোলা হয়, ডায়ালগের মধ্যে প্রথম ফোকাসযোগ্য উপাদানটি ফোকাস পাবে যদি না ডায়ালগের মধ্যে একটি ভিন্ন উপাদানের autofocus বৈশিষ্ট্য সেট থাকে। ক্লোজ বোতামে autofocus অ্যাট্রিবিউট সেট করা নিশ্চিত করে যে ডায়ালগ খোলা হলে এটি ফোকাস পায়। কিন্তু <dialog> এর মধ্যে autofocus সহ শুধুমাত্র অনেক বিবেচনার সাথে করা উচিত। অটোফোকাসড এলিমেন্টের আগে অনুক্রমের সমস্ত উপাদান বাদ দেওয়া হয়। আমরা ফোকাস পাঠে এই বৈশিষ্ট্যটি আরও আলোচনা করব।

HTMLDialogElement ইন্টারফেসে একটি returnValue সম্পত্তি রয়েছে। একটি method="dialog" সহ একটি ফর্ম জমা দিলে ফর্মটি জমা দেওয়ার জন্য ব্যবহৃত সাবমিট বোতামটির name , যদি থাকে, তাহলে returnValue সেট করে। আমরা যদি <button type="submit" name="toasty">close</button> লিখতাম, তাহলে returnValue toasty হবে।

যখন একটি ডায়ালগ খোলা হয়, তখন বুলিয়ান open অ্যাট্রিবিউট উপস্থিত থাকে, যার অর্থ ডায়ালগ সক্রিয় থাকে এবং এর সাথে ইন্টারঅ্যাক্ট করা যায়। .show() বা .showModal() এর পরিবর্তে open অ্যাট্রিবিউট যোগ করে একটি ডায়ালগ খোলা হলে, ডায়ালগটি মোডাল-লেস হবে। HTMLDialogElement.open প্রপার্টি true বা false রিটার্ন করে, ডায়ালগটি ইন্টারঅ্যাকশনের জন্য উপলব্ধ কিনা তার উপর নির্ভর করে - এটি মডেল কি না।

যদিও জাভাস্ক্রিপ্ট একটি ডায়ালগ খোলার পছন্দের পদ্ধতি, পৃষ্ঠা লোডের open বৈশিষ্ট্য সহ, এবং তারপর এটিকে .close() দিয়ে সরিয়ে দেওয়া, জাভাস্ক্রিপ্ট না থাকলেও ডায়ালগটি উপলব্ধ রয়েছে তা নিশ্চিত করতে সহায়তা করতে পারে।

অতিরিক্ত বিবরণ

tabindex ব্যবহার করবেন না

যে উপাদানটি ডায়ালগ খুলতে সক্রিয় করা হয় এবং এতে থাকা ক্লোজ বোতামটি (এবং সম্ভবত অন্যান্য বিষয়বস্তু) ফোকাস গ্রহণ করতে পারে এবং ইন্টারেক্টিভ হয়। <dialog> উপাদানটি ইন্টারেক্টিভ নয় এবং ফোকাস গ্রহণ করে না। ডায়ালগে tabindex বৈশিষ্ট্য যোগ করবেন না।

ARIA ভূমিকা

অন্তর্নিহিত ভূমিকা হল dialog । যদি ডায়ালগ একটি নিশ্চিতকরণ উইন্ডো হয় যা একটি গুরুত্বপূর্ণ বার্তা যোগাযোগ করে যার জন্য নিশ্চিতকরণ বা অন্য ব্যবহারকারীর প্রতিক্রিয়া প্রয়োজন, সেট করুন role="alertdialog" । ডায়ালগের একটি অ্যাক্সেসযোগ্য নামও থাকা উচিত৷ যদি দৃশ্যমান পাঠ্য অ্যাক্সেসযোগ্য নামের জন্য প্রদান করতে পারে, aria-labelledby="idOfLabelingText" যোগ করুন।

CSS ডিফল্ট

মনে রাখবেন যে ব্রাউজারগুলি dialog জন্য ডিফল্ট স্টাইলিং প্রদান করে। ফায়ারফক্স, ক্রোম এবং এজ সেটের color: CanvasText; background-color: Canvas; এবং Safari সেট color: black; background-color: white; তাদের ব্যবহারকারী-এজেন্ট স্টাইলশীটে। color dialog থেকে উত্তরাধিকারসূত্রে প্রাপ্ত হয়েছে এবং body বা :root থেকে নয়, যা অপ্রত্যাশিত হতে পারে। background-color সম্পত্তি উত্তরাধিকারসূত্রে পাওয়া যায় না।

আপনার উপলব্ধি পরীক্ষা করুন

ডায়ালগ উপাদান আপনার জ্ঞান পরীক্ষা.

আপনি কিভাবে ডায়ালগ পিছনে এলাকা স্টাইল করবেন?

::background সিউডো-এলিমেন্ট সহ।
আবার চেষ্টা করুন
::backdrop সিউডো-এলিমেন্ট সহ।
সঠিক!
background সম্পত্তি সঙ্গে.
আবার চেষ্টা করুন