Konfigurasi jQuery UI Dialog
jQuery UI Dialog digunakan untuk menangani hal-hal yang berhubungan dengan komunikasi antarmuka antara aplikasi dengan pengguna. Karena tidak mungkin jika sebuah aplikasi bisa berbicara dan menyarankan sesuatu untuk dilakukan oleh pengguna, kotak dialog menjadi salah satu cara yang bisa digunakan untuk berkomunikasi.
Dasar Penggunaan
Buat sebuah elemen divisi sembarang, kemudian isi elemen tersebut dengan sesuatu. Seleksi elemen tersebut dengan jQuery, kemudian terapkan metode .dialog()
:
HTML
<div id="dialog">
Konten di sini...
</div>
jQuery UI
$('#dialog').dialog();
Konfigurasi jQuery UI Dialog
Opsi | Nilai | Deskripsi |
---|---|---|
title | "Judul Dialog" |
Menentukan judul kotak dialog. |
autoOpen | true |
Jika bernilai true , maka kotak dialog akan tampil pada saat halaman pertama kali diakses. Jika bernilai false , kotak dialog tidak akan tampil saat halaman diakses sampai sebuah pemicu memerintahkan kotak dialog tersebut untuk tampil. Pemicu biasanya berupa tombol atau suatu aksi (default: true ) |
false |
||
width | 100 , 200 , 300 , … |
Menentukan lebar kotak dialog (default: 300 ) |
height | 100 , 200 , 300 , … |
Menentukan tinggi kotak dialog (default: "auto" ) |
maxWidth | 100 , 200 , 300 , … |
Menentukan lebar maksimal kotak dialog (default: false ) |
maxHeight | 100 , 200 , 300 , … |
Menentukan tinggi maksimal kotak dialog (default: false ) |
minWidth | 100 , 200 , 300 , … |
Menentukan lebar minimal kotak dialog (default: 150 ) |
minHeight | 100 , 200 , 300 , … |
Menentukan tinggi minimal kotak dialog (default: 150 ) |
show | "fade" , "slide" , ... (efek jQuery UI) |
Menentukan efek khusus saat kotak dialog tampil (default: null ) |
hide | "fade" , "slide" , ... (efek jQuery UI) |
Menentukan efek khusus saat kotak dialog ditutup (default: null ) |
closeText | "close" , "tutup" , ... |
Menentukan teks pada tombol penutup kotak dialog di sebelah kanan atas. Secara umum tidak terlihat karena opsi ini memang tidak terlalu penting. Bahkan, dalam tema jQuery UI, teks ini juga tidak akan ditampilkan:.ui-dialog-titlebar-close span {display:none} (default: "close" ) |
modal | true | Pilihan untuk menampilkan tabir transparan saat kotak dialog muncul. (default: false ) |
false | ||
draggable | true | Pilihan untuk menentukan apakah kotak dialog dapat diseret (drag) atau tidak. (default: true ) |
false | ||
resizable | true | Pilihan untuk menentukan apakah kotak dialog dapat diubah ukurannya atau tidak. (default: true ) |
false | ||
buttons | { |
Menambahkan tombol di dalam kotak dialog. Bagian ini biasanya yang sedikit rumit, karena selain menampilkan tombol, Anda juga harus bisa membuat tombol tersebut berfungsi sehingga kotak dialog bisa hidup. |
Contoh Penerapan
autoOpen:false
Menentukan opsi autoOpen:false
akan membuat kotak dialog tidak muncul pada saat pertama kali halaman diakses dan hanya akan muncul jika diperintah.
Kita buat sebuah elemen divisi sebagai kotak dialog dan sebuah tombol sebagai pemicunya:
HTML
<div id="dialog">
Konten di sini...
</div>
<button id="open">Buka Dialog</button>
jQuery UI
$('#dialog').dialog({
autoOpen: false
});
$('#open').button({
icons: {
primary: "ui-icon-folder-open"
}
}).click(function() {
$('#dialog').dialog("open");
});
.dialog("open")
dan .dialog("close")
adalah metode yang digunakan untuk menampilkan dan menyembunyikan kotak dialog. Selain menggunakan opsi autoOpen:false
, menghilangkan kotak dialog juga bisa dilakukan dengan cara yang lebih sederhana yaitu dengan CSS atau dengan fungsi .hide()
:
#dialog {display:none}
$('#dialog').hide();
title:"Kotak Dialog", width:250, height:200
Menambahkan judul “Kotak Dialog” dan menentukan lebar kotak dialog sebesar 250 piksel dan tinggi kotak dialog sebesar 200 piksel:
$('#dialog').dialog({
title: "Kotak Dialog",
width: 250,
height: 200
});
show:"blind", hide:"puff"
Menciptakan efek blind
pada saat kotak dialog ditampilkan dan efek puff
pada saat kotak dialog ditutup:
HTML
<div id="dialog" style="display:none;">
Konten di sini...
</div>
<button id='open'>Buka Dialog</button>
jQuery UI
$('#open').button({
icons: {
primary: "ui-icon-folder-open"
}
}).click(function() {
$('#dialog').dialog({
title: "Kotak Dialog",
show: "blind",
hide: "puff"
});
});
modal:true
Menentukan opsi modal:true
akan menciptakan tabir di belakang kotak dialog saat kotak dialog ditampilkan:
$('#dialog').dialog({
title: "Kotak Dialog",
modal: true
});
$('#open').button({
icons: {
primary: "ui-icon-folder-open"
}
}).click(function() {
$('#dialog').dialog("open");
});
draggable:false, resizable:false
Menentukan opsi draggable:false
dan resizable:false
akan menonaktifkan fitur draggable dan resizable pada kotak dialog:
$('#dialog').dialog({
title: "Kotak Dialog",
draggable: false,
resizable: false
});
Menghidupkan Kotak Dialog
Tombol dalam kotak dialog dengan kemampuan untuk menjalankan perintah akan menghidupkan kotak dialog dan tidak hanya sekedar berakhir sebagai kotak peringatan. Anda bisa menciptakan kotak dialog yang dapat memerintahkan elemen lain untuk melakukan sesuatu.
Pada dasarnya, opsi buttons
dapat dituliskan seperti ini:
buttons: {
"OK": function() {
// Fungsi yang akan bekerja jika
// tombol `OK` diklik dibuat di sini...
},
"Cancel": function() {
// Fungsi yang akan bekerja jika
// tombol `Cancel` diklik dibuat di sini...
}
}
Sebagai contoh, kita akan membuat dua buah tombol dalam kotak dialog untuk mengendalikan elemen yang berada di luar kotak dialog:
HTML
<div id="dialog"></div>
<div id="kotak">Kendalikan Saya!</div>
CSS
#kotak {
width:170px;
height:200px;
background:#4AB847;
border:2px solid #369834;
padding:10px;
font-size:16px;
font-weight:bold;
color:white;
cursor:pointer;
}
jQuery UI
$('#dialog').dialog({
title: "Tombol dalam Dialog",
autoOpen: false,
buttons: {
"SlideUp": function() {
$('#kotak').slideUp(1000);
},
"SlideDown": function() {
$('#kotak').slideDown(1000);
}
}
});
// Tampilkan kotak dialog saat `#kotak` didekati pointer
$('#kotak').mouseenter(function() {
$('#dialog').dialog("open");
});
Modal Konfirmasi
Sebenarnya cara kerjanya sangat sederhana. Saat sebuah tombol diklik, itu akan memicu sebuah fungsi untuk menampilkan kotak konfirmasi. Salah satu tombol di dalam kotak konfirmasi merupakan perintah sebenarnya dari tombol yang diklik tadi. Sedangkan tombol yang Anda kira sebagai pemicu utama untuk menjalankan perintah sebenarnya hanyalah tombol untuk menampilkan kotak dialog konfirmasi:
HTML
<div class="separator">
<img class="item" alt="" src="my-image.jpg">
<button id="delete">Hapus Gambar!</button>
</div>
<div id="confirm-box">
<span class="ui-icon ui-icon-alert" style="float:left;margin:0 10px 50px 0;"></span>Apakah Anda yakin akan menghapus gambar ini? Hal ini tidak bisa dibatalkan dan gambar ini akan terhapus selamanya.
</div>
CSS
.separator {
position:relative;
float:left;
}
.separator button {
position:absolute;
top:10px;
left:10px;
}
jQuery UI
$('#confirm-box').dialog({
modal: true,
autoOpen: false,
title: "Konfirmasi",
buttons: {
"Ya": function() {
$('img.item').parent().hide("explode", {
pieces: 36
}, 1000);
$(this).dialog("close");
},
"Batal": function() {
$(this).dialog("close");
}
}
});
// Tampilkan kotak dialog konfirmasi saat tombol hapus diklik
$('#delete').button({
icons: {
primary: "ui-icon-trash"
}
}).click(function() {
$('#confirm-box').dialog("open");
});
11 Comments:
mas nih membutuhkan jQuery level atw versi berapa...?
By Anonymous, at Tuesday, March 6, 2012 at 9:11:00 PM GMT+7
gmana cara nerapin di post homepage mas? :Ozz
By Anonymous, at Monday, September 3, 2012 at 1:07:00 PM GMT+7
kayak gini kah ?
<script type='text/CSS'>
$('.post-outer').post-outer({
draggable:true,
resizable:false
});
</script>
By Anonymous, at Monday, September 3, 2012 at 1:09:00 PM GMT+7
Pertama-tama pasang dulu library JQuery UI setelah JQuery - Pelajari di sini, setelah itu baru kita bisa bekerja. Untuk kasusmu mungkin seperti ini:
<script type='text/javascript'>
$('.post-outer').dialog({
draggable:true,
resizable:false
});
</script>
Sampel lain: http://jsfiddle.net/tovic/2WLCU/20/
By Taufik Nurrohman, at Monday, September 3, 2012 at 2:16:00 PM GMT+7
mas fungsi itu buat tv gmn ?
By Anonymous, at Wednesday, September 12, 2012 at 12:32:00 AM GMT+7
kulo mboten ngertos iki kang ah, kode yang siap pakai lah kang biar lebih mudah dipahami, gatot soalnya
By Anonymous, at Wednesday, September 12, 2012 at 11:18:00 AM GMT+7
http://jsfiddle.net/tovic/2WLCU/26/
By Taufik Nurrohman, at Wednesday, September 12, 2012 at 4:50:00 PM GMT+7
This comment has been removed by the author.
By Anonymous, at Thursday, September 13, 2012 at 12:40:00 AM GMT+7
mas , source "Modal Konfirmasi" itu hanya untuk menghidden images ya,
By Unknown, at Monday, May 13, 2013 at 4:11:00 PM GMT+7
JQuery UI belum dipasang.
By Taufik Nurrohman, at Wednesday, October 2, 2013 at 7:13:00 AM GMT+7
Urutannya adalah CSS JQuery UI » JQuery » JQuery UI » Deklarasi Skrip:
<link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.10.1/themes/base/jquery-ui.css" rel="stylesheet"/>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.10.2/jquery-ui.min.js"></script>
<script>
$(document).ready(function() {
$('#confirm-box').dialog({
modal: true,
autoOpen: false,
title: "Konfirmasi",
buttons: {
"Ya": function() {},
"Batal": function() {}
}
});
});
</script>
Kode baris ke dua, kalau sudah ada tidak perlu disertakan lagi. Pindahkan posisinya supaya tampak seperti urutan skrip di atas. Lebih baik pelajari dulu dasarnya di sini.
By Taufik Nurrohman, at Thursday, October 3, 2013 at 7:32:00 AM GMT+7
Post a Comment
<< Home