Kita tahu beberapa operator pembanding dari matematika.
Didalam Javascript operator-operator itu ditulis seperi ini:
- Lebih besar/kurang dari:
a > b
,a < b
. - Lebih besar/kurang dari atau sama:
a >= b
,a <= b
. - Sama dengan:
a == b
, perhatikan tanda dua=
digunakan untuk test persamaan, jika menggunakan satu=
sepertia = b
itu adalah sebuah asignment atau memasukan nilai kedalam variabel. - Tidak sama dengan: Didalam matematika notasinya seperti
≠
, tetapi didalam Javascript ditulis sepertia != b
.
Didalam artikel ini kita akan belajar lebih lanjut tentang perbedaan tipe dari perbandingan, bagaimana cara Javascript membuatnya, termasuk sifat-sifat penting.
Diakhir nanti kamu akan menemukan hal yang bagus untuk menghindari masalah yang berhubungan dengan “kebiasaan Javascript”.
Boolean ialah hasilnya
Semua operator pembanding mengembalikan nilai boolean:
true
– berarti “ya”, “betul” atau “fakta”.false
– berarti “tidak”, “salah” atau “bukan fakta”.
Misalnya:
alert( 2 > 1 ); // true (benar)
alert( 2 == 1 ); // false (salah)
alert( 2 != 1 ); // true (benar)
Hasil perbandingan bisa ditetapkan ke variabel, sama seperti nilainya:
let result = 5 > 4; // tetapkan hasil perbandingan
alert( result ); // true
Perbandingan string
Untuk melihat apakah satu string lebih besar dari yang lain, JavaScript menggunakan yang disebut “kamus” atau urutan “lexicografik”.
Dengan keta lain, string diperbandingkan huruf-demi-huruf.
Misalnya:
alert( 'Z' > 'A' ); // true
alert( 'Glow' > 'Glee' ); // true
alert( 'Bee' > 'Be' ); // true
algoritma untuk membandingkan dua string sederhana:
- Bandingkan karakter pertama dari kedua string.
- Jika karakter pertama dari string pertama lebih besar (atau lebih kecil) dari string kedua, maka string pertama lebih besar (atau lebih kecil) dari string kedua. Kita selesai.
- Sebaliknya, jika karakter pertama kedua string sama, bandingkan karakter kedua dengan cara sama.
- Ulangi sampai string berakhir.
- Jika kedua string berakhir pada panjang yang sama, maka mereka sama. Sebaliknya, string lebih panjang yang lebih besar.
Pada contoh di atas, pembandingan 'Z' > 'A'
menghasilkan pada langkah pertama sedangkan string "Glow"
dan "Glee"
dibandingkan karakter-demi-karakter:
G
sama denganG
.l
sama denganl
.o
lebih besar darie
. Berhenti di sini. String pertama lebih besar.
Algoritma pembangingan yang diberikan di atas secara kasar equivalen dengan yang digunakan dalam kamus atau buku telpon, tapi tak sepenuhnya sama.
Misalnya, case diperhitungkan. Huruf besar "A"
tak sama dengan huruf kecil "a"
. Yang mana yang lebih besar? Huruf kecil "a"
. Kenapa? Karena karakter huruf kecil punya index lebih besar dalam tabel encoding internal yang dipakai JavaScript (Unicode). Kita akan kembali ke detil spesifik dan konsekuensinya dalam bab String.
Pembandingan dari tipe yang berbeda
Ketika membandingkan nilai dari tipe yang berbeda, JavaScript mengkonversi nilai tersebut ke angka.
Misalnya:
alert( '2' > 1 ); // true, string '2' menjadi angka 2
alert( '01' == 1 ); // true, string '01' menjadi angka 1
Untuk nilai boolean, true
menjadi 1
dan false
menjadi 0
.
Misalnya:
alert( true == 1 ); // true
alert( false == 0 ); // true
Memungkinkan juga bahwa pada saat yang sama:
- Dua nilai equal.
- Satu dari mereka
true
sebagai boolean dan satunya lagifalse
sebagai boolean.
Misalnya:
let a = 0;
alert( Boolean(a) ); // false
let b = "0";
alert( Boolean(b) ); // true
alert(a == b); // true!
Dari cara pandang JavaScript’, hasil ini terbilang normal. Pengecekan equalitas mengkonversi nilai menggunakan konversi numerik (jadi "0"
menjadi 0
), sedangkan konversi explisit Boolean
menggunakan set aturan yang lain.
Equalitas ketat
Pengecekan equalitas reguler ==
punya satu problem. Ia tak bisa membedakan 0
dari false
:
alert( 0 == false ); // true
Hal yang sama terjadi pada string kosong:
alert( '' == false ); // true
Ini terjadi karena operand dari tipe yang berbeda dikonversi ke angka oleh operator equalitas ==
. String kosong, sama seperti false
, menjadi nol.
Apa yang dilakukan jika kita ingin membedakan 0
dari false
?
Operator equalitas ketat ===
mengecek equalitas tanpa konversi tipe.
Dengan kata lain, jika a
dan b
tipenya berbeda, maka a === b
segera menghasilkan false
tanpa konversi apapun terhadap mereka.
Mari kita coba:
alert( 0 === false ); // false, karena tipenya berbeda
Ada juga operator “non-equalitas ketat” !==
yang analog dengan !=
.
Operator equalitas ketat sedikit lebih panjang untuk ditulis, tapi lebih memperlihatkan apa yang terjadi dan meninggalkan ruang lebih kecil untuk galat.
Pembandingan dengan null dan undefined
Ada sikap non-intuitif ketika null
atau undefined
diperbandingkan dengan nilai lain.
- Untuk pengecekan equalitas ketat
===
-
Nilai ini berbeda, karena setiap dari mereka tipenya berbeda.
alert( null === undefined ); // false
- Untuk pengecekan non-ketat
==
-
Ada aturan spesial. Kedyanya merupakan “pasangan manis”: mereka sama (karena
==
), tapi tidak dengan nilai lain manapun.alert( null == undefined ); // true
- Untuk pembandingan matematika dan lainnya
< > <= >=
-
null/undefined
dikonversi ke angka:null
menjadi0
, sedangkanundefined
menjadiNaN
.
Sekarang mari kita lihat beberapa hal lucu yang terjadi ketika kita menerapkan aturan ini. Dan, yang lebih penting, bagaimana supaya tidak jatuh ke dalam perangkap ini.
Hasil aneh: null vs 0
Mari kita bandingkan null
dengan nol:
alert( null > 0 ); // (1) false
alert( null == 0 ); // (2) false
alert( null >= 0 ); // (3) true
Secara matematik, ini aneh. Hasil terakhir menyatakan bahwa "null
lebih besar atau sama dengan nol", seharusnya salah satu dari pembandingan di atasnya true
, tapi nyatanya malah tidak.
Alasannya ialah pengecekan equalitas ==
dan pembandingan > < >= <=
bekerja secara berbeda. Pembandingan mengkonversi null
ke angka 0
. Itulah kenapa (3) null >= 0
true dan (1) null > 0
false.
Di sisi lain, pengecekan equalitas ==
untuk undefined
and null
dijelaskan bahwa, tanpa konversi apapun, mereka sama dengan satu sama lain dan tidak sama dengan nilai lain manapun. Itulah kenapa (2) null == 0
is false.
Uundefined yang tak bisa diperbandingkan
Nilai undefined
sebainya tak diperbandingkan dengan nilai lain:
alert( undefined > 0 ); // false (1)
alert( undefined < 0 ); // false (2)
alert( undefined == 0 ); // false (3)
Kenapa ia tak suka sekali dengan nol? Selalu false!
Kita dapatkan hasil ini karena:
- Pembandingan
(1)
dan(2)
menghasilkanfalse
karenaundefined
dikonversi keNaN
danNaN
merupakan numerik spesial yang mengembalikanfalse
untuk semua pembandingan. - Pengecekan equalitas
(3)
mengembalikanfalse
karenaundefined
hanya sama dengannull
dan tidak dengan nilai lain manapun.
Hindari problem
Kenapa kita menggunakan contoh ini? Haruskah kita ingat semua keanehan ini? Tidak juga. Sebenarnya, hal tricky macam ini akan menjadi akrab seiring waktu, tapi ada cara solid untuk menghindari masalah dengan mereka:
Perlakukan pembandingan manapun dengan undefined/null
kecuali equalitas ketat ===
dengan hati-hati.
Jangan gunakan pembandingan >= > < <=
dengan variabel yang bisa jadi null/undefined
, kecuali kamu paham apa yang kamu lakukan. Jika variabel bisa punya nilai ini, cek mereka secara terpisah.
Kesimpulan
- Operator pembandingan menghasilkan nilai boolean.
- String dibandingkan huruf-demi-huruf dalam urutan “kamus”.
- Ketika nilai dari tipe berbeda diperbandingkan, mereka dikonversi ke angka (kecuali pengecekan equalitas ketat).
- Nilai
null
danundefined
sama dengan==
satu sama lain dan tidak sama dengan nilai lain manapun. - Waspada ketika menggunakan pembandingan seperti
>
atau<
dengan variabel yang kadang bisa jadinull/undefined
. Pengecekan secara terpisahnull/undefined
merupakan ide yang bagus.