কিভাবে sidenav থেকে একটি প্রতিক্রিয়াশীল স্লাইড তৈরি করা যায় তার একটি মৌলিক ওভারভিউ
এই পোস্টে আমি আপনার সাথে শেয়ার করতে চাই কিভাবে আমি ওয়েবের জন্য একটি Sidenav উপাদান প্রোটোটাইপ করেছি যা প্রতিক্রিয়াশীল, স্টেটফুল, কীবোর্ড নেভিগেশন সমর্থন করে, জাভাস্ক্রিপ্টের সাথে এবং ছাড়া কাজ করে এবং ব্রাউজার জুড়ে কাজ করে। ডেমো চেষ্টা করুন.
আপনি যদি ভিডিও পছন্দ করেন তবে এখানে এই পোস্টটির একটি YouTube সংস্করণ রয়েছে:
ওভারভিউ
একটি প্রতিক্রিয়াশীল নেভিগেশন সিস্টেম তৈরি করা কঠিন। কিছু ব্যবহারকারী একটি কীবোর্ডে থাকবে, কারো কাছে শক্তিশালী ডেস্কটপ থাকবে, এবং কেউ একটি ছোট মোবাইল ডিভাইস থেকে ভিজিট করবে। পরিদর্শন করা প্রত্যেকেরই মেনু খুলতে এবং বন্ধ করতে সক্ষম হওয়া উচিত।
ওয়েব কৌশল
এই উপাদান অন্বেষণে আমি কয়েকটি সমালোচনামূলক ওয়েব প্ল্যাটফর্ম বৈশিষ্ট্য একত্রিত করার আনন্দ পেয়েছি:
- CSS
:target - CSS গ্রিড
- CSS রূপান্তরিত করে
- ভিউপোর্ট এবং ব্যবহারকারীর পছন্দের জন্য CSS মিডিয়া ক্যোয়ারী
-
focusUX বর্ধনের জন্য JS
আমার সমাধানের একটি সাইডবার আছে এবং শুধুমাত্র যখন 540px বা তার কম "মোবাইল" ভিউপোর্টে টগল করে। মোবাইল ইন্টারেক্টিভ লেআউট এবং স্ট্যাটিক ডেস্কটপ লেআউটের মধ্যে স্যুইচ করার জন্য 540px হবে আমাদের ব্রেকপয়েন্ট।
CSS :target সিউডো-ক্লাস
একটি <a> লিঙ্ক ইউআরএল হ্যাশকে #sidenav-open এবং অন্যটি খালি ( '' ) তে সেট করে। অবশেষে, একটি উপাদানের হ্যাশের সাথে মেলে id রয়েছে:
<a href="#sidenav-open" id="sidenav-button" title="Open Menu" aria-label="Open Menu">
<a href="#" id="sidenav-close" title="Close Menu" aria-label="Close Menu"></a>
<aside id="sidenav-open">
…
</aside>
এই লিঙ্কগুলির প্রতিটিতে ক্লিক করলে আমাদের পৃষ্ঠার URL-এর হ্যাশ অবস্থার পরিবর্তন হয়, তারপর একটি ছদ্ম-শ্রেণীর সাহায্যে আমি সাইডেনাভ দেখাই এবং লুকাই:
@media (max-width: 540px) {
#sidenav-open {
visibility: hidden;
}
#sidenav-open:target {
visibility: visible;
}
}
CSS গ্রিড
অতীতে, আমি শুধুমাত্র পরম বা স্থির অবস্থান sidenav লেআউট এবং উপাদান ব্যবহার করতাম। গ্রিড যদিও, এর grid-area সিনট্যাক্স সহ, আমাদের একই সারি বা কলামে একাধিক উপাদান বরাদ্দ করতে দেয়।
স্তূপ
প্রাথমিক লেআউট উপাদান #sidenav-container হল একটি গ্রিড যা 1টি সারি এবং 2টি কলাম তৈরি করে, প্রতিটির 1টি stack নামে পরিচিত। যখন স্থান সীমাবদ্ধ থাকে, তখন CSS সমস্ত <main> উপাদানের সন্তানকে একই গ্রিড নামে বরাদ্দ করে, সমস্ত উপাদানকে একই স্থানে স্থাপন করে, একটি স্ট্যাক তৈরি করে।
#sidenav-container {
display: grid;
grid: [stack] 1fr / min-content [stack] 1fr;
min-height: 100vh;
}
@media (max-width: 540px) {
#sidenav-container > * {
grid-area: stack;
}
}
মেনু ব্যাকড্রপ
<aside> হল অ্যানিমেটিং উপাদান যা সাইড নেভিগেশন ধারণ করে। এটির 2টি শিশু রয়েছে: নেভিগেশন কন্টেইনার <nav> নামের [nav] এবং একটি ব্যাকড্রপ <a> নামে [escape] , যা মেনু বন্ধ করতে ব্যবহৃত হয়।
#sidenav-open {
display: grid;
grid-template-columns: [nav] 2fr [escape] 1fr;
}
মেনু ওভারলে এবং এর নেতিবাচক স্থান বন্ধ বোতামের জন্য আপনার পছন্দের অনুপাত খুঁজে পেতে 2fr এবং 1fr সামঞ্জস্য করুন।
CSS 3D রূপান্তর এবং রূপান্তর
আমাদের লেআউট এখন একটি মোবাইল ভিউপোর্ট আকারে স্ট্যাক করা হয়েছে৷ যতক্ষণ না আমি কিছু নতুন শৈলী যোগ করি, এটি ডিফল্টরূপে আমাদের নিবন্ধকে ওভারলে করছে। এখানে কিছু UX আছে যার জন্য আমি এই পরবর্তী বিভাগে শুটিং করছি:
- খোলা এবং বন্ধ অ্যানিমেট
- শুধুমাত্র গতির সাথে অ্যানিমেট করুন যদি ব্যবহারকারী এটির সাথে ঠিক থাকে
-
visibilityঅ্যানিমেট করুন যাতে কীবোর্ড ফোকাস অফস্ক্রিন উপাদানে প্রবেশ না করে
আমি মোশন অ্যানিমেশন বাস্তবায়ন শুরু করার সাথে সাথে, আমি মনের শীর্ষে অ্যাক্সেসযোগ্যতা দিয়ে শুরু করতে চাই।
অ্যাক্সেসযোগ্য গতি
সবাই স্লাইড আউট মোশন অভিজ্ঞতা চাইবে না। আমাদের সমাধানে এই পছন্দটি একটি মিডিয়া কোয়েরির ভিতরে একটি --duration CSS ভেরিয়েবল সামঞ্জস্য করে প্রয়োগ করা হয়। এই মিডিয়া ক্যোয়ারী মানটি গতির জন্য ব্যবহারকারীর অপারেটিং সিস্টেমের পছন্দকে প্রতিনিধিত্ব করে (যদি উপলব্ধ থাকে)।
#sidenav-open {
--duration: .6s;
}
@media (prefers-reduced-motion: reduce) {
#sidenav-open {
--duration: 1ms;
}
}
এখন যখন আমাদের sidenav খোলা এবং বন্ধ স্লাইড করছে, যদি একজন ব্যবহারকারী হ্রাস করা গতি পছন্দ করে, আমি অবিলম্বে উপাদানটিকে দৃশ্যে স্থানান্তরিত করি, গতি ছাড়াই অবস্থা বজায় রাখি।
রূপান্তর, রূপান্তর, অনুবাদ
সিডেনাভ আউট (ডিফল্ট)
মোবাইলে আমাদের sidenav-এর ডিফল্ট অবস্থাকে অফস্ক্রিন অবস্থায় সেট করতে, আমি উপাদানটিকে transform: translateX(-110vw) দিয়ে অবস্থান করি।
দ্রষ্টব্য, আমি -100vw এর সাধারণ অফস্ক্রিন কোডে আরেকটি 10vw যোগ করেছি, যাতে নিশ্চিত করা যায় যে sidenav-এর box-shadow যখন লুকানো থাকে তখন মূল ভিউপোর্টে উঁকি না দেয়।
@media (max-width: 540px) {
#sidenav-open {
visibility: hidden;
transform: translateX(-110vw);
will-change: transform;
transition:
transform var(--duration) var(--easeOutExpo),
visibility 0s linear var(--duration);
}
}
সিডেনভ ইন
যখন #sidenav উপাদানটি :target হিসাবে মেলে, translateX() অবস্থানটিকে হোমবেস 0 এ সেট করুন এবং দেখুন যেভাবে CSS উপাদানটিকে তার -110vw এর আউট অবস্থান থেকে 0 var(--duration) এর "ইন" অবস্থানে স্লাইড করে যখন URL হ্যাশ পরিবর্তন করা হয়।
@media (max-width: 540px) {
#sidenav-open:target {
visibility: visible;
transform: translateX(0);
transition:
transform var(--duration) var(--easeOutExpo);
}
}
স্থানান্তর দৃশ্যমানতা
এখন লক্ষ্য হল স্ক্রীনরিডারদের থেকে মেনুটি লুকিয়ে রাখা যখন এটি আউট হয়ে যায়, তাই সিস্টেমগুলি অফস্ক্রিন মেনুতে ফোকাস রাখে না। যখন :target পরিবর্তিত হয় তখন আমি একটি দৃশ্যমান রূপান্তর সেট করে এটি সম্পন্ন করি।
- ভিতরে যাওয়ার সময়, দৃশ্যমানতা পরিবর্তন করবেন না; এখনই দৃশ্যমান হবে যাতে আমি উপাদানটি স্লাইড দেখতে পারি এবং ফোকাস গ্রহণ করতে পারি।
- বাইরে যাওয়ার সময়, ট্রানজিশন ভিজিবিলিটি কিন্তু দেরি করে, তাই ট্রানজিশন আউটের শেষে
hiddenফ্লিপ করে।
অ্যাক্সেসযোগ্যতা UX বর্ধিতকরণ
লিঙ্ক
এই সমাধানটি রাষ্ট্র পরিচালনার জন্য URL পরিবর্তনের উপর নির্ভর করে। স্বাভাবিকভাবেই, <a> উপাদানটি এখানে ব্যবহার করা উচিত, এবং এটি বিনামূল্যে কিছু চমৎকার অ্যাক্সেসিবিলিটি বৈশিষ্ট্য পায়। আসুন আমাদের ইন্টারেক্টিভ উপাদানগুলিকে লেবেলগুলির সাথে স্পষ্টভাবে অভিপ্রায়ে সজ্জিত করি৷
<a href="#" id="sidenav-close" title="Close Menu" aria-label="Close Menu"></a>
<a href="#sidenav-open" id="sidenav-button" class="hamburger" title="Open Menu" aria-label="Open Menu">
<svg>...</svg>
</a>
এখন আমাদের প্রাথমিক মিথস্ক্রিয়া বোতামগুলি মাউস এবং কীবোর্ড উভয়ের জন্যই তাদের অভিপ্রায় স্পষ্টভাবে বর্ণনা করে৷
:is(:hover, :focus)
এই সুবিধাজনক CSS কার্যকরী ছদ্ম-নির্বাচক আমাদেরকে ফোকাসের সাথে শেয়ার করার মাধ্যমে আমাদের হোভার শৈলীগুলির সাথে দ্রুত অন্তর্ভুক্ত করতে দেয়।
.hamburger:is(:hover, :focus) svg > line {
stroke: hsl(var(--brandHSL));
}
জাভাস্ক্রিপ্টে ছিটিয়ে দিন
বন্ধ করতে escape টিপুন
আপনার কীবোর্ডের Escape কীটি মেনুটি বন্ধ করতে হবে? চলুন যে আপ তারের.
const sidenav = document.querySelector('#sidenav-open');
sidenav.addEventListener('keyup', event => {
if (event.code === 'Escape') document.location.hash = '';
});
ব্রাউজার ইতিহাস
ব্রাউজারের ইতিহাসে একাধিক এন্ট্রি স্ট্যাক করা থেকে খোলা এবং বন্ধ মিথস্ক্রিয়া প্রতিরোধ করার জন্য, বন্ধ বোতামে নিম্নলিখিত জাভাস্ক্রিপ্ট ইনলাইন যোগ করুন:
<a href="#" id="sidenav-close" title="Close Menu" aria-label="Close Menu" onchange="history.go(-1)"></a>
এটি বন্ধ করার সময় ইউআরএল ইতিহাসের এন্ট্রি মুছে ফেলবে, এটি এমনভাবে তৈরি করবে যেন মেনুটি কখনই খোলা হয়নি।
UX ফোকাস করুন
পরবর্তী স্নিপেটটি খোলা বা বন্ধ করার পরে খোলা এবং বন্ধ বোতামগুলিতে ফোকাস রাখতে সাহায্য করে। আমি টগল করা সহজ করতে চাই।
sidenav.addEventListener('transitionend', e => {
const isOpen = document.location.hash === '#sidenav-open';
isOpen
? document.querySelector('#sidenav-close').focus()
: document.querySelector('#sidenav-button').focus();
})
যখন sidenav খোলে, বন্ধ বোতামে ফোকাস করুন। সিডেনাভ বন্ধ হয়ে গেলে, খোলা বোতামে ফোকাস করুন। আমি জাভাস্ক্রিপ্টের উপাদানটিতে focus() কল করে এটি করি।
উপসংহার
এখন আপনি জানেন যে আমি কীভাবে এটি করেছি, আপনি কীভাবে করবেন?! এটি কিছু মজার উপাদান আর্কিটেকচারের জন্য তৈরি করে! কে স্লট সহ 1 ম সংস্করণ করতে যাচ্ছে? 🙂
আসুন আমাদের পদ্ধতির বৈচিত্র্য আনুন এবং ওয়েবে তৈরি করার সমস্ত উপায় শিখি। একটি ত্রুটি তৈরি করুন, আমাকে আপনার সংস্করণ টুইট করুন , এবং আমি এটিকে নীচের সম্প্রদায়ের রিমিক্স বিভাগে যোগ করব৷
কমিউনিটি রিমিক্স
- @_developit কাস্টম উপাদান সহ: ডেমো এবং কোড
- @mayeedwin1 HTML/CSS/JS সহ: ডেমো এবং কোড
- @a_nurella একটি গ্লিচ রিমিক্স সহ: ডেমো এবং কোড
- @EvroMalarkey HTML/CSS/JS সহ: ডেমো এবং কোড