04/2020: Jawaban lama terkoreksi
Gunakan : pemilih psuedo yang dipilih pada opsi yang dipilih dan kemudian gunakan fungsi .val untuk mendapatkan nilai opsi.
$('select[name=selector] option').filter(':selected').val()
Catatan samping : Menggunakan filter lebih baik daripada menggunakan :selected
pemilih langsung di permintaan pertama.
Jika di dalam change handler, Anda bisa menggunakan hanya this.value
untuk mendapatkan nilai opsi yang dipilih. Lihat demo untuk opsi lainnya.
//ways to retrieve selected option and text outside handler
console.log('Selected option value ' + $('select option').filter(':selected').val());
console.log('Selected option value ' + $('select option').filter(':selected').text());
$('select').on('change', function () {
//ways to retrieve selected option and text outside handler
console.log('Changed option value ' + this.value);
console.log('Changed option text ' + $(this).find('option').filter(':selected').text());
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<select>
<option value="1" selected>1 - Text</option>
<option value="2">2 - Text</option>
<option value="3">3 - Text</option>
<option value="4">4 - Text</option>
</select>
Jawaban lama:
Sunting: Seperti yang banyak ditunjukkan, ini tidak mengembalikan nilai opsi yang dipilih.
~~ Gunakan .val untuk mendapatkan nilai opsi yang dipilih. Lihat di bawah,
$('select[name=selector]').val()~~