Gelagat Konsol JavaScript Chrome: Menilai Objek Dengan Malas
Gelagat konsol JavaScript Chrome semasa menilai objek telah diperhatikan sebagai berpotensi tidak dijangka. Untuk menggambarkan ini, pertimbangkan kod berikut:
var s = ["hi"]; console.log(s); s[0] = "bye"; console.log(s);
Dalam Firefox, konsol mengeluarkan:
[ "hi" ] [ "bye" ]
Walau bagaimanapun, dalam Chrome versi 7.0.517.41 beta, outputnya ialah:
[ "bye" ] [ "bye" ]
Penilaian Tidak Dijangka Gelagat
Tingkah laku ini menunjukkan bahawa konsol Chrome mungkin "malas" semasa menilai objek. Apabila pernyataan console.log pertama dilaksanakan, konsol merujuk objek dalam ingatan. Sebarang pengubahsuaian seterusnya pada objek, seperti menukar elemen pertama daripada "hai" kepada "bye," tidak ditunjukkan dalam output pernyataan console.log pertama. Ini menunjukkan bahawa konsol hanya menilai objek pada masa pernyataan konsol.log pertama dan menyimpan syot kilat.
Penjelasan Pepijat
Tingkah laku ini didokumenkan dalam mengikuti laporan pepijat Webkit: https://bugs.webkit.org/show_bug.cgi?id=35801 (kini diperbaiki). Pepijat menyatakan bahawa konsol Chrome tidak melakukan penilaian malas untuk objek yang diakses secara langsung, mengakibatkan tingkah laku yang diperhatikan.
Penyelesaian
Untuk mengelakkan tingkah laku yang tidak dijangka ini, satu boleh memanggil keString pada objek sebelum menghantarnya ke console.log. Ini memaksa Chrome untuk membuat perwakilan objek yang tidak diubah oleh perubahan seterusnya, memastikan output konsol mencerminkan keadaan semasa objek.
var s = ["hi"]; console.log(s.toString()); s[0] = "bye"; console.log(s.toString());
Output:
hi bye
Atas ialah kandungan terperinci Mengapakah Konsol JavaScript Chrome Menunjukkan Hasil Yang Tidak Dijangka Semasa Menilai Objek?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!