بسم الله الرحمن الرحيم
أهلاً وسهلاً بزوار بلوجر فيومي"> بلوجر فيومي!
في المقال ده ، هنتكلم عن كيفية إنشاء قائمة علوية متجاوبة تتضمن قائمة جانبية وقوائم منسدله وزر للترجمه وتكبير الشاشه باستخدام HTML وCSS وجافا سكريبت. ومكتبات font-awesome و google translate يمكنك الاطلاع ايضا على كيفية تضمين مكتبة خارجية في مدونتك من خلال الرابط التالي: كيفية تضمين مكتبة خارجية.
لو حابب تجرب القائمة قبل تضمينها ممكن تجربها عن طريق اداة تحرير ومعاينة الاكواد هنا
الخطوات:
1. هيكل القائمة العلوية والقائمة الجانبية:
أولاً، استخدم الكود التالي لإنشاء القائمة العلوية وقائمة جانبية. يجب وضع هذا الكود داخل وسم <body> في قالب بلوجر:
<nav class="navbar"> <div class="navbar-title"> <h1>عنوان القائمة</h1> </div> <ul class="navbar-nav"> <li class="nav-item"> <a class="nav-link" href="#" onclick="blfymOpenModal('languageModal')"><i class="fas fa-globe"></i></a> </li> <li class="nav-item"> <a class="nav-link" href="#" onclick="blfymToggleFullscreen()"><i class="fas fa-expand"></i></a> </li> <li class="nav-item"> <a class="nav-link" href="#" onclick="blfymOpenNav()"><i class="fas fa-bars"></i></a> </li> </ul> </nav> <div id="languageModal" class="modal"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title">اختيار اللغة</h5> <span class="close" onclick="blfymCloseModal('languageModal')">×</span> </div> <div class="modal-body"> <div id="google_translate_element"></div> </div> </div> </div> </div> <div id="mySidebar" class="sidebar"> <a href="javascript:void(0)" class="closebtn" onclick="blfymCloseNav()">×</a> <a href="#">رابط 1</a> <a href="#">رابط 2</a> <a href="#">رابط 3</a> <a href="javascript:void(0)" class="dropdown-btn" onclick="blfymToggleDropdown(this)">قائمة منسدلة 1</a> <ul> <li><a href="#">عنصر 1</a></li> <li><a href="#">عنصر 2</a></li> </ul> <a href="javascript:void(0)" class="dropdown-btn" onclick="blfymToggleDropdown(this)">قائمة منسدلة 2</a> <ul> <li><a href="#">عنصر 3</a></li> <li><a href="#">عنصر 4</a></li> </ul> </div>
2. إضافة CSS لتصميم القوائم:
أضف الكود التالي إلى وسم <b:skin> في قالب بلوجر لتحسين تصميم القوائم:
/* CSS للقائمة العلوية */ .navbar { background: linear-gradient(45deg, #0099ff, #33ccff); color: white; padding: 10px; display: flex; justify-content: space-between; align-items: center; } .navbar-title { flex-grow: 1; text-align: center; } .navbar-title h1 { margin: 0; font-size: 20px; } .navbar-nav { list-style: none; margin: 0; padding: 0; display: flex; } .navbar-nav .nav-item { margin-right: 15px; } .navbar-nav .nav-item .nav-link { color: white; text-decoration: none; font-size: 16px; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background-color: rgba(255, 255, 255, 0.2); transition: background-color 0.3s; } .navbar-nav .nav-item .nav-link:hover { background-color: rgba(255, 255, 255, 0.4); } .sidebar { height: 100%; width: 250px; position: fixed; top: 0; right: -250px; background-color: #333; transition: 0.3s; overflow-x: hidden; padding-top: 60px; } .sidebar a { padding: 10px 15px; text-decoration: none; font-size: 18px; color: #f1f1f1; display: block; transition: 0.3s; } .sidebar a:hover { background-color: #575757; } .sidebar .closebtn { position: absolute; top: 0; left: 0; font-size: 30px; margin-right: 20px; } .sidebar ul { display: none; list-style-type: none; padding-left: 20px; } .sidebar a.active + ul { display: block; } .modal { display: none; position: fixed; z-index: 1; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0, 0, 0, 0.4); } .modal-dialog { margin: 15% auto; padding: 20px; border: 1px solid #888; width: 80%; background-color: white; } .modal-header, .modal-body { padding: 10px; } .modal-header { border-bottom: 1px solid #888; } .modal-title { font-size: 20px; } .close { color: #aaa; font-size: 28px; font-weight: bold; float: right; cursor: pointer; } .close:hover, .close:focus { color: black; text-decoration: none; cursor: pointer; } @media (max-width: 768px) { .navbar-nav { flex-direction: column; display: none; } .navbar-nav.show { display: flex; } .navbar-toggler { display: block; cursor: pointer; } }
3. إضافة جافا سكريبت لتفاعل القوائم:
استخدم الكود التالي في ملف JavaScript لتفعيل القائمة العلوية المتجاوبة والقائمة الجانبية. يجب وضع هذا الكود في قسم <head> أو في ملف JavaScript مرتبط:
<script> function blfymToggleFullscreen() { if (!document.fullscreenElement) { document.documentElement.requestFullscreen(); } else { if (document.exitFullscreen) { document.exitFullscreen(); } } } function blfymOpenNav() { document.getElementById("mySidebar").style.right = "0"; } function blfymCloseNav() { document.getElementById("mySidebar").style.right = "-250px"; } function blfymOpenModal(modalId) { document.getElementById(modalId).style.display = "block"; } function blfymCloseModal(modalId) { document.getElementById(modalId).style.display = "none"; } function blfymToggleDropdown(element) { var dropdown = element.nextElementSibling; if (dropdown.style.display === "block") { dropdown.style.display = "none"; } else { dropdown.style.display = "block"; } } </script>
4. اضافة المكتبات الازمة لتشغيل القائمة
يجب اضافة هذه المكتبات للتاكد من ان الترجمه والايقونات ستعمل بشكل صحيح
font-awesome & google translate
توضع الاكواد التاليه فوق الوسم
<head>
<script type="text/javascript"> function googleTranslateElementInit() { new google.translate.TranslateElement({pageLanguage: 'ar'}, 'google_translate_element'); } </script> <script type="text/javascript" src="//translate.google.com/translate_a/element.js?cb=googleTranslateElementInit"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
باتباع الخطوات أعلاه، يمكنك إنشاء قائمة علوية متجاوبة مع قائمة جانبية باستخدام HTML وCSS وجافا سكريبت. هذا سيساعدك في تحسين تجربة المستخدم على موقعك ويجعل القوائم أكثر تفاعلية.