ডায়ালগ এলিমেন্ট হল এইচটিএমএল-এ যেকোনো ধরনের ডায়ালগ উপস্থাপনের জন্য একটি দরকারী উপাদান, এটি কীভাবে কাজ করে তা খুঁজে বের করুন।
একটি মডেল ডায়ালগ হল একটি ওয়েব পৃষ্ঠার একটি বিশেষ ধরনের পপ-আপ বক্স, যা ব্যবহারকারীকে নিজের দিকে ফোকাস করতে বাধা দেয়। একটি ডায়ালগ পপ আপ করার জন্য কিছু বৈধ ব্যবহারের ক্ষেত্রে আছে, কিন্তু এটি করার আগে খুব বিবেচনা করা উচিত। মডেল ডায়ালগগুলি ব্যবহারকারীদের নির্দিষ্ট বিষয়বস্তুর উপর ফোকাস করতে বাধ্য করে, এবং, অস্থায়ীভাবে অন্তত, পৃষ্ঠার বাকি অংশটিকে উপেক্ষা করে৷
ডায়ালগগুলি হয় মডেল হতে পারে (শুধুমাত্র ডায়ালগের বিষয়বস্তুর সাথে ইন্টারঅ্যাক্ট করা যেতে পারে) অথবা নন-মোডাল (এটি এখনও ডায়ালগের বাইরের বিষয়বস্তুর সাথে ইন্টারঅ্যাক্ট করা সম্ভব)। মোডাল ডায়ালগগুলি পৃষ্ঠার বাকি বিষয়বস্তুর উপরে প্রদর্শিত হয়। পৃষ্ঠার বাকি অংশ নিষ্ক্রিয় এবং, ডিফল্টরূপে, একটি আধা-স্বচ্ছ ব্যাকড্রপ দ্বারা অস্পষ্ট।
একটি ডায়ালগ তৈরি করার জন্য শব্দার্থিক 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
সম্পত্তি সঙ্গে.