Jalan Pintas untuk Menangani Perintah-Perintah JQuery di dalam Peraturan Kondisi
Dalam sebuah forum Saya pernah sekali diajari mengenai cara tersingkat untuk menangani perintah-perintah jQuery di dalam peraturan kondisi yang biasa dituliskan seperti ini:
if (statement) {
$(selector).method1();
} else {
$(selector).method2();
}
Kode di bawah ini adalah jalan pintas untuk kondisional di atas:
$(selector)[statement ? "method1" : "method2"]();
Pada awalnya Saya merasa bingung dengan sudut pandang yang orang tersebut berikan, sampai kemudian Saya menyadari bahwa pada dasarnya ini hanyalah sebuah jalan pintas peraturan if/else untuk memanggil item objek yang berbeda berdasarkan kondisi tertentu.
jQuery, pada dasarnya hanyalah sekumpulan fungsi yang dinyatakan di dalam objek. Kurang lebihnya seperti ini (memang tidak sama persis seperti ini, tapi setidaknya lumayan mirip):
var foo = {
addClass: function(param) { ... },
removeClass: function(param) { ... },
toggleClass: function(param) { ... },
hasClass: function(param) { ... }
...
}
Sehingga setiap fungsi bisa dipanggil dengan cara seperti ini:
foo.addClass('bar');
foo.removeClass('bar');
Atau seperti ini:
foo["addClass"]('bar');
foo["removeClass"]('bar');
Katakanlah kita ingin memanggil fungsi tertentu di dalam foo
hanya jika suatu kondisi terpenuhi. Jika kondisi tidak terpenuhi, maka fungsi cadangan yang lain akan dijalankan:
if (abc === true) {
foo["removeClass"]('bar');
} else {
foo["addClass"]('bar');
}
Yang mana jika diubah ke pernyataan kondisional ringkas akan menjadi seperti ini:
var x = (abc === true) ? "removeClass" : "addClass";
foo[x]('bar');
Sehingga kita bisa menyimpulkannya menjadi seperti ini:
foo[abc === true ? "removeClass" : "addClass"]('bar');
Contoh Penerapan
Berikut ini adalah contoh penerapan kondisional jalan pintas untuk menangani perintah .slideDown()
dan .fadeOut()
berdasarkan visibilitas panel:
Sebelum
$('h2').click(function() {
$(this).toggleClass('active');
if ($(this).next().is(':hidden')) {
$(this).next().slideDown();
} else {
$(this).next().fadeOut();
}
});
Sesudah
$('h2').click(function() {
$(this).toggleClass('active')
.next()[$(this).next().is(':hidden') ? "slideDown" : "fadeOut"]();
});
Labels: JavaScript, jQuery, Lanjutan, Masalah
6 Comments:
Ini berarti untuk mempersingkat kode yang panjang juga ya kak ?
By IRIL SAGITA, at Friday, May 3, 2013 at 4:20:00 PM GMT+7
Aduh lieur kang... can dugi elmu abdi kadinya :)
By Kang Ismet, at Friday, May 3, 2013 at 10:32:00 PM GMT+7
euh....sarua ateuh :p
By Beben Koben, at Saturday, May 4, 2013 at 9:55:00 AM GMT+7
aduh pusing ane mas ^_^
By Fajrin, at Sunday, May 5, 2013 at 8:06:00 AM GMT+7
Memperhatikan saja ini Mas,udah terlalu dalam sekali kodenya kalau saya lihat :)
By Anonymous, at Thursday, May 23, 2013 at 10:26:00 PM GMT+7
Komo deui ane lier....
By Anonymous, at Saturday, December 7, 2013 at 9:03:00 PM GMT+7
Post a Comment
<< Home