ফোকাস

ফর্ম কন্ট্রোল , লিঙ্ক এবং বোতাম সহ ইন্টারেক্টিভ উপাদানগুলি ডিফল্টভাবে ফোকাসযোগ্য এবং ট্যাবেবল। ট্যাবযোগ্য উপাদানগুলি নথির ক্রমিক ফোকাস নেভিগেশন অর্ডারের অংশ। অন্যান্য উপাদানগুলি জড়, যার অর্থ তারা ইন্টারেক্টিভ নয়। এইচটিএমএল অ্যাট্রিবিউটের সাহায্যে, ইন্টারেক্টিভ উপাদানগুলিকে জড় করা এবং জড় উপাদানগুলিকে ইন্টারেক্টিভ করা সম্ভব।

ডিফল্টরূপে, নেভিগেশন ফোকাস অর্ডার ভিজ্যুয়াল অর্ডারের মতোই, যা সোর্স কোড অর্ডার। এমন HTML বৈশিষ্ট্য রয়েছে যা এই ক্রম পরিবর্তন করতে পারে এবং CSS বৈশিষ্ট্যগুলি যা সামগ্রীর ভিজ্যুয়াল ক্রম পরিবর্তন করতে পারে। HTML এর সাথে ট্যাবিং অর্ডার বা CSS এর সাথে ভিজ্যুয়াল রেন্ডারিং অর্ডার পরিবর্তন করা ব্যবহারকারীর অভিজ্ঞতার ক্ষতি করতে পারে।

CSS এবং HTML এর সাথে অনুভূত এবং প্রকৃত ট্যাবিং ক্রম পরিবর্তন করবেন না। নিম্নলিখিত দুটি উদাহরণ দেখায় যে, ট্যাব অর্ডার যা দৃশ্যত প্রত্যাশিত ক্রম থেকে ভিন্ন তা ব্যবহারকারীদের কাছে বিভ্রান্তিকর এবং ব্যবহারকারীর অভিজ্ঞতার জন্য খারাপ।

এই উদাহরণে, tabindex অ্যাট্রিবিউটের মান ট্যাব অর্ডারকে বিশৃঙ্খল করে তুলেছে:

এই উদাহরণে, CSS ট্যাবিং অর্ডার এবং বিষয়বস্তুর ভিজ্যুয়াল অর্ডারের মধ্যে পার্থক্য তৈরি করেছে:

flex-flow: row-reverse; ঘোষণা ভিজ্যুয়াল অর্ডার বিপরীত করেছে. এছাড়াও, সিএসএস অর্ডার প্রপার্টি ষষ্ঠ শব্দ "এই"-তে প্রয়োগ করা হয়েছিল, যা দৃশ্যত সেই একটি শব্দটিকে সরিয়ে দিয়েছে। ট্যাবিং সিকোয়েন্স হল কোডের ক্রম, যা আর ভিজ্যুয়াল অর্ডারের সাথে মেলে না, কীবোর্ড ব্যবহারকারীদের জন্য সংযোগ বিচ্ছিন্ন করে।

জড় উপাদান ইন্টারেক্টিভ করা

contenteditable এবং tabindex বৈশিষ্ট্যগুলি, বৈশ্বিক বৈশিষ্ট্যগুলি, যে কোনও উপাদানের সাথে যুক্ত করা যেতে পারে, সেগুলিকে প্রক্রিয়ায় ফোকাসযোগ্য করে তোলে। ফোকাসযোগ্য উপাদানগুলিকে একটি মাউস বা পয়েন্টার দিয়েও ফোকাস করা যেতে পারে, autofocus অ্যাট্রিবিউট সেট বা স্ক্রিপ্ট দ্বারা, যেমন element.focus() দিয়ে।

tabindex বৈশিষ্ট্য

গ্লোবাল tabindex অ্যাট্রিবিউট, অ্যাট্রিবিউটে প্রবর্তিত, এমন উপাদানগুলিকে সক্ষম করে যা অন্যথায় ফোকাস পেতে ফোকাস পেতে সক্ষম হবে না, সাধারণত ট্যাব কী দিয়ে, তাই নাম।

tabindex অ্যাট্রিবিউট এর মান একটি পূর্ণসংখ্যা হিসাবে নেয়। একটি নেতিবাচক মান একটি উপাদানকে ফোকাসযোগ্য করে তোলে কিন্তু ট্যাবযোগ্য নয়। 0 এর একটি tabindex মান উপাদানটিকে ফোকাসযোগ্য এবং ট্যাবযোগ্য করে তোলে, যে উপাদানটির উপর এটি সোর্স কোডের ক্রমানুসারে ফোকাস নেভিগেশন ক্রমতে প্রয়োগ করা হয় তা যোগ করে। 1 বা তার বেশি মান উপাদানটিকে ফোকাসযোগ্য এবং ট্যাব করার যোগ্য করে তোলে, কিন্তু এটিকে একটি অগ্রাধিকারযুক্ত ট্যাবিং ক্রমতে যুক্ত করে, এবং আমরা উপরে যেমন দেখেছি, এড়িয়ে যাওয়া উচিত।

এই পৃষ্ঠায়, শেয়ার বোতাম, <share-action> , একটি কাস্টম উপাদানtabindex="0" কীবোর্ড ডিফল্ট ট্যাবিং অর্ডারে এই-সাধারণভাবে ফোকাসযোগ্য নয় এমন উপাদান যোগ করে:

<share-action authors="@front-end.social/@estellevw" data-action="click" data-category="web.dev" data-icon="share" data-label="share, mastodon" role="button" tabindex="0">
  <svg aria-label="share" role="img" xmlns="http://www.w3.org/2000/svg">
    <use href="#shareIcon" />
  </svg>
  <span>Share</span>
</share-action>

এই পৃষ্ঠায় আরেকটি কাস্টম উপাদান রয়েছে: স্থানীয় নেভিগেশনে নেতিবাচক tabindex মান সহ একটি কাস্টম উপাদান রয়েছে:

<web-navigation-drawer type="standard" tabindex="-1">

একটি নেতিবাচক মান সহ একটি tabindex বৈশিষ্ট্য উপাদানটিকে ফোকাসযোগ্য করে তোলে তবে ট্যাবযোগ্য নয়। উপাদানটি ফোকাস গ্রহণ করতে সক্ষম, যেমন HTMLElement.focus() এর মাধ্যমে, কিন্তু এটি অনুক্রমিক ফোকাস নেভিগেশন অর্ডারের অংশ নয়৷ অ-ট্যাবেবল, ফোকাসযোগ্য উপাদানগুলির জন্য নিয়ম হল tabindex="-1" ব্যবহার করা। মনে রাখবেন যে আপনি যদি একটি ইন্টারেক্টিভ উপাদানে tabindex="-1" যোগ করেন তবে এটি আর ট্যাবযোগ্য হবে না।

element.focus() পদ্ধতিটি ফোকাসযোগ্য উপাদানগুলিতে ফোকাস সেট করতে ব্যবহার করা যেতে পারে। লক্ষ্য করুন যে ব্রাউজারগুলি দৃষ্টি নিবদ্ধ উপাদানগুলিকে স্ক্রোল করে। এই কারণে, element.focus({preventScroll:true}) ব্যবহার এড়িয়ে চলুন, কারণ একটি অদৃশ্যমান উপাদানের উপর ফোকাস করলে ব্যবহারকারীর অভিজ্ঞতা খারাপ হবে।

আপনি যদি বর্তমানে কোন উপাদানটিতে ফোকাস আছে তা খুঁজে বের করতে নথিটি জিজ্ঞাসা করতে চান, শুধুমাত্র-পঠনযোগ্য Document.activeElement বৈশিষ্ট্যটি ব্যবহার করুন৷

1 বা তার বেশি tabindex সহ উপাদানগুলি একটি পৃথক ট্যাব অনুক্রমে অন্তর্ভুক্ত করা হয়। আপনি যেমন কোডপেনে লক্ষ্য করবেন, ট্যাবিং একটি পৃথক ক্রমানুসারে শুরু হয়, সর্বনিম্ন মানের থেকে সর্বোচ্চ মানের ক্রমানুসারে, নিয়মিত ক্রমানুসারে (কোনও tabindex সেট নয়, বা tabindex="0" ) উৎস ক্রমে যাওয়ার আগে:

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

