কিভাবে <progress>
উপাদানের সাথে একটি রঙ অভিযোজিত এবং অ্যাক্সেসযোগ্য লোডিং বার তৈরি করা যায় তার একটি ভিত্তিগত ওভারভিউ।
এই পোস্টে আমি <progress>
উপাদানের সাথে একটি রঙ অভিযোজিত এবং অ্যাক্সেসযোগ্য লোডিং বার কীভাবে তৈরি করা যায় সে সম্পর্কে চিন্তাভাবনা ভাগ করতে চাই। ডেমো চেষ্টা করুন এবং উৎস দেখুন !
আপনি যদি ভিডিও পছন্দ করেন তবে এখানে এই পোস্টটির একটি YouTube সংস্করণ রয়েছে:
ওভারভিউ
<progress>
উপাদানটি সম্পূর্ণ হওয়ার বিষয়ে ব্যবহারকারীদের ভিজ্যুয়াল এবং শ্রবণযোগ্য প্রতিক্রিয়া প্রদান করে। এই ভিজ্যুয়াল ফিডব্যাকটি এমন পরিস্থিতিতে মূল্যবান যেমন: একটি ফর্মের মাধ্যমে অগ্রগতি, তথ্য ডাউনলোড বা আপলোড করা বা এমনকি দেখানো যে অগ্রগতির পরিমাণ অজানা কিন্তু কাজ এখনও সক্রিয়।
এই GUI চ্যালেঞ্জটি বিদ্যমান HTML <progress>
উপাদানের সাথে কাজ করেছে যাতে অ্যাক্সেসযোগ্যতার কিছু প্রচেষ্টা বাঁচানো যায়। রঙ এবং লেআউটগুলি অন্তর্নির্মিত উপাদানটির জন্য কাস্টমাইজেশনের সীমাকে ঠেলে দেয়, উপাদানটিকে আধুনিকীকরণ করতে এবং এটি ডিজাইন সিস্টেমের মধ্যে আরও ভালভাবে ফিট করে।
মার্কআপ
আমি একটি <label>
এ <progress>
উপাদানটি মোড়ানো বেছে নিয়েছি যাতে আমি একটি অন্তর্নিহিত সম্পর্কের পক্ষে স্পষ্ট সম্পর্ক বৈশিষ্ট্যগুলি এড়িয়ে যেতে পারি। আমি লোডিং অবস্থার দ্বারা প্রভাবিত একটি অভিভাবক উপাদানকেও লেবেল করেছি, তাই স্ক্রিন রিডার প্রযুক্তিগুলি সেই তথ্যটি ব্যবহারকারীর কাছে ফেরত দিতে পারে৷
<progress></progress>
যদি কোন value
না থাকে, তাহলে উপাদানটির অগ্রগতি অনিশ্চিত । max
অ্যাট্রিবিউট ডিফল্ট 1, তাই অগ্রগতি 0 এবং 1-এর মধ্যে। উদাহরণস্বরূপ, max
100-এ সেট করা হলে, পরিসরটি 0-100-এ সেট করা হবে। আমি 0 এবং 1 সীমার মধ্যে থাকতে বেছে নিয়েছি, অগ্রগতির মানগুলিকে 0.5 বা 50% এ অনুবাদ করেছি।
লেবেল-মোড়ানো অগ্রগতি
একটি অন্তর্নিহিত সম্পর্কে, একটি অগ্রগতি উপাদান এই মত একটি লেবেল দ্বারা মোড়ানো হয়:
<label>Loading progress<progress></progress></label>
আমার ডেমোতে আমি শুধুমাত্র স্ক্রীন রিডারদের জন্য লেবেল অন্তর্ভুক্ত করতে বেছে নিয়েছি। এটি একটি <span>
এ লেবেল পাঠ্যটি মোড়ানো এবং এতে কিছু শৈলী প্রয়োগ করে করা হয় যাতে এটি কার্যকরভাবে পর্দার বাইরে থাকে:
<label>
<span class="sr-only">Loading progress</span>
<progress></progress>
</label>
WebAIM থেকে নিম্নলিখিত সহগামী CSS সহ:
.sr-only {
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
}
লোডিং অগ্রগতি দ্বারা প্রভাবিত এলাকা
আপনার যদি সুস্থ দৃষ্টি থাকে, তাহলে সম্পর্কিত উপাদান এবং পৃষ্ঠার ক্ষেত্রগুলির সাথে একটি অগ্রগতি সূচক যুক্ত করা সহজ হতে পারে, কিন্তু দৃষ্টি প্রতিবন্ধী ব্যবহারকারীদের জন্য, এটি এতটা পরিষ্কার নয়। লোডিং সম্পূর্ণ হলে পরিবর্তিত হবে এমন শীর্ষ-সবথেকে এলিমেন্টে aria-busy
অ্যাট্রিবিউট বরাদ্দ করে এটিকে উন্নত করুন। অধিকন্তু, aria-describedby
দ্বারা অগ্রগতি এবং লোডিং জোনের মধ্যে একটি সম্পর্ক নির্দেশ করুন।
<main id="loading-zone" aria-busy="true">
…
<progress aria-describedby="loading-zone"></progress>
</main>
জাভাস্ক্রিপ্ট থেকে, টাস্কের শুরুতে aria-busy
true
এ এবং শেষ হলে false
এ টগল করুন।
আরিয়া অ্যাট্রিবিউট সংযোজন
যদিও একটি <progress>
উপাদানের অন্তর্নিহিত ভূমিকা হল progressbar
, আমি এটিকে এমন ব্রাউজারগুলির জন্য স্পষ্ট করে দিয়েছি যেগুলির অন্তর্নিহিত ভূমিকা নেই। আমি স্পষ্টভাবে উপাদানটিকে অজানা অবস্থায় রাখার জন্য indeterminate
বৈশিষ্ট্য যুক্ত করেছি, যা উপাদানটির কোনো value
সেট নেই তা পর্যবেক্ষণ করার চেয়ে পরিষ্কার।
<label>
Loading
<progress
indeterminate
role="progressbar"
aria-describedby="loading-zone"
tabindex="-1"
>unknown</progress>
</label>
জাভাস্ক্রিপ্ট থেকে অগ্রগতি উপাদান ফোকাসযোগ্য করতে tabindex="-1"
ব্যবহার করুন। এটি স্ক্রিন রিডার প্রযুক্তির জন্য গুরুত্বপূর্ণ, যেহেতু অগ্রগতির পরিবর্তন হিসাবে অগ্রগতি ফোকাস দেওয়া, ব্যবহারকারীর কাছে ঘোষণা করবে যে আপডেট করা অগ্রগতি কতদূর পৌঁছেছে।
শৈলী
স্টাইলিংয়ের ক্ষেত্রে অগ্রগতির উপাদানটি কিছুটা জটিল। অন্তর্নির্মিত HTML উপাদানগুলির বিশেষ লুকানো অংশ রয়েছে যা নির্বাচন করা কঠিন হতে পারে এবং প্রায়শই কেবলমাত্র সীমিত বৈশিষ্ট্য সেট করার প্রস্তাব দেয়।
লেআউট
লেআউট শৈলীগুলি অগ্রগতি উপাদানের আকার এবং লেবেল অবস্থানে কিছুটা নমনীয়তা দেওয়ার উদ্দেশ্যে তৈরি করা হয়েছে৷ একটি বিশেষ সমাপ্তি অবস্থা যোগ করা হয়েছে যা একটি দরকারী হতে পারে, কিন্তু প্রয়োজন নেই, অতিরিক্ত ভিজ্যুয়াল কিউ।
<progress>
লেআউট
অগ্রগতি উপাদানটির প্রস্থকে স্পর্শ করা হয়নি তাই এটি নকশায় প্রয়োজনীয় স্থানের সাথে সঙ্কুচিত এবং বৃদ্ধি পেতে পারে। অন্তর্নির্মিত শৈলীগুলি appearance
এবং border
সেট করার দ্বারা ছিনিয়ে none
হয়। এটি করা হয় যাতে উপাদানটি ব্রাউজার জুড়ে স্বাভাবিক করা যায়, যেহেতু প্রতিটি ব্রাউজার তাদের উপাদানের জন্য নিজস্ব শৈলী রয়েছে।
progress {
--_track-size: min(10px, 1ex);
--_radius: 1e3px;
/* reset */
appearance: none;
border: none;
position: relative;
height: var(--_track-size);
border-radius: var(--_radius);
overflow: hidden;
}
_radius
জন্য 1e3px
এর মান একটি বড় সংখ্যা প্রকাশ করতে বৈজ্ঞানিক সংখ্যার স্বরলিপি ব্যবহার করে যাতে border-radius
সর্বদা বৃত্তাকার হয়। এটি 1000px
এর সমতুল্য। আমি এটি ব্যবহার করতে পছন্দ করি কারণ আমার লক্ষ্য হল এমন একটি মান ব্যবহার করা যাতে আমি এটি সেট করতে পারি এবং ভুলে যেতে পারি (এবং এটি 1000px
এর চেয়ে ছোট)। প্রয়োজনে এটিকে আরও বড় করাও সহজ: শুধুমাত্র 3 কে 4 এ পরিবর্তন করুন, তাহলে 1e4px
10000px
এর সমতুল্য।
overflow: hidden
ব্যবহার করা হয় এবং একটি বিতর্কিত শৈলী হয়েছে। এটি কয়েকটি জিনিসকে সহজ করেছে, যেমন ট্র্যাকে border-radius
মানগুলি পাস করার প্রয়োজন নেই এবং ট্র্যাক ফিল উপাদানগুলি; কিন্তু এর মানে হল যে কোন অগ্রগতির সন্তান উপাদানের বাইরে থাকতে পারবে না। এই কাস্টম অগ্রগতি উপাদানটির উপর আরেকটি পুনরাবৃত্তি overflow: hidden
এবং এটি অ্যানিমেশন বা আরও ভাল সমাপ্তির অবস্থার জন্য কিছু সুযোগ খুলতে পারে।
অগ্রগতি সম্পূর্ণ
CSS নির্বাচকরা এখানে মানের সাথে সর্বাধিক তুলনা করে কঠিন কাজ করে এবং যদি তারা মিলে যায় তবে অগ্রগতি সম্পূর্ণ হয়। সম্পূর্ণ হলে, একটি ছদ্ম-উপাদান তৈরি হয় এবং অগ্রগতি উপাদানের শেষে যুক্ত করা হয়, যা সমাপ্তির জন্য একটি চমৎকার অতিরিক্ত ভিজ্যুয়াল কিউ প্রদান করে।
progress:not([max])[value="1"]::before,
progress[max="100"][value="100"]::before {
content: "✓";
position: absolute;
inset-block: 0;
inset-inline: auto 0;
display: flex;
align-items: center;
padding-inline-end: max(calc(var(--_track-size) / 4), 3px);
color: white;
font-size: calc(var(--_track-size) / 1.25);
}
রঙ
ব্রাউজারটি অগ্রগতি উপাদানের জন্য নিজস্ব রঙ নিয়ে আসে এবং শুধুমাত্র একটি CSS বৈশিষ্ট্যের সাথে আলো এবং অন্ধকারের সাথে অভিযোজিত হয়। এটি কিছু বিশেষ ব্রাউজার-নির্দিষ্ট নির্বাচকদের সাথে তৈরি করা যেতে পারে।
হালকা এবং গাঢ় ব্রাউজার শৈলী
আপনার সাইটটিকে একটি অন্ধকার এবং হালকা অভিযোজিত <progress>
উপাদানে বেছে নিতে, color-scheme
যা প্রয়োজন।
progress {
color-scheme: light dark;
}
একক সম্পত্তি অগ্রগতি ভরা রঙ
একটি <progress>
এলিমেন্ট টিন্ট করতে, accent-color
ব্যবহার করুন।
progress {
accent-color: rebeccapurple;
}
accent-color
উপর নির্ভর করে ট্র্যাকের পটভূমির রঙ হালকা থেকে অন্ধকারে পরিবর্তিত হয় তা লক্ষ্য করুন। ব্রাউজারটি সঠিক বৈসাদৃশ্য নিশ্চিত করছে: বেশ ঝরঝরে।
সম্পূর্ণ কাস্টম হালকা এবং গাঢ় রং
<progress>
উপাদানে দুটি কাস্টম বৈশিষ্ট্য সেট করুন, একটি ট্র্যাকের রঙের জন্য এবং অন্যটি ট্র্যাকের অগ্রগতির রঙের জন্য। prefers-color-scheme
মিডিয়া কোয়েরির ভিতরে, ট্র্যাক এবং ট্র্যাক অগ্রগতির জন্য নতুন রঙের মান প্রদান করুন।
progress {
--_track: hsl(228 100% 90%);
--_progress: hsl(228 100% 50%);
}
@media (prefers-color-scheme: dark) {
progress {
--_track: hsl(228 20% 30%);
--_progress: hsl(228 100% 75%);
}
}
ফোকাস শৈলী
এর আগে আমরা উপাদানটিকে একটি নেতিবাচক ট্যাব সূচক দিয়েছিলাম যাতে এটি প্রোগ্রামগতভাবে ফোকাস করা যায়। স্মার্ট ফোকাস রিং শৈলী বেছে নিতে ফোকাস কাস্টমাইজ করতে :focus-visible
ব্যবহার করুন। এটির সাথে, একটি মাউস ক্লিক এবং ফোকাস ফোকাস রিং দেখাবে না, তবে কীবোর্ড ক্লিকগুলি দেখাবে। ইউটিউব ভিডিওটি আরও গভীরতার সাথে এটির মধ্যে যায় এবং পর্যালোচনা করার যোগ্য।
progress:focus-visible {
outline-color: var(--_progress);
outline-offset: 5px;
}
ব্রাউজার জুড়ে কাস্টম শৈলী
প্রতিটি ব্রাউজার প্রকাশ করে এমন একটি <progress>
উপাদানের অংশগুলি নির্বাচন করে শৈলীগুলি কাস্টমাইজ করুন। অগ্রগতি উপাদান ব্যবহার করা একটি একক ট্যাগ, তবে এটি কয়েকটি শিশু উপাদান দিয়ে তৈরি যা CSS ছদ্ম নির্বাচকদের মাধ্যমে প্রকাশ করা হয়। আপনি সেটিং সক্ষম করলে Chrome DevTools আপনাকে এই উপাদানগুলি দেখাবে:
- আপনার পৃষ্ঠায় ডান-ক্লিক করুন এবং DevTools আনতে উপাদান পরিদর্শন নির্বাচন করুন।
- DevTools উইন্ডোর উপরের-ডান কোণে সেটিংস গিয়ারে ক্লিক করুন।
- এলিমেন্ট শিরোনামের অধীনে, ব্যবহারকারী এজেন্ট শ্যাডো DOM চেকবক্স খুঁজুন এবং সক্ষম করুন।
সাফারি এবং ক্রোমিয়াম শৈলী
ওয়েবকিট-ভিত্তিক ব্রাউজার যেমন Safari এবং Chromium প্রকাশ করে ::-webkit-progress-bar
এবং ::-webkit-progress-value
, যা CSS-এর একটি উপসেট ব্যবহার করার অনুমতি দেয়। আপাতত, আগে তৈরি করা কাস্টম বৈশিষ্ট্যগুলি ব্যবহার করে background-color
সেট করুন, যা আলো এবং অন্ধকারের সাথে খাপ খায়।
/* Safari/Chromium */
progress[value]::-webkit-progress-bar {
background-color: var(--_track);
}
progress[value]::-webkit-progress-value {
background-color: var(--_progress);
}
ফায়ারফক্স শৈলী
ফায়ারফক্স শুধুমাত্র <progress>
উপাদানে ::-moz-progress-bar
ছদ্ম নির্বাচককে প্রকাশ করে। এর মানে আমরা সরাসরি ট্র্যাক টিন্ট করতে পারি না।
/* Firefox */
progress[value]::-moz-progress-bar {
background-color: var(--_progress);
}
লক্ষ্য করুন যে ফায়ারফক্সে accent-color
থেকে একটি ট্র্যাক রঙ সেট করা হয়েছে যখন iOS সাফারির একটি হালকা নীল ট্র্যাক রয়েছে। এটি ডার্ক মোডে একই রকম: ফায়ারফক্সের একটি গাঢ় ট্র্যাক রয়েছে কিন্তু আমাদের সেট করা কাস্টম রঙ নয় এবং এটি ওয়েবকিট-ভিত্তিক ব্রাউজারে কাজ করে।
অ্যানিমেশন
ব্রাউজার বিল্ট-ইন ছদ্ম নির্বাচকদের সাথে কাজ করার সময়, এটি প্রায়শই অনুমোদিত CSS বৈশিষ্ট্যের সীমিত সেটের সাথে থাকে।
ট্র্যাক ফিলিং আপ অ্যানিমেটিং
অগ্রগতি উপাদানের inline-size
একটি পরিবর্তন যোগ করা Chromium-এর জন্য কাজ করে কিন্তু Safari-এর জন্য নয়। ফায়ারফক্স এটির ::-moz-progress-bar
এ একটি ট্রানজিশন প্রপার্টি ব্যবহার করে না।
/* Chromium Only 😢 */
progress[value]::-webkit-progress-value {
background-color: var(--_progress);
transition: inline-size .25s ease-out;
}
অ্যানিমেটিং :indeterminate
অবস্থা
এখানে আমি একটু বেশি সৃজনশীল হয়েছি যাতে আমি একটি অ্যানিমেশন দিতে পারি। Chromium-এর জন্য একটি ছদ্ম-উপাদান তৈরি করা হয়েছে এবং একটি গ্রেডিয়েন্ট প্রয়োগ করা হয়েছে যা তিনটি ব্রাউজারের জন্য সামনে এবং পিছনে অ্যানিমেটেড।
কাস্টম বৈশিষ্ট্য
কাস্টম বৈশিষ্ট্যগুলি অনেক কিছুর জন্য দুর্দান্ত, তবে আমার পছন্দের একটি হল অন্যথায় যাদুকর চেহারার CSS মানকে একটি নাম দেওয়া। নিম্নলিখিত একটি মোটামুটি জটিল linear-gradient
, কিন্তু একটি সুন্দর নামের সাথে। এর উদ্দেশ্য এবং ব্যবহারের ক্ষেত্রে স্পষ্টভাবে বোঝা যায়।
progress {
--_indeterminate-track: linear-gradient(to right,
var(--_track) 45%,
var(--_progress) 0%,
var(--_progress) 55%,
var(--_track) 0%
);
--_indeterminate-track-size: 225% 100%;
--_indeterminate-track-animation: progress-loading 2s infinite ease;
}
কাস্টম বৈশিষ্ট্যগুলি কোডটিকে শুষ্ক থাকতে সাহায্য করবে কারণ আবারও, আমরা এই ব্রাউজার-নির্দিষ্ট নির্বাচকদের একসাথে গোষ্ঠীবদ্ধ করতে পারি না।
কীফ্রেমগুলি
লক্ষ্য হল একটি অসীম অ্যানিমেশন যা সামনে পিছনে যায়। শুরু এবং শেষ কীফ্রেমগুলি CSS-এ সেট করা হবে। একটি অ্যানিমেশন তৈরি করতে শুধুমাত্র একটি কীফ্রেম প্রয়োজন, মধ্যবর্তী কীফ্রেমটি 50%
, যেখান থেকে শুরু হয়েছে সেখানে ফিরে আসে, বারবার!
@keyframes progress-loading {
50% {
background-position: left;
}
}
প্রতিটি ব্রাউজার টার্গেটিং
প্রতিটি ব্রাউজারই <progress>
উপাদানে ছদ্ম-উপাদান তৈরির অনুমতি দেয় না বা অগ্রগতি বারকে অ্যানিমেট করার অনুমতি দেয় না। ছদ্ম-উপাদানের চেয়ে আরও বেশি ব্রাউজার ট্র্যাক অ্যানিমেটিং সমর্থন করে, তাই আমি ছদ্ম-উপাদানগুলি থেকে বেস হিসাবে এবং অ্যানিমেটিং বারগুলিতে আপগ্রেড করি।
ক্রোমিয়াম সিউডো-উপাদান
ক্রোমিয়াম ছদ্ম-উপাদানকে অনুমতি দেয়: ::after
। অনির্দিষ্ট কাস্টম বৈশিষ্ট্য ব্যবহার করা হয়, এবং সামনে এবং পিছনে অ্যানিমেশন খুব ভাল কাজ করে।
progress:indeterminate::after {
content: "";
inset: 0;
position: absolute;
background: var(--_indeterminate-track);
background-size: var(--_indeterminate-track-size);
background-position: right;
animation: var(--_indeterminate-track-animation);
}
সাফারি অগ্রগতি বার
সাফারির জন্য, কাস্টম বৈশিষ্ট্য এবং একটি অ্যানিমেশন ছদ্ম-উপাদান অগ্রগতি বারে প্রয়োগ করা হয়:
progress:indeterminate::-webkit-progress-bar {
background: var(--_indeterminate-track);
background-size: var(--_indeterminate-track-size);
background-position: right;
animation: var(--_indeterminate-track-animation);
}
ফায়ারফক্সের অগ্রগতি বার
ফায়ারফক্সের জন্য, কাস্টম বৈশিষ্ট্য এবং একটি অ্যানিমেশন ছদ্ম-উপাদান অগ্রগতি বারেও প্রয়োগ করা হয়:
progress:indeterminate::-moz-progress-bar {
background: var(--_indeterminate-track);
background-size: var(--_indeterminate-track-size);
background-position: right;
animation: var(--_indeterminate-track-animation);
}
জাভাস্ক্রিপ্ট
জাভাস্ক্রিপ্ট <progress>
উপাদানের সাথে একটি গুরুত্বপূর্ণ ভূমিকা পালন করে। এটি উপাদানটিতে পাঠানো মান নিয়ন্ত্রণ করে এবং স্ক্রিন রিডারদের জন্য নথিতে যথেষ্ট তথ্য উপস্থিত রয়েছে তা নিশ্চিত করে।
const state = {
val: null
}
ডেমো অগ্রগতি নিয়ন্ত্রণ করার জন্য বোতাম অফার করে; তারা state.val
আপডেট করে এবং তারপর DOM আপডেট করার জন্য একটি ফাংশন কল করে।
document.querySelector('#complete').addEventListener('click', e => {
state.val = 1
setProgress()
})
setProgress()
এই ফাংশনটি যেখানে UI/UX অর্কেস্ট্রেশন ঘটে। একটি setProgress()
ফাংশন তৈরি করে শুরু করুন। কোনো প্যারামিটারের প্রয়োজন নেই কারণ এতে state
অবজেক্ট, অগ্রগতি উপাদান এবং <main>
জোনে অ্যাক্সেস রয়েছে।
const setProgress = () => {
}
<main>
জোনে লোডিং অবস্থা সেট করা হচ্ছে
অগ্রগতি সম্পূর্ণ হয়েছে কি না তার উপর নির্ভর করে, সম্পর্কিত <main>
উপাদানটির aria-busy
অ্যাট্রিবিউটে একটি আপডেট প্রয়োজন:
const setProgress = () => {
zone.setAttribute('aria-busy', state.val < 1)
}
লোডিং পরিমাণ অজানা থাকলে বৈশিষ্ট্যগুলি সাফ করুন
মানটি অজানা বা সেট না থাকলে, এই ব্যবহারে null
, value
এবং aria-valuenow
বৈশিষ্ট্যগুলি সরান। এটি <progress>
কে অনিশ্চিত করে তুলবে।
const setProgress = () => {
zone.setAttribute('aria-busy', state.val < 1)
if (state.val === null) {
progress.removeAttribute('aria-valuenow')
progress.removeAttribute('value')
progress.focus()
return
}
}
জাভাস্ক্রিপ্ট দশমিক গণিত সমস্যা ঠিক করুন
যেহেতু আমি অগ্রগতি ডিফল্ট সর্বোচ্চ 1 এর সাথে লেগে থাকতে বেছে নিয়েছি, তাই ডেমো বৃদ্ধি এবং হ্রাস ফাংশন দশমিক গণিত ব্যবহার করে। জাভাস্ক্রিপ্ট এবং অন্যান্য ভাষাগুলি সর্বদা দুর্দান্ত নয় । এখানে একটি roundDecimals()
ফাংশন যা গণিত ফলাফলের অতিরিক্ত ছাঁটাই করবে:
const roundDecimals = (val, places) =>
+(Math.round(val + "e+" + places) + "e-" + places)
মানটিকে বৃত্তাকার করুন যাতে এটি উপস্থাপন করা যায় এবং পাঠযোগ্য হয়:
const setProgress = () => {
zone.setAttribute('aria-busy', state.val < 1)
if (state.val === null) {
progress.removeAttribute('aria-valuenow')
progress.removeAttribute('value')
progress.focus()
return
}
const val = roundDecimals(state.val, 2)
const valPercent = val * 100 + "%"
}
স্ক্রীন রিডার এবং ব্রাউজারের অবস্থার জন্য মান সেট করুন
মানটি DOM-এর তিনটি স্থানে ব্যবহৃত হয়:
-
<progress>
উপাদানেরvalue
বৈশিষ্ট্য। -
aria-valuenow
বৈশিষ্ট্য। -
<progress>
ভিতরের পাঠ্য বিষয়বস্তু।
const setProgress = () => {
zone.setAttribute('aria-busy', state.val < 1)
if (state.val === null) {
progress.removeAttribute('aria-valuenow')
progress.removeAttribute('value')
progress.focus()
return
}
const val = roundDecimals(state.val, 2)
const valPercent = val * 100 + "%"
progress.value = val
progress.setAttribute('aria-valuenow', valPercent)
progress.innerText = valPercent
}
অগ্রগতি ফোকাস প্রদান
মানগুলি আপডেট করার সাথে, দর্শনীয় ব্যবহারকারীরা অগ্রগতি পরিবর্তন দেখতে পাবে, তবে স্ক্রিন রিডার ব্যবহারকারীদের এখনও পরিবর্তনের ঘোষণা দেওয়া হয়নি। <progress>
উপাদানে ফোকাস করুন এবং ব্রাউজার আপডেট ঘোষণা করবে!
const setProgress = () => {
zone.setAttribute('aria-busy', state.val < 1)
if (state.val === null) {
progress.removeAttribute('aria-valuenow')
progress.removeAttribute('value')
progress.focus()
return
}
const val = roundDecimals(state.val, 2)
const valPercent = val * 100 + "%"
progress.value = val
progress.setAttribute('aria-valuenow', valPercent)
progress.innerText = valPercent
progress.focus()
}
উপসংহার
এখন যেহেতু আপনি জানেন যে আমি কীভাবে এটি করেছি, আপনি কেমন হবে‽ 🙂৷
অন্য সুযোগ দেওয়া হলে আমি অবশ্যই কিছু পরিবর্তন করতে চাই। আমি মনে করি বর্তমান উপাদানটি পরিষ্কার করার জায়গা আছে, এবং <progress>
উপাদানের ছদ্ম-শ্রেণির শৈলীর সীমাবদ্ধতা ছাড়াই চেষ্টা করার এবং তৈরি করার জায়গা আছে। এটা অন্বেষণ মূল্য!
আসুন আমাদের পদ্ধতির বৈচিত্র্য আনুন এবং ওয়েবে তৈরি করার সমস্ত উপায় শিখি।
একটি ডেমো তৈরি করুন, আমাকে লিঙ্কগুলি টুইট করুন এবং আমি নীচের সম্প্রদায়ের রিমিক্স বিভাগে এটি যুক্ত করব!