MooTools - Fx.Slide

Fx.Slides - это опция, которая позволяет отображать контент, перемещаясь в поле зрения. Это очень просто, но улучшает внешний вид вашего пользовательского интерфейса.

Давайте обсудим создание и инициализацию Fx.Slide, его параметры и методы.

Сначала мы инициализируем класс Fx.Slide пользовательским экземпляром. Для этого нам нужно создать и выбрать элемент HTML. После этого мы применим к этим элементам CSS. Наконец, мы инициируем новый экземпляр Fx.Slide с нашей переменной элемента.

Параметры Fx.Slide

Вариантов Fx.Slide всего два - режим и обертка.

Режим

Режим дает вам два варианта: «вертикальный» или «горизонтальный». По вертикали раскрывается сверху вниз, по горизонтали - слева направо. Нет возможности идти снизу вверх или справа налево, хотя я понимаю, что взломать сам класс для достижения этой цели относительно просто. На мой взгляд, это вариант, который я хотел бы видеть стандартным, и если кто-то взломал класс, чтобы разрешить эти варианты, напишите нам.

Обертка

По умолчанию Fx.Slide создает оболочку вокруг вашего элемента слайда, давая ему 'overflow': 'hidden'. Wrapper позволяет вам установить другой элемент в качестве оболочки. Как я уже сказал выше, я не понимаю, где это может пригодиться, и мне было бы интересно услышать какие-либо мысли (спасибо Horseweapon на mooforum.net за то, что помог мне прояснить это).

Fx.Slide методы

Fx.Slide также предлагает множество методов для отображения и скрытия вашего элемента.

slideIn ()

Как следует из названия, этот метод вызовет событие start и покажет ваш элемент.

выскользнуть()

Возвращает ваш элемент в скрытое состояние.

переключить ()

Это будет либо сдвигать элемент внутрь, либо наружу, в зависимости от его текущего состояния. Очень полезный метод добавления к событиям щелчка.

скрывать()

Это скроет элемент без эффекта скольжения.

Показать()

Это покажет элемент без эффекта скольжения.

Ярлыки Fx.Slide

Класс Fx.Slide также предоставляет несколько удобных ярлыков для добавления эффектов к элементу.

set ('слайд')

Вместо создания нового класса вы можете создать новый экземпляр, если «установите» слайд на элементе.

Syntax

slideElement.set('slide');

параметры настройки

Вы даже можете установить параметры с помощью ярлыка -

Syntax

slideElement.set('slide', {duration: 1250});

горка()

Как только слайд имеет значение .set (), вы можете запустить его с помощью метода .slide ().

Syntax

slideElement.slide('in');

.slide приму -

  • ‘in’
  • ‘out’
  • ‘toggle’
  • ’show’
  • ‘hide’

… Каждый соответствует описанным выше методам.

Example

Давайте рассмотрим пример, который объясняет о Fx.Slide. Взгляните на следующий код.

<!DOCTYPE html>
<html>
   
   <head>
      <style>
         .ind {
            width: 200px;
            padding: 10px;
            background-color: #87AEE1;
            font-weight: bold;
            border-bottom: 1px solid white;
         }
         .slide {
            margin: 20px 0; 
            padding: 10px;
            width: 200px;
            background-color: #F9E79F;
         }
         #slide_wrap {
            padding: 30px;
            background-color: #D47000;
         }
      </style>
      
      <script type = "text/javascript" src = "MooTools-Core-1.6.0.js"></script>
      <script type = "text/javascript" src = "MooTools-More-1.6.0.js"></script>
      
      <script type = "text/javascript">
         window.addEvent('domready', function() {
            var slideElement = $('slideA');
            
            var slideVar = new Fx.Slide(slideElement, {
               //Fx.Slide Options
               mode: 'horizontal', //default is 'vertical'
               
               //wrapper: this.element, //default is this.element
               //Fx Options
               link: 'cancel',
               transition: 'elastic:out',
               duration: 'long', 
               
               //Fx Events
               onStart: function(){
                  $('start').highlight("#EBCC22");
               },
               
               onCancel: function(){
                  $('cancel').highlight("#EBCC22");
               },
               
               onComplete: function(){
                  $('complete').highlight("#EBCC22");
               }
            }).hide().show().hide(); //note, .hide and .show do not fire events 

            $('openA').addEvent('click', function(){
               slideVar.slideIn();
            });

            $('closeA').addEvent('click', function(){
               slideVar.slideOut();
            });

            //EXAMPLE B
            var slideElementB = $('slideB');
            var slideVarB = new Fx.Slide(slideElementB, {
            
               //Fx.Slide Options
               mode: 'vertical', //default is 'vertical'
               link: 'chain', 
               
               //Fx Events
               onStart: function(){
                  $('start').highlight("#EBCC22");
               },
               
               onCancel: function(){
                  $('cancel').highlight("#EBCC22");
               },
               
               onComplete: function(){
                  $('complete').highlight("#EBCC22");
               }
            });

            $('openB').addEvent('click', function(){
               slideVarB.slideIn();
            });

            $('closeB').addEvent('click', function(){
               slideVarB.slideOut();
            });
         });
      </script>
   </head>

   <body>
      <div id = "start" class = "ind">Start</div>
      <div id = "cancel" class = "ind">Cancel</div>
      <div id = "complete" class = "ind">Complete</div>
 
      <button id = "openA">open A</button>
      <button id = "closeA">close A</button>

      <div id = "slideA" class = "slide">Here is some content - A. Notice the delay 
         before onComplete fires.  This is due to the transition effect, the onComplete 
         will not fire until the slide element stops "elasticing." Also, notice that 
         if you click back and forth, it will "cancel" the previous call and give the 
         new one priority.</div>
 
      <button id = "openB">open B</button>
      <button id = "closeB">close B</button>

      <div id = "slideB" class = "slide">Here is some content - B. Notice how 
         if you click me multiple times quickly I "chain" the events.  This slide is 
         set up with the option "link: 'chain'"</div>
         
   </body>
</html>

Output

Нажмите на кнопки - openA, closeA, openB и closeB. Наблюдайте за изменениями, эффектами и уведомлениями о событиях на индикаторах.