ফোকাস

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

ডিফল্টরূপে, নেভিগেশন ফোকাস অর্ডার ভিজ্যুয়াল অর্ডারের মতোই, যা সোর্স কোড অর্ডার। এমন 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 বৈশিষ্ট্য থাকলে কি সত্য হবে?

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