در این قسمت از یکی دیگر از مجموعه آموزش های طراحی سایت، ساخت یک منو ناوبری زیبا با استفاده از CSS و JavaSCRIPT را مشاهده می کنید. امیدوارم که برای شما مفید واقع شود.
در طراحی وب، منوی ناوبری یک عنصر اساسی است که کاربران را قادر میسازد به راحتی در سایت حرکت کنند. اما طراحی یک منوی ناوبری جالب و جذاب به عنوان یک عنصر برجسته و تمایزدهنده میتواند تجربه کاربری را بهبود بخشد. در این مقاله، ما قصد داریم یک منوی ناوبری جادویی را با استفاده از HTML، CSS و JavaScript طراحی کنیم و از جلوههای خارجی منحنی استفاده کنیم تا ظاهری زیبا و جذاب برای آن ایجاد کنیم.
بخش اول: طراحی ساختار HTML
در این بخش، به طراحی ساختار اولیه HTML برای منوی ناوبری میپردازیم. این ساختار شامل عناصر `<ul>` و `<li>` است که به ترتیب لیستهای ناوبری و آیتمهای آن را نشان میدهند. همچنین، برای هر آیتم، لینک مربوطه را نیز قرار میدهیم. همچنین پیشنهاد میکنم مقاله 5 پروژه جاوا اسکریپت با چت جی پی تی را سری بزنید.
مثال:
منوی ناوبری جادویی
توضیحات:
بطور کلی، کد HTML برای طراحی منوی ناوبری جادویی شامل یک عنصر `<nav>` و یک لیست نامرئی `<ul>` است. درون لیست نامرئی، هر آیتم منو با استفاده از عنصر `<li>` و لینک با استفاده از عنصر `<a>` نمایش داده میشود. آیتمهای منوی اصلی در سطح اول لیست نامرئی قرار میگیرند و زیرمجموعههای منو با استفاده از لیست نامرئی داخلی دیگر ایجاد میشوند.
به طور کلی، ساختار کد HTML برای طراحی منوی ناوبری جادویی به صورت زیر است:
<nav>
<ul>
<li><a href="#">آیتم منو 1</a></li>
<li><a href="#">آیتم منو 2</a></li>
<li><a href="#">آیتم منو 3</a></li>
<li><a href="#">آیتم منو 4</a></li>
</ul>
</nav>
در کد بالا، هر `<li>` شامل یک عنصر `<a>` است که به صفحه یا بخش مورد نظری که باید با کلیک روی آن لینک شود، پیوند داده شده است. شما میتوانید متن لینک را با متن دلخواه خود جایگزین کنید و همچنین مقصد لینک را با آدرس مورد نظر خود تغییر دهید.
این عناصر HTML اصلی کد منوی ناوبری جادویی هستند. با استفاده از CSS و JavaScript، میتوانید استایل و رفتار منو را به دلخواه خود تغییر دهید. در کد CSS، استایلهای مربوط به منوی ناوبری و جلوههای خارجی منحنی تعریف شده است. و در کد JavaScript، رفتار هاور ماوس بر روی آیتمهای منو پیاده سازی شده است. اگر به این زبان علاقه مند هستید پیشنهاد میکنم از آموزش زبان HTML دیدن کنید.
بخش دوم: طراحی استایل CSS
در این بخش، به طراحی استایل CSS برای منوی ناوبری میپردازیم. از جلوههای خارجی منحنی استفاده میکنیم تا به منوی ناوبری شکلی زیبا و دلخواه بدهیم. با استفاده از خواص CSS مختلف، مانند `border-radius` و `transform`, این جلوههای منحنی را ایجاد میکنیم. همچنین، استایلهای دیگری نیز برای طراحی رنگبندی، فونت، و پوزیشن منوی ناوبری اعمال میکنیم.
مثال:
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
}
nav ul {
list-style-type: none;
margin: 0;
padding: 0;
background-color: #f1f1f1;
display: flex;
justify-content: center;
border-radius: 20px;
}
nav li {
margin: 5px;
}
nav a {
display: block;
padding: 10px 20px;
text-decoration: none;
color: #333;
border-radius: 10px;
transition: background-color 0.3s ease;
}
nav a:hover {
background-color: #ddd;
}
nav ul ul {
display: none;
position: absolute;
background-color: #f1f1f1;
border-radius: 20px;
}
nav ul li:hover > ul {
display: inherit;
}
nav ul ul li {
width: 150px;
float: none;
display: list-item;
position: relative;
}
nav ul ul ul li {
position: relative;
top: -60px;
left: 150px;
}
توضیح:
در این کد CSS، استایلهای مربوط به منوی ناوبری و جلوههای خارجی منحنی تعریف شده است.
“`css
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
}
“`
این قسمت کدها به بدنه صفحه اعمال میشود و فونت مورد استفاده، حاشیهها و پرشینگهای صفحه را صفر تنظیم میکند.
“`css
nav ul {
list-style-type: none;
margin: 0;
padding: 0;
background-color: #f1f1f1;
display: flex;
justify-content: center;
border-radius: 20px;
}
“`
این بخش مشخصات استایل لیست نامرئی (`<ul>`) را تعیین میکند. استایلهایی مانند نوع لیست، حاشیهها، پرشینگها، رنگ پس زمینه و انعطاف پذیری (`flex`) برای مرکز چین کردن آیتمها درون منو تعیین میشوند. همچنین یک حاشیه گرد (`border-radius`) با شعاع 20 پیکسل به منو اضافه میشود تا شکل منحنی را به آن بدهد.
“`css
nav li {
margin: 5px;
}
“`
این بخش حاشیههای کناری آیتمها را تعیین میکند.
“`css
nav a {
display: block;
padding: 10px 20px;
text-decoration: none;
color: #333;
border-radius: 10px;
transition: background-color 0.3s ease;
}
“`
این بخش استایل لینکها (`<a>`) را تعیین میکند. استایلهایی مانند نمایش بلوک، حاشیهها، رنگ متن، حاشیه گرد و انتقال رنگ پس زمینه با انتقال نرم (`transition`) تعیین میشوند. این انتقال باعث میشود که رنگ پس زمینه لینکها با انیمیشنی نرم تغییر کند در هنگام هاور ماوس بر روی آنها.
“`css
nav a:hover {
background-color: #ddd;
}
“`
این بخش استایل لینکها را در هنگام هاور ماوس بر روی آنها تغییر میدهد. در اینجا، رنگ پس زمینه لینک با رنگ خاکستری روشن (`#ddd`) جایگزین میشود.
“`css
nav ul ul {
display: none;
position: absolute;
background-color: #f1f1f1;
border-radius: 20px;
}
“`
این بخش استایل لیست نامرئی داخلی (`<ul>`) برای زیرمنوها را تعیین میکند. استایلهایی مانند نمایش نداشتن (`display:none`)، موقعیت مطلق (`position: absolute`)، رنگ پس زمینه و حاشیه گرد به زیرمنوها اعمال میشوند.
“`css
nav ul li:hover > ul {
display: inherit;
}
“`
این بخش استایل زیرمنوها را در هنگام هاور ماوس بر روی آیتمهای منوی اصلی تعیین میکند. با استفاده از این استایل، زیرمنوها به صورت نمایش (`display: inherit`) نمایان میشوند.
“`css
nav ul ul li {
width: 200px;
float: none;
display: list-item;
position: relative;
}
“`
این بخش استایل آیتمهای زیرمنو را تعیین میکند. با استفاده از استایلهای مانند عرض 200 پیکسل، شناوری نداشتن (`float: none`)، نمایش به صورت آیتم لیست (`display: list-item`) و موقعیت نسبی (`position: relative`)، آیتمهای زیرمنو در یک سطر نمایش داده میشوند. برای اطلاعات بیشتر به آموزش CSS مراجعه کنید.
“`css
nav ul ul ul li {
position: relative;
top: -60px;
left: 200px;
}
“`
این بخش استایل آیتمهای زیرزیرمنو را تعیین میکند. با استفاده از استایلهای مانند موقعیت نسبی (`position: relative`)، تعیین موقعیت با استفاده از بالا (`top`) و چپ (`left`)، آیتمهای زیرزیرمنو به صورت منحنی به سمت چپ و بالا نمایش داده میشوند.
بخش سوم: اضافه کردن رفتار با JavaScript
در این بخش، به اضافه کردن رفتار و تعامل به منوی ناوبری با استفاده از JavaScript میپردازیم. به وسیلهی رویدادهای ماوس و توابع JavaScript، میتوانیم تغییراتی را در منو ایجاد کنیم. به عنوان مثال، هنگامی که کاربر روی یک آیتم هاور میکند، میتوانیم استایل آن آیتم را تغییر دهیم و یا زیرمنوها را نمایش دهیم.
مثال:
// اضافه کردن رفتار به هاور ماوس
var navItems = document.querySelectorAll('nav a');
for (var i = 0; i < navItems.length; i++) {
navItems[i].addEventListener('mouseover', function () {
this.style.backgroundColor = '#ddd';
});
navItems[i].addEventListener('mouseout', function () {
this.style.backgroundColor = '';
});
}
توضیح:
این کد JavaScript به صورت کامل رفتاری را به المانهای لینک در منوی ناوبری (nav) اضافه میکند. همچنین، با استفاده از رویدادهای mouseover و mouseout، تغییراتی را در ظاهر المانهای لینک ایجاد میکند وقتی ماوس روی آنها حرکت میکند یا از روی آنها خارج میشود.
در خط اول، تمام المانهای لینک درون منوی ناوبری با استفاده از کوئریسلکتور (querySelectorAll) و به عنوان معیار انتخاب، ‘nav a’، انتخاب میشوند و در متغیر navItems ذخیره میشوند.
سپس، با استفاده از یک حلقه (for loop)، به ترتیب هر المان لینک را در navItems در نظر میگیریم. درون حلقه، دو رویداد بر روی هر المان لینک اضافه میشود.
در خطوط سوم تا پنجم، رویداد mouseover به هر المان لینک اضافه میشود. وقتی ماوس روی المان لینک حرکت میکند، تابع مربوطه صدا زده میشود و با استفاده از کلیدواژه this به المان لینک مورد نظر دسترسی پیدا میکنیم. سپس، رنگ پس زمینه آن المان لینک به ‘#ddd’ تغییر میکند. این کد تغییر رنگ پس زمینه المان لینک را به رنگ خاکستری روشن (light gray) تنظیم میکند.
همچنین، در خطوط هفتم تا نهم، رویداد mouseout به هر المان لینک اضافه میشود. وقتی ماوس از روی المان لینک خارج میشود، تابع مربوطه فراخوانی میشود و با استفاده از کلیدواژه this به المان لینک مورد نظر دسترسی پیدا میکنیم. سپس، رنگ پس زمینه آن المان لینک به حالت اولیه خود برگشت میکند (بدون تنظیم رنگ پس زمینه خاصی). این کد باعث برگشت المان لینک به رنگ پس زمینه پیشفرض میشود.
سوالات متداول:
سوال ۱: چگونه میتوان یک منوی ناوبری جادویی با استفاده از HTML، CSS و JavaScript طراحی کرد؟
پاسخ: برای طراحی یک منوی ناوبری جادویی با استفاده از HTML، CSS و JavaScript، میتوانید از روشهای مختلفی استفاده کنید. یک روش معمول این است که از لیستی از المانهای `ul` و `li` در HTML استفاده کنید، و با استفاده از CSS و JavaScript، تغییرات و جلوههای خاصی به این المانها اعمال کنید. به عنوان مثال، میتوانید از CSS Transitions و Transformations استفاده کنید تا حرکتها و تغییرات در منوی ناوبری خود ایجاد کنید. همچنین میتوانید از JavaScript برای اعمال رفتارهای تعاملی به منوی ناوبری استفاده کنید، مانند باز و بسته کردن منو، تغییر حالت آن و غیره.
سوال ۲: چه جلوههای خارجی منحنی میتوان بر روی منوی ناوبری اعمال کرد؟
پاسخ: برای اعمال جلوههای خارجی منحنی به منوی ناوبری، میتوانید از ویژگیها و تکنیکهای CSS استفاده کنید. به عنوان مثال، میتوانید با استفاده از ترانزیشنها و ترانسفرمیشنها، حرکتهای منحنی را به المانهای منوی ناوبری اعمال کنید. میتوانید از ترانزیشنهای CSS برای ایجاد انیمیشنهای انتقالی و تغییر اندازه استفاده کنید. همچنین، میتوانید از توابع و متدهای JavaScript برای اعمال جلوههای پیچیدهتری مانند منحنیها و انیمیشنهای سفارشی استفاده کنید.
سوال ۳: چگونه میتوان یک ترانزیشن منحنی بر روی المانها اعمال کرد؟
پاسخ: برای اعمال ترانزیشن منحنی بر روی المانها در CSS، میتوانید از تابع `cubic-bezier()` استفاده کنید. این تابع به شما اجازه میدهد یک تابع منحنی سفارشی را برای ترانزیشن تعیین کنید. تابع `cubic-bezier()` چهار پارامتر دارد که هر کدام از 0 تا 1 مقدار میگیرند. این پارامترها نشان دهنده نقاط کنترل منحنی هستند و با تغییر مقادیر آنها میتوانید ترانزیشنهای منحنی مختلفی را اعمل کنید. برای مثال، اگر بخواهید یک ترانزیشن منحنی با انحنای زیاد داشته باشید، میتوانید از مقادیری نزدیک به 0 و 1 استفاده کنید. به طور کلی، با آزمایش و تغییر مقادیر پارامترها، میتوانید ترانزیشن منحنی دلخواه خود را به دست آورید.
سوال ۴: چگونه میتوان با استفاده از JavaScript رفتارهای تعاملی به منوی ناوبری اضافه کرد؟
پاسخ: برای اضافه کردن رفتارهای تعاملی به منوی ناوبری با استفاده از JavaScript، میتوانید از رویدادها و توابع جاوااسکریپت استفاده کنید. به طور معمول، شما میتوانید رویدادهای موس مانند `click` و `mouseover` را بر روی المانهای منو اعمال کنید تا عملکرد تعاملی را فعال کنید. برای مثال، با استفاده از رویداد `click`، میتوانید منو را باز و بسته کنید. همچنین، با استفاده از رویداد `mouseover` و `mouseout`، میتوانید تغییراتی مانند تغییر رنگ یا جلوههای دیگر به المانهای منو اعمال کنید. با استفاده از توابع جاوااسکریپت، میتوانید وضعیت منو را بررسی کنید و تغییراتی مانند اضافه کردن و حذف کلاسها را اعمال کنید تا جلوهها و رفتارهای مورد نظر را به منو اضافه کنید.
نتیجهگیری:
در این مقاله، یک منوی ناوبری جادویی و جذاب با استفاده از HTML، CSS و JavaScript طراحی کردیمو از جلوههای خارجی منحنی استفاده کردیم تا ظاهری زیبا و جذاب برای آن ایجاد کنیم. با استفاده از ساختار HTML، عناصر `<ul>` و `<li>` را برای لیست ناوبری و آیتمهای منوی ناوبری قرار دادیم. سپس با استفاده از استایل CSS، جلوههای منحنی را با استفاده از خواص مختلفی مانند `border-radius` و `transform` طراحی کردیم. در نهایت، با استفاده از JavaScript، رفتار و تعامل را به منوی ناوبری اضافه کردیم، مانند تغییر استایل آیتمها در هاور ماوس و نمایش زیرمنوها.
این طراحی منوی ناوبری جادویی با استفاده از HTML، CSS و JavaScript و جلوههای خارجی منحنی، به کاربران امکان میدهد به راحتی در سایت حرکت کنند و تجربه کاربری زیبا و جذابی را تجربه کنند. با استفاده از این روشها و تکنیکها، شما نیز میتوانید منوی ناوبری خود را به شکلی جالب و منحصر به فرد طراحی کنید و تجربه کاربری برتری را برای کاربرانتان ایجاد کنید.