Логин:
Пароль:
Страница 1 из 11
Форум » О uCoz » Скрипты » Вертикальное меню аккордеон
Вертикальное меню аккордеон
AndreyДата: Вторник, 24.12.2013, 18:17:33 | Сообщение # 1
Технарь
Offline
3

Ещё один аккордеон, только на этот раз в виде меню и с использованием JS

Мой тест на Фидле

Идём в CSS и прописываем стиль нашего аккордеона:
Код
.accordion,
.accordion ul,
.accordion li,
.accordion a,
.accordion span {
   margin: 0;
   padding: 0;
   border: none;
   outline: none;
}

.accordion li {
   list-style: none;
}

/* Layout & Style */

.accordion li > a {
   display: block;
   position: relative;
   min-width: 110px;
   padding: 0 10px 0 40px;
   height: 32px;

   color: #fdfdfd;
   font: bold 12px/32px Arial, sans-serif;
   text-decoration: none;
   text-shadow: 0px 1px 0px rgba(0,0,0, .35);

   background: #6c6e74;
   background: -moz-linear-gradient(top,  #6c6e74 0%, #4b4d51 100%);
   background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#6c6e74), color-stop(100%,#4b4d51));
   background: -webkit-linear-gradient(top,  #6c6e74 0%,#4b4d51 100%);
   background: -o-linear-gradient(top,  #6c6e74 0%,#4b4d51 100%);
   background: -ms-linear-gradient(top,  #6c6e74 0%,#4b4d51 100%);
   background: linear-gradient(top,  #6c6e74 0%,#4b4d51 100%);

   -webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
   -moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
   box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
}

.accordion > li:hover > a,
.accordion > li:target > a,
.accordion > li > a.active {
   color: #3e5706;
   text-shadow: 1px 1px 1px rgba(255,255,255, .2);
     
   background: #a5cd4e;
   background: -moz-linear-gradient(top,  #a5cd4e 0%, #6b8f1a 100%);
   background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#a5cd4e), color-stop(100%,#6b8f1a));
   background: -webkit-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%);
   background: -o-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%);
   background: -ms-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%);
   background: linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%);   
}

.accordion li > a span {
   display: block;
   position: absolute;
   top: 7px;
   right: 0;
   padding: 0 10px;
   margin-right: 10px;
     
   font: normal bold 12px/18px Arial, sans-serif;
   background: #404247;
     
   -webkit-border-radius: 15px;
   -moz-border-radius: 15px;
   border-radius: 15px;

   -webkit-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
   -moz-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
   box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
}

.accordion > li:hover > a span,
.accordion > li:target > a span,
.accordion > li > a.active span {
   color: #fdfdfd;
   text-shadow: 0px 1px 0px rgba(0,0,0, .35);
   background: #3e5706;
}

/* Images */

.accordion > li > a:before {
   position: absolute;
   top: 0;
   left: 0;
   content: '';
   width: 24px;
   height: 24px;
   margin: 4px 8px;

   background-repeat: no-repeat;
   background-position: 0px 0px;
}

.accordion li.files > a:before { background-position: 0px 0px; }
.accordion li.files:hover > a:before,
.accordion li.files:target > a:before,
.accordion li.files > a.active:before { background-position: 0px -24px; }

.accordion li.mail > a:before { background-position: -24px 0px; }
.accordion li.mail:hover > a:before,
.accordion li.mail:target > a:before,
.accordion li.mail > a.active:before { background-position: -24px -24px; }

.accordion li.cloud > a:before { background-position: -48px 0px; }
.accordion li.cloud:hover > a:before,
.accordion li.cloud:target > a:before,
.accordion li.cloud > a.active:before { background-position: -48px -24px; }

.accordion li.sign > a:before { background-position: -72px 0px; }
.accordion li.sign:hover > a:before,
.accordion li.sign:target > a:before,
.accordion li.sign > a.active:before { background-position: -72px -24px; }

/* Sub Menu */

.sub-menu li a {
   color: #797979;
   text-shadow: 1px 1px 0px rgba(255,255,255, .2);

   background: #e5e5e5;
   border-bottom: 1px solid #c9c9c9;

   -webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
   -moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
   box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
}

.sub-menu li:hover a { background: #efefef; }

.sub-menu li:last-child a { border: none; }

.sub-menu li > a span {
   color: #797979;
   text-shadow: 1px 1px 0px rgba(255,255,255, .2);
   background: transparent;
   border: 1px solid #c9c9c9;

   -webkit-box-shadow: none;
   -moz-box-shadow: none;
   box-shadow: none;
}

.sub-menu em {
   position: absolute;
   top: 0;
   left: 0;
   margin-left: 14px;
   color: #a6a6a6;
   font: normal 10px/32px Arial, sans-serif;
}

/* Functionality */

.accordion li > .sub-menu {
   display: none;
}

.accordion li:target > .sub-menu {
   display: block;
}


Теперь где хотите видеть сам аккордеон, вставляем:
Код
<ul class="accordion">
       
     <li id="one" class="files">

      <a href="#" class="">Мои файлы<span>495</span></a>

      <ul class="sub-menu" style="display: none; ">
         
       <li><a href="#"><em>01</em>Dropbox<span>42</span></a></li>
         
       <li><a href="#"><em>02</em>Skydrive<span>87</span></a></li>

       <li><a href="#"><em>03</em>FTP Сервер<span>366</span></a></li>

       <li><a href="#"><em>04</em>Google Drive<span>1</span></a></li>
         
       <li><a href="#"><em>05</em>Skydrive<span>10</span></a></li>

      </ul>

     </li>
       
     <li id="two" class="mail">

      <a href="#" class="">Почта<span>26</span></a>

      <ul class="sub-menu" style="display: none; ">
         
       <li><a href="#"><em>01</em>Gmail<span>9</span></a></li>
         
       <li><a href="#"><em>02</em>Yandex<span>14</span></a></li>

      </ul>

     </li>
       
     <li id="three" class="cloud">

      <a href="#" class="">Работа<span>58</span></a>

      <ul class="sub-menu" style="display: none; ">
         
       <li><a href="#"><em>01</em>Отправка<span>12</span></a></li>
         
       <li><a href="#"><em>02</em>Сайты<span>19</span></a></li>

       <li><a href="#"><em>03</em>Сделать<span>27</span></a></li>

       <li><a href="#"><em>04</em>Пароли<span>12</span></a></li>
         
       <li><a href="#"><em>05</em>Профили<span>19</span></a></li>

       <li><a href="#"><em>06</em>Опции<span>27</span></a></li>

      </ul>

     </li>
       
     <li id="four" class="sign">

      <a href="#" class="active">Войти</a>

      <ul class="sub-menu" style="display: block; ">
         
       <li><a href="#"><em>01</em>Выход</a></li>
         
       <li><a href="#"><em>02</em>Удалить профиль</a></li>

       <li><a href="#"><em>03</em>Параметры</a></li>

      </ul>

     </li>
      
</ul>


Теперь подключаем два JS скрипта, прописываем их между <body> и </body>:
Код
<script type="text/javascript" src="js/jquery.min.js"></script>
   <script type="text/javascript">

    $(document).ready(function() {

       
     var accordion_head = $('.accordion > li > a'),
      accordion_body = $('.accordion li > .sub-menu');

     accordion_head.first().addClass('active').next().slideDown('normal');

     accordion_head.on('click', function(event) {
        
      event.preventDefault();

      if ($(this).attr('class') != 'active'){
       accordion_body.slideUp('normal');
       $(this).next().stop(true,true).slideToggle('normal');
       accordion_head.removeClass('active');
       $(this).addClass('active');
      }

     });

    });

   </script>


Прикреплённый архив заливаем к себе на хост в папку "js"

Вот и всё, наше меню аккордеон установлено!

Материал подготовил: Andrey
Для того чтоб скачать прикреплённые файлы нужно Зарегестрироватся, или войти на сайт под своим логином
 
профиль
Форум » О uCoz » Скрипты » Вертикальное меню аккордеон
Страница 1 из 11
Поиск: