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.