MooTools - Penggeser

Slider adalah fungsionalitas yang mencerminkan suatu tindakan saat menggeser kenop atau tombol apa pun. Anda dapat membuat penggeser Anda sendiri saat menentukan elemen, penangan, opsi, dan peristiwa panggilan balik. Mari kita bahas lebih lanjut tentang slider.

Membuat Slider Baru

Pertama-tama kita harus memilih elemen HTML yang sesuai untuk slider. Sambil mempertimbangkan ide dasarnya, elemen div adalah yang paling cocok untuk slider karena dengan menggunakan div, kita dapat membuat elemen anak. Kita sekarang harus mengatur CSS untuk div tersebut untuk membuat struktur div sebagai slider yang sempurna. Di sini, div induk adalah untukslider dan div turunan untuk knob.

Sekarang kita harus menggunakan div ini sebagai slider dengan meneruskan elemen ke konstruktor Slider sebagai sliderObject, dan knobObject. Lihatlah sintaks berikut untuk menentukan slider.

Sintaksis

var SliderObject = new Slider(sliderObject , knobObject , [,options,],..);

Kami juga harus menentukan opsi slider.

Opsi Slider

Mari kita bahas beberapa opsi yang digunakan untuk slider.

Jepret

Nilai sekejap bisa berupa nilai benar atau salah. Ini menentukan apakah kenop akan terkunci ke anak tangga saat diseret di sepanjang penggeser. Secara default, ini salah.

Mengimbangi

Ini adalah offset relatif kenop dari posisi awal. Cobalah bereksperimen dengan yang ini. Secara default, nilainya 0.

Jarak

Ini adalah opsi yang sangat berguna. Anda dapat mengatur kisaran angka yang akan dipecah langkah-langkahnya. Misalnya, jika rentang Anda adalah [0, 200] dan Anda memiliki 10 langkah, langkah Anda akan terpisah 20 langkah. Rentang ini juga dapat menyertakan angka negatif, misalnya [-10, 0], yang sangat berguna saat membalikkan scroll. Secara default, ini salah.

Roda

Setel roda ke true dan penggulung akan mengenali peristiwa roda mouse. Saat menggunakan roda mouse, Anda mungkin harus menyesuaikan kisaran untuk memastikan bahwa peristiwa roda mouse tidak tampak terbalik (sekali lagi, lebih banyak lagi nanti).

Langkah

Default 100 langkah sangat berguna karena mudah digunakan sebagai persentase. Namun, Anda dapat menetapkan sebanyak mungkin langkah (yang dapat digunakan) sesuai alasannya. Secara default, nilainya 100.

Mode

Mode akan menentukan apakah slider mendaftarkan dirinya sebagai vertikal atau horizontal. Namun, ada beberapa langkah lagi yang diperlukan untuk mengubah dari horizontal dan vertikal. Secara default, ini horizontal.

Acara Callback

Ada tiga peristiwa panggilan balik penting yang disediakan oleh Slider.

dalam perubahan

Setiap perubahan pada langkah saat ini memicu pelaksanaan acara. Lihat contoh yang diberikan di bawah ini untuk melihat kapan dijalankan.

onTick

Setiap perubahan posisi pegangan memicu pelaksanaan acara ini. Lihat contoh yang diberikan di bawah ini untuk melihat apa yang dijalankannya.

onComplete

Kejadian ini dijalankan setiap kali pegangan dilepaskan. Lihat contoh yang diberikan di bawah ini untuk melihat kapan dijalankan.

Contoh

Contoh berikut menjelaskan penggeser horizontal dan vertikal bersama dengan indikator peristiwa. Perhatikan kode berikut.

<!DOCTYPE html>
<html>

   <head>
      <style "text/css">
         #slider {
            width: 200px;
            height: 20px;
            background-color: #0099FF;
         }
         #knob {
            width: 20px;
            height: 20px;
            background-color: #993333;
         }
         #sliderv {
            width: 20px;
            height: 200px;
            background-color: #0099FF;
         }
         #knobv {
            width: 20px;
            height: 20px;
            background-color: #993333;
         }
         #change{
            background-color: burlywood;
            border: 2px solid black;
            width: 200px;
         }
         #complete{
            background-color: burlywood;
            border: 2px solid black;
            width: 200px;
         }
      </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 SliderObject = new Slider('slider', 'knob', {
               //options
               range: [0, 10],
               snap: false,
               steps: 10,
               offset: 0,
               wheel: true,
               mode: 'horizontal',
               
               //callback events
               onChange: function(step){
                  $('change').highlight('#F3F825');
                  $('steps_number').set('html', step);
               },
               
               onTick: function(pos){
                  $('tick').highlight('#F3F825');
                  $('knob_pos').set('html', pos);
                  
                  //this line is very necessary (left with horizontal)
                  this.knob.setStyle('left', pos);
               },
               
               onComplete: function(step){
                  $('complete').highlight('#F3F825')
                  $('steps_complete_number').set('html', step);
                  this.set(step);
               }
            });
            
            var SliderObjectV = new Slider('sliderv', 'knobv', {
               range: [-10, 0],
               snap: true,
               steps: 10,
               offset: 0,
               wheel: true,
               mode: 'vertical',
               onChange: function(step){
                  $('stepsV_number').set('html', step*-1);
               }
            });
            
            //sets the vertical one to start at 0
            //without this it would start at the top
            SliderObjectV.set(0);
            
            //sets the slider to step 7
            $('set_knob').addEvent('click', function(){ SliderObject.set(7)});
         });
      </script>
   </head>
   
   <body>
      <div id = "slider">
         <div id = "knob"></div>
      </div><br/><br/>
      
      <div id = "sliderv">
         <div id = "knobv"></div>
      </div><br/>
      
      <span id = "stepsV_number"></span> <br/>
      
      <div id = "change" class = "indicator">
         <strong>onChange</strong><br/>
         Passes the step you are on: <span id = "steps_number"></span>
      </div></br/>
      
      <div id = "complete" class = "indicator">
         <strong>onComplete</strong><br />
         passes the current step: <span id = "steps_complete_number"></span>
      </div>
      
   </body>
</html>

Keluaran

Klik pada kenop coklat pada slider horizontal atau vertikal lalu seret, Anda akan menemukan posisi langkah dan indikasi kejadian untuk setiap tindakan.