21 Haz 2021 07:44 Yeni Konu Oluştur

Haberler:

Üye kayıt esnasında E-posta adresinizin doğru olduğuna ve Aktivasyon Mailinize bakmayı unutmayın.


smf 2.1 responsive menü 1 (responsive menu)

Başlatan snrj, 16 Şub 2015 13:01

« önceki - sonraki »

0 Üye ve 1 Ziyaretçi konuyu incelemekte.

*

  1. 3,084

  2. 584

  3. 973



index.template.php de bul
echo '
<div id="main_menu">
<ul class="dropmenu" id="menu_nav">';

// Note: Menu markup has been cleaned up to remove unnecessary spans and classes.
foreach ($context['menu_buttons'] as $act => $button)
{
echo '
<li id="button_', $act, '"', !empty($button['sub_buttons']) ? ' class="subsections"' :'', '>
<a', $button['active_button'] ? ' class="active"' : '', ' href="', $button['href'], '"', isset($button['target']) ? ' target="' . $button['target'] . '"' : '', '>
', $button['icon'], $button['title'], '
</a>';

if (!empty($button['sub_buttons']))
{
echo '
<ul>';

foreach ($button['sub_buttons'] as $childbutton)
{
echo '
<li', !empty($childbutton['sub_buttons']) ? ' class="subsections"' :'', '>
<a href="', $childbutton['href'], '"' , isset($childbutton['target']) ? ' target="' . $childbutton['target'] . '"' : '', '>
', $childbutton['title'], '
</a>';
// 3rd level menus :)
if (!empty($childbutton['sub_buttons']))
{
echo '
<ul>';

foreach ($childbutton['sub_buttons'] as $grandchildbutton)
echo '
<li>
<a href="', $grandchildbutton['href'], '"' , isset($grandchildbutton['target']) ? ' target="' . $grandchildbutton['target'] . '"' : '', '>
', $grandchildbutton['title'], '
</a>
</li>';

echo '
</ul>';
}

echo '
</li>';
}
echo '
</ul>';
}
echo '
</li>';
}

echo '
</ul>
</div>';

değiştir
echo '<script src="',$settings['theme_url'],'/scripts/modernizr.custom.js"></script>
<div class="main clearfix"><nav id="menu2" class="nav2"><ul> ';

// Note: Menu markup has been cleaned up to remove unnecessary spans and classes.
foreach ($context['menu_buttons'] as $act => $button)
{
echo '
<li id="button_', $act, '"', !empty($button['sub_buttons']) ? ' ' :'', '>
<a', $button['active_button'] ? ' ' : '', ' href="', $button['href'], '"', isset($button['target']) ? ' target="' . $button['target'] . '"' : '', '>
<span class="icon">', $button['icon'],'</span><span>', $button['title'], '</span>
</a>';

echo '
</li>';
}