বিষয়বস্তু contenteditable বৈশিষ্ট্য

contenteditable বৈশিষ্ট্যটি আগে আলোচনা করা হয়েছিল। যেকোনো উপাদানে contenteditable="true" সেট করা এটিকে সম্পাদনাযোগ্য, ফোকাসযোগ্য এবং ট্যাব অর্ডারের অংশ করে তোলে। ফোকাস আচরণ tabindex="0" সেট করার অনুরূপ, কিন্তু একই নয়। নেস্টেড contenteditable উপাদান ফোকাসযোগ্য কিন্তু ট্যাবযোগ্য নয়। একটি নেস্টেড contenteditable উপাদান ট্যাবেবল করতে, tabindex="0" যোগ করুন, যা এটিকে অনুক্রমিক ফোকাস নেভিগেশন অর্ডারে যুক্ত করবে।

ইন্টারেক্টিভ উপাদানগুলিতে ফোকাস দেওয়া

autofocus বৈশিষ্ট্য

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

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

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

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

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

ইন্টারেক্টিভ উপাদান নিষ্ক্রিয় করা

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

নেতিবাচক tabindex মান

আমরা উপরে যেমন শিখেছি, নেতিবাচক মান সহ একটি tabindex বৈশিষ্ট্য একটি উপাদানকে ফোকাসযোগ্য করে তোলে কিন্তু ট্যাবযোগ্য নয়। একটি ফোকাসযোগ্য-বাই-ডিফল্ট উপাদানে tabindex="0" যোগ করার সময়, লিঙ্ক, বোতাম, ফর্ম কন্ট্রোল এবং contenteditable উপাদান সহ প্রয়োজনীয় নয়; একটি নেতিবাচক মান সহ একটি tabindex সহ অনুক্রমিক ফোকাস নেভিগেশন অর্ডার থেকে সাধারণত ট্যাবযোগ্য উপাদানগুলি সরিয়ে দেয়।

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

অক্ষম

বুলিয়ান অক্ষম অ্যাট্রিবিউট ফর্ম কন্ট্রোলগুলিকে তৈরি করে যার উপর এটি প্রয়োগ করা হয় এবং তাদের বংশধর, যদি থাকে, ফোকাসযোগ্য নয়। অক্ষম ফর্ম নিয়ন্ত্রণ ফোকাস করা যাবে না, ক্লিক ইভেন্ট পাবেন না, এবং ফর্ম জমা দেওয়ার পরে জমা দেওয়া হয় না। নোট disabled একটি বিশ্বব্যাপী বৈশিষ্ট্য নয়. এটি <button> , <input> , <optgroup> , <option> , <select> , <textarea> , ফর্ম-সম্পর্কিত কাস্টম উপাদান এবং <fieldset> এর ক্ষেত্রে প্রযোজ্য। <optgroup> বা <fieldset> এ সেট করা হলে, <fieldset> -এর প্রথম <legend> এর বিষয়বস্তু ব্যতীত সমস্ত চাইল্ড ফর্ম নিয়ন্ত্রণ নিষ্ক্রিয় করা হয়।

একই উপাদান যা disabled সমর্থন করে তাও :disabled এবং :enabled সিউডোক্লাসের সাথে লক্ষ্যযোগ্য। যে উপাদানগুলি disabled বৈশিষ্ট্যের সাথে নিষ্ক্রিয় করা হয় সেগুলি সাধারণত ব্যবহারকারী-এজেন্ট স্টাইলশীটের মাধ্যমে হালকা ধূসর হিসাবে স্টাইল করা হয়, এমনকি যদি একটি accent-color সেট করা থাকে।

