Rumah hujung hadapan web tutorial js Pengenalan kepada peraturan untuk menukar objek kepada nombor atau rentetan dalam kemahiran JavaScript_javascript

Pengenalan kepada peraturan untuk menukar objek kepada nombor atau rentetan dalam kemahiran JavaScript_javascript

May 16, 2016 pm 04:22 PM
javascript object string

Semasa proses menulis program JavaScript, JS akan menukar objek secara automatik kepada nombor atau rentetan mengikut konteks yang berbeza sebelum diproses. Peraturan untuk penukaran automatik ini adalah seperti berikut:

Peraturan untuk penukaran automatik objek kepada rentetan:

1 Jika kelas yang dimiliki objek mengatasi kaedah toString(), panggil kaedah ini. Jika hasil pulangan panggilan toString() adalah Primitif (rentetan, nombor, boolean, tidak ditentukan, batal), nilai Primitif ditukar kepada rentetan dan dikembalikan.

2. Jika kelas yang dimiliki objek itu tidak mengatasi kaedah toString() - hasil pengembalian panggilan toString() ialah "[objek Objek]" atau jika kaedah toString() ditindih tetapi kaedah mengembalikan objek. Kemudian JS akan memanggil kaedah valueOf() objek Jika hasil pulangan panggilan valueOf() adalah Primitif (rentetan, nombor, boolean, tidak ditentukan, null), nilai Primitif akan ditukar menjadi rentetan dan dikembalikan.

3. Jika kedua-dua mata di atas tidak dipenuhi dan nilai Primitif tidak boleh diperolehi dengan memanggil kaedah toString() objek atau kaedah valueOf(), maka JS akan membuang TypeError.

Peraturan untuk penukaran automatik objek kepada nombor:

1. Panggil kaedah valueOf() bagi objek Jika nilai yang diperolehi ialah nilai Primitif, tukarkan nilai Primitif kepada nombor dan kembalikannya.

2. Jika nilai Primitif tidak boleh diperolehi daripada kaedah valueOf(), maka panggil kaedah toString() objek jika toString() mengembalikan nilai Primitif, tukar nilai Primitif kepada nombor dan kembalikannya.

3 Jika kedua-dua mata di atas tidak dipenuhi, JS akan membuang TypeError.

Seperti yang anda lihat, peraturan untuk penukaran automatik objek kepada rentetan dan penukaran automatik objek kepada nombor sebenarnya adalah sama. Perbezaannya terletak pada susunan panggilan kaedah toString() dan kaedah valueOf().

Mengikut peraturan di atas, beberapa hasil penukaran boleh difahami dengan baik:


1. Untuk tatasusunan kosong, apabila menukarnya kepada nombor, hasilnya ialah 0. Ini kerana kaedah tatasusunan valueOf() akan dipanggil dahulu Memandangkan valueOf() mengembalikan objek tatasusunan itu sendiri, JS kemudiannya akan memanggil kaedah toString() tatasusunan kosong kerana hasil pulangan toString() bagi kosong array ialah aksara nol, jadi rentetan kosong akhirnya akan ditukar kepada nombor 0 dan dikembalikan.

2. Untuk tatasusunan dengan hanya satu ahli angka, gunakan peraturan yang sama untuk menukarnya kepada nombor dan hasil akhir ialah nombor.

3 Untuk tatasusunan dengan berbilang ahli angka, kerana rentetan tidak boleh ditukar kepada nombor, hasil akhir ialah NaN.

Bilakah ia ditukar kepada rentetan? Bilakah ia ditukar kepada nombor?

Apabila melakukan penukaran jenis automatik pada objek, JS akan memilih untuk menukarnya menjadi rentetan atau nombor bergantung pada jenis objek dan pengendali. Peraturan khusus adalah seperti berikut:

1 Jika objek muncul pada kedua-dua belah operator, tukar objek itu kepada rentetan.
2. Semua objek (kecuali objek Tarikh) ditukar kepada nombor terlebih dahulu.
3. Untuk objek Tarikh, tukarkannya kepada rentetan dahulu.

Perlu diperhatikan bahawa untuk pengendali, kecuali apabila objek atau rentetan muncul pada kedua-dua belah operator, operasi "tukar kepada nombor" dilakukan dalam semua kes lain Pada masa yang sama, operasi ini juga berkaitan dengan tertib antara nilai .

Percubaan


Salin kod Kod adalah seperti berikut:

console.log(3 * []);//0
console.log(3 * [2]);//6
console.log(3 * [1,2]);//NaN

console.log(3 [2]);//32

var sekarang = Tarikh baharu();
console.log(sekarang 1);//Rabu 26 Mac 2014 10:51:39 GMT 0800 (CST)1
console.log(sekarang - 1);//1395802299223
console.log(sekarang * 2);//2791604598448

console.log(true true);//2
console.log(2 null);//2, null ditukar kepada 0
console.log(2 undefined);//NaN, undefined ditukar kepada NaN
console.log(1 2 "kucing");//3 kucing
console.log(1 (2 "kucing"));//12 kucing

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk melaksanakan sistem pengecaman pertuturan dalam talian menggunakan WebSocket dan JavaScript Bagaimana untuk melaksanakan sistem pengecaman pertuturan dalam talian menggunakan WebSocket dan JavaScript Dec 17, 2023 pm 02:54 PM

Bagaimana untuk melaksanakan sistem pengecaman pertuturan dalam talian menggunakan WebSocket dan JavaScript

WebSocket dan JavaScript: teknologi utama untuk melaksanakan sistem pemantauan masa nyata WebSocket dan JavaScript: teknologi utama untuk melaksanakan sistem pemantauan masa nyata Dec 17, 2023 pm 05:30 PM

WebSocket dan JavaScript: teknologi utama untuk melaksanakan sistem pemantauan masa nyata

Bagaimana untuk melaksanakan sistem tempahan dalam talian menggunakan WebSocket dan JavaScript Bagaimana untuk melaksanakan sistem tempahan dalam talian menggunakan WebSocket dan JavaScript Dec 17, 2023 am 09:39 AM

Bagaimana untuk melaksanakan sistem tempahan dalam talian menggunakan WebSocket dan JavaScript

Cara menggunakan JavaScript dan WebSocket untuk melaksanakan sistem pesanan dalam talian masa nyata Cara menggunakan JavaScript dan WebSocket untuk melaksanakan sistem pesanan dalam talian masa nyata Dec 17, 2023 pm 12:09 PM

Cara menggunakan JavaScript dan WebSocket untuk melaksanakan sistem pesanan dalam talian masa nyata

JavaScript dan WebSocket: Membina sistem ramalan cuaca masa nyata yang cekap JavaScript dan WebSocket: Membina sistem ramalan cuaca masa nyata yang cekap Dec 17, 2023 pm 05:13 PM

JavaScript dan WebSocket: Membina sistem ramalan cuaca masa nyata yang cekap

Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Jan 05, 2024 pm 06:08 PM

Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP

Bagaimana untuk menggunakan insertBefore dalam javascript Bagaimana untuk menggunakan insertBefore dalam javascript Nov 24, 2023 am 11:56 AM

Bagaimana untuk menggunakan insertBefore dalam javascript

Bagaimana untuk mendapatkan kod status HTTP dalam JavaScript dengan cara yang mudah Bagaimana untuk mendapatkan kod status HTTP dalam JavaScript dengan cara yang mudah Jan 05, 2024 pm 01:37 PM

Bagaimana untuk mendapatkan kod status HTTP dalam JavaScript dengan cara yang mudah

See all articles