echo '
</ul></nav>
</div><script>
var changeClass = function (r,className1,className2) {
var regex = new RegExp("(?:^|\\s+)" + className1 + "(?:\\s+|$)");
if( regex.test(r.className) ) {
r.className = r.className.replace(regex,\' \'+className2+\' \');
    }
    else{
r.className = r.className.replace(new RegExp("(?:^|\\s+)" + className2 + "(?:\\s+|$)"),\' \'+className1+\' \');
    }
    return r.className;
};

var menu2Elements = document.getElementById(\'menu2\');
menu2Elements.insertAdjacentHTML(\'afterBegin\',\'<button type="button" id="menu2toggle" class="nav2toogle" aria-hidden="true">Menu</button>\');

document.getElementById(\'menu2toggle\').onclick = function() {
changeClass(this, \'nav2toogle active\', \'nav2toogle\');
}

document.onclick = function(e) {
var mobileButton = document.getElementById(\'menu2toggle\'),
buttonStyle =  mobileButton.currentStyle ? mobileButton.currentStyle.display : getComputedStyle(mobileButton, null).display;

if(buttonStyle === \'block\' && e.target !== mobileButton && new RegExp(\' \' + \'active\' + \' \').test(\' \' + mobileButton.className + \' \')) {
changeClass(mobileButton, \'nav2toogle active\', \'nav2toogle\');
}
}
</script>';

index.css de en alta ekle
/* Global CSS that are applied for all screen sizes */

.nav2 ul {
max-width: 1240px;
margin: 0;
padding: 0;
list-style: none;
font-size: 1.5em;
font-weight: 300;
}


.nav2 a {
display: block;
color: rgba(249, 249, 249, .9);
text-decoration: none;
-webkit-transition: color .5s, background .5s, height .5s;
-moz-transition: color .5s, background .5s, height .5s;
-o-transition: color .5s, background .5s, height .5s;
-ms-transition: color .5s, background .5s, height .5s;
transition: color .5s, background .5s, height .5s;
}

/* Hover effect for the whole nav2igation to make the hovered item stand out */

.no-touch .nav2 ul:hover a {
color: rgba(249, 249, 249, .5);
}

.no-touch .nav2 ul:hover a:hover {
color: rgba(249, 249, 249, 0.99);
}

/* Adding some background color to the different menu2 items */

.nav2 li:nth-child(6n+1) {
background: rgb(208, 101, 3);
}

.nav2 li:nth-child(6n+2) {
background: rgb(233, 147, 26);
}

.nav2 li:nth-child(6n+3) {
background: rgb(22, 145, 190);
}

.nav2 li:nth-child(6n+4) {
background: rgb(22, 107, 162);
}

.nav2 li:nth-child(6n+5) {
background: rgb(27, 54, 71);
}

.nav2 li:nth-child(6n+6) {
background: rgb(21, 40, 54);
}

/* For screen bigger than 800px */
@media (min-width: 50em) {

/* Transforms the list into a horizontal nav2igation */
.nav2 li {
float: left;
width: 16.66666666666667%;
text-align: center;
-webkit-transition: border .5s;
-moz-transition: border .5s;
-o-transition: border .5s;
-ms-transition: border .5s;
transition: border .5s;
}

.nav2 a {
display: block;
width: auto;
}

/* hover, focused and active effects that add a little colored border to the different items */
.no-touch .nav2 li:nth-child(6n+1) a:hover,
.no-touch .nav2 li:nth-child(6n+1) a:active,
.no-touch .nav2 li:nth-child(6n+1) a:focus {
border-bottom: 4px solid rgb(174, 78, 1);
}

.no-touch .nav2 li:nth-child(6n+2) a:hover,
.no-touch .nav2 li:nth-child(6n+2) a:active,
.no-touch .nav2 li:nth-child(6n+2) a:focus {
border-bottom: 4px solid rgb(191, 117, 20);
}

.no-touch .nav2 li:nth-child(6n+3) a:hover,
.no-touch .nav2 li:nth-child(6n+3) a:active,
.no-touch .nav2 li:nth-child(6n+3) a:focus {
border-bottom: 4px solid rgb(12, 110, 149);
}

.no-touch .nav2 li:nth-child(6n+4) a:hover,
.no-touch .nav2 li:nth-child(6n+4) a:active,
.no-touch .nav2 li:nth-child(6n+4) a:focus {
border-bottom: 4px solid rgb(10, 75, 117);
}

.no-touch .nav2 li:nth-child(6n+5) a:hover,
.no-touch .nav2 li:nth-child(6n+5) a:active,
.no-touch .nav2 li:nth-child(6n+5) a:focus {
border-bottom: 4px solid rgb(16, 34, 44);
}

.no-touch .nav2 li:nth-child(6n+6) a:hover,
.no-touch .nav2 li:nth-child(6n+6) a:active,
.no-touch .nav2 li:nth-child(6n+6) a:focus {
border-bottom: 4px solid rgb(9, 18, 25);
}

/* Placing the icon */

.icon {
padding-top: 1.4em;
}

.icon + span {
margin-top: 2.1em;
-webkit-transition: margin .5s;
-moz-transition: margin .5s;
-o-transition: margin .5s;
-ms-transition: margin .5s;
transition: margin .5s;
}

/* Animating the height of the element*/
.nav2 a {
height: 26px;
}

.no-touch .nav2 a:hover ,
.nav2 a:active ,
.nav2 a:focus {
height: 28px;
}

/* Making the text follow the height animation */
.no-touch .nav2 a:hover .icon + span {
margin-top: 3.2em;
-webkit-transition: margin .5s;
-moz-transition: margin .5s;
-o-transition: margin .5s;
-ms-transition: margin .5s;
transition: margin .5s;
}

/* Positioning the icons and preparing for the animation*/
.nav2 i {
position: relative;
display: inline-block;
margin: 0 auto;
padding: 0.4em;
border-radius: 50%;
font-size: 1.8em;
box-shadow: 0 0 0 30px transparent;
background: rgba(255,255,255,0.1);
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-o-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
-webkit-transition: box-shadow .6s ease-in-out;
-moz-transition: box-shadow .6s ease-in-out;
-o-transition: box-shadow .6s ease-in-out;
-ms-transition: box-shadow .6s ease-in-out;
transition: box-shadow .6s ease-in-out;
}

/* Animate the box-shadow to create the effect */
.no-touch .nav2 a:hover i,
.no-touch .nav2 a:active i,
.no-touch .nav2 a:focus i {
box-shadow: 0 0 0 0 rgba(255,255,255,0.2);
-webkit-transition: box-shadow .4s ease-in-out;
-moz-transition: box-shadow .4s ease-in-out;
-o-transition: box-shadow .4s ease-in-out;
-ms-transition: box-shadow .4s ease-in-out;
transition: box-shadow .4s ease-in-out;
}

}

@media (min-width: 50em) and (max-width: 61.250em) {

/* Size and font adjustments to make it fit into the screen*/
.nav2 ul {
font-size: 1.2em;
}

}

/* The "tablet" and "mobile" version */

@media (max-width: 49.938em) {

/* Instead of adding a border, we transition the background color */
.no-touch .nav2 ul li:nth-child(6n+1) a:hover,
.no-touch .nav2 ul li:nth-child(6n+1) a:active,
.no-touch .nav2 ul li:nth-child(6n+1) a:focus {
background: rgb(227, 119, 20);
}

.no-touch .nav2 li:nth-child(6n+2) a:hover,
.no-touch .nav2 li:nth-child(6n+2) a:active,
.no-touch .nav2 li:nth-child(6n+2) a:focus {
background: rgb(245, 160, 41);
}

.no-touch .nav2 li:nth-child(6n+3) a:hover,
.no-touch .nav2 li:nth-child(6n+3) a:active,
.no-touch .nav2 li:nth-child(6n+3) a:focus {
background: rgb(44, 168, 219);
}

.no-touch .nav2 li:nth-child(6n+4) a:hover,
.no-touch .nav2 li:nth-child(6n+4) a:active,
.no-touch .nav2 li:nth-child(6n+4) a:focus {
background: rgb(31, 120, 176);
}

.no-touch .nav2 li:nth-child(6n+5) a:hover,
.no-touch .nav2 li:nth-child(6n+5) a:active,
.no-touch .nav2 li:nth-child(6n+5) a:focus {
background: rgb(39, 70, 90);
}

.no-touch .nav2 li:nth-child(6n+6) a:hover,
.no-touch .nav2 li:nth-child(6n+6) a:active,
.no-touch .nav2 li:nth-child(6n+6) a:focus {
background: rgb(32, 54, 68);
}

.nav2 ul li {
-webkit-transition: background 0.5s;
-moz-transition: background 0.5s;
-o-transition: background 0.5s;
-ms-transition: background 0.5s;
transition: background 0.5s;
}

}

/* CSS specific to the 2x3 columns version */
@media (min-width:32.5em) and (max-width: 49.938em) {

/* Creating the 2 column layout using floating elements once again */
.nav2 li {
display: block;
float: left;
width: 50%;
}

/* Adding some padding to make the elements look nicer*/
.nav2 a {
padding: 0.8em;
}

/* Displaying the icons on the left, and the text on the right side using inlin-block*/
.nav2 li span,
.nav2 li span.icon {
display: inline-block;
}

.nav2 li span.icon {
width: 50%;
}

.nav2 li .icon + span {
font-size: 1em;
}

.icon + span {
position: relative;
top: -0.2em;
}

/* Adaptating to the icons to animate the size and border of the rounded background in a more discreet way */
.nav2 li i {
display: inline-block;
padding: 8% 9%;
border: 4px solid transparent;
border-radius: 50%;
font-size: 1.5em;
background: rgba(255,255,255,0.1);
-webkit-transition: border .5s;
-moz-transition: border .5s;
-o-transition: border .5s;
-ms-transition: border .5s;
transition: border .5s;
}

/* Transition effect on the border color */
.no-touch .nav2 li:hover i,
.no-touch .nav2 li:active i,
.no-touch .nav2 li:focus i {
border: 4px solid rgba(255,255,255,0.1);
}

}

/* Adapting the font size and width for smaller screns*/
@media (min-width: 32.5em) and (max-width: 38.688em) {

.nav2 li span.icon {
width: 50%;
}

.nav2 li .icon + span {
font-size: 0.9em;
}
}

/* Styling the toggle menu2 link and hiding it */
.nav2 .nav2toogle{
display: none;
width: 100%;
padding: 0.5em 0.5em 0.8em;
font-family: 'Lato',Calibri,Arial,sans-serif;
font-weight: normal;
text-align: left;
color: rgb(7, 16, 15);
font-size: 1.2em;
background: none;
border: none;
border-bottom: 4px solid rgb(221, 221, 221);
cursor: pointer;
}

.nav2toogle i{
z-index:-1;
}

.icon-menu2 {
position: relative;
top: 3px;
line-height: 0;
font-size: 1.6em;
}

@media (max-width: 32.438em) {

/* Unhiding the styled menu2 link */
.nav2 .nav2toogle{
margin: 0;
display: block;
}

/* Animating the height of the nav2igation when the button is clicked */

/* When JavaScript is disabled, we hide the menu2 */
.no-js .nav2 ul {
max-height: 30em;
overflow: hidden;
}

/* When JavaScript is enabled, we hide the menu2 */
.js .nav2 ul {
max-height: 0em;
overflow: hidden;
}

/* Displaying the menu2 when the user has clicked on the button*/
.js .nav2 .active + ul {
max-height: 30em;
overflow: hidden;
-webkit-transition: max-height .4s;
-moz-transition: max-height .4s;
-o-transition: max-height .4s;
-ms-transition: max-height .4s;
transition: max-height .4s;
}

/* Adapting the layout of the menu2 for smaller screens : icon on the left and text on the right*/

.nav2 li span {
display: inline-block;
}

.nav2 a {
padding: 0.5em;
}

.icon + span {
margin-left: 1em;
font-size: 0.8em;
}

/* Adding a left border of 8 px with a different color for each menu2 item*/
.nav2 li:nth-child(6n+1) {
border-left: 8px solid rgb(174, 78, 1);
}

.nav2 li:nth-child(6n+2) {
border-left: 8px solid rgb(191, 117, 20);
}

.nav2 li:nth-child(6n+3) {
border-left: 8px solid rgb(13, 111, 150);
}

.nav2 li:nth-child(6n+4) {
border-left: 8px solid rgb(10, 75, 117);
}

.nav2 li:nth-child(6n+5) {
border-left: 8px solid rgb(16, 34, 44);
}

.nav2 li:nth-child(6n+6) {
border-left: 8px solid rgb(9, 18, 25);
}

/* make the nav2 bigger on touch screens */
.touch .nav2 a {
padding: 0.8em;
}
}


ekteki js dosyasını temanızın scripts klasörüne atın



  1. 632

  2. 251


MENU ×