একটি বুলিয়ান অ্যাট্রিবিউট হওয়ায়, অ্যাট্রিবিউটের উপস্থিতি অন্যথায় সক্রিয় উপাদানটিকে নিষ্ক্রিয় করে; আপনি এটি false সেট করতে পারবেন না। একটি অক্ষম উপাদান পুনরায় সক্ষম করতে, বৈশিষ্ট্যটি সরাতে হবে, সাধারণত Element.removeAttribute('disabled') এর মাধ্যমে।

HTMLInputElement.disabled প্রপার্টি আপনাকে একটি ইনপুট নিষ্ক্রিয় কিনা তা পরীক্ষা করতে দেয়। যেহেতু disabled একটি বৈশ্বিক বৈশিষ্ট্য নয়, এটি HTMLElement থেকে উত্তরাধিকারসূত্রে প্রাপ্ত নয়, তবে HTMLSelectElement , HTMLTextareaElement এর মতো প্রতিটি সমর্থনকারী উপাদান ইন্টারফেসে একই পঠনযোগ্য বৈশিষ্ট্য রয়েছে৷

disabled বৈশিষ্ট্যটি সাধারণত inert উপাদানগুলির ক্ষেত্রে প্রযোজ্য নয় যা tabindex বা contenteditable এর মাধ্যমে ফোকাসযোগ্য করা হয়। এটি <form> উপাদানের ক্ষেত্রেও প্রযোজ্য নয়। এইগুলি নিষ্ক্রিয় করতে, বিশ্বব্যাপী inert বৈশিষ্ট্য ব্যবহার করা যেতে পারে।

inert বৈশিষ্ট্য

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

নিয়ন্ত্রণ গঠনে disabled প্রয়োগ করার সময়, ব্রাউজার ডিফল্ট স্টাইলিং প্রদান করে এবং :disabled ছদ্ম ক্লাস ব্যবহার করে স্টাইল করা যেতে পারে। inert বৈশিষ্ট্য কোন চাক্ষুষ সূচক প্রদান করে না এবং কোন মিলিত সিউডোক্লাস নেই (যদিও [inert] বৈশিষ্ট্য নির্বাচক মেলে)।

জড়তা নির্দেশ করে এমন স্টাইল ছাড়া দৃশ্যমান সামগ্রীতে inert ব্যবহার করলে ব্যবহারকারীর অভিজ্ঞতা খারাপ হতে পারে। যেহেতু নিষ্ক্রিয় বিষয়বস্তু স্ক্রিন রিডার ব্যবহারকারীদের কাছে উপলব্ধ নয়, তাই এটি বিভ্রান্তির দিকে নিয়ে যেতে পারে যখন স্ক্রীন রিডার ব্যবহারকারীরা এমন সামগ্রী দেখেন যা অ্যাক্সেসিবিলিটি সরঞ্জামগুলিতে উপলব্ধ নয়৷ CSS এর মাধ্যমে জড়তা খুব স্পষ্ট করুন।

নিশ্চিত করুন যে ফোকাস কখনই অ-দৃশ্যমান বিষয়বস্তুর দিকে চলে যায়। অফ-স্ক্রিনে রেন্ডার করা যেকোন কিছু যা ফোকাস করার সময় স্বয়ংক্রিয়ভাবে দেখা যায় না তাকে জড় করা উচিত। যদি বিষয়বস্তু লুকানো থাকে, কিন্তু ফোকাস করার সময় দেখা যায়, যেমন এই পৃষ্ঠায় বিষয়বস্তু লিঙ্ক এড়িয়ে যান , এটি নিষ্ক্রিয় করার প্রয়োজন নেই।

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

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

ফোকাস আপনার জ্ঞান পরীক্ষা.

কোনো উপাদানকে ফোকাস করা না গেলে তাকে কী বলে বর্ণনা করা হয়?

খালি।
আবার চেষ্টা করুন
জড়।
সঠিক!
লুকানো।
আবার চেষ্টা করুন

উপাদানটির একটি disabled বৈশিষ্ট্য থাকলে কি সত্য হবে?

এটা ফোকাসযোগ্য হবে.
সঠিক!
এটা প্রদর্শিত হবে না.
আবার চেষ্টা করুন
যদি এটি একটি ফর্ম উপাদান এটি জমা দেওয়া হবে না.
সঠিক!