Rumah >hujung hadapan web >tutorial js >Mengapakah `string.replace` Menghasilkan Rentetan Kosong Apabila Menggantikan dengan Tanda Dolar ($)?

Mengapakah `string.replace` Menghasilkan Rentetan Kosong Apabila Menggantikan dengan Tanda Dolar ($)?

DDD
DDDasal
2024-10-28 17:30:03698semak imbas

Why Does `string.replace` Produce an Empty String When Replacing with a Dollar Sign ($)?

Kelakuan Penggantian Rentetan Pelik Menggunakan Tanda Dolar ($) dalam rentetan.ganti

Apabila cuba menggantikan rentetan menggunakan rentetan.ganti kaedah dan menentukan penggantian sebagai tanda dolar ($), hasil yang tidak dijangka daripada rentetan kosong mungkin timbul. Fenomena ini berlaku disebabkan oleh kepentingan istimewa tanda dolar dalam ungkapan biasa JavaScript dan kaedah rentetan.ganti.

Untuk menggantikan rentetan dengan tanda dolar dengan tepat, rentetan gantian hendaklah dinyatakan sebagai $$ dan bukannya $. Ini kerana tanda dolar, apabila digunakan dalam ungkapan biasa, mempunyai makna khusus yang berkaitan dengan rujukan belakang, kumpulan tangkapan dan penghujung rentetan.

Sebagai contoh, pertimbangkan kod berikut:

<code class="javascript">var text = "as";
text = text.replace(text, "$'");
console.log(text); // Prints empty string</code>

Dalam kes ini, rentetan kosong dicetak kerana rentetan gantian ditafsirkan sebagai rujukan kepada kumpulan tangkapan. Memandangkan tiada kumpulan tangkapan ditakrifkan dalam ungkapan biasa, hasilnya ialah rentetan kosong.

Untuk membetulkan gelagat ini, gunakan $$ sebagai rentetan gantian:

<code class="javascript">var text = "as";
text = text.replace(text, "$$'");
console.log(text); // Prints $'</code>

Dengan menggunakan $ $ dan bukannya $, tanda dolar dianggap sebagai aksara literal, dan penggantian yang dimaksudkan berlaku. Ini kerana $$ terlepas daripada makna istimewa tanda dolar dalam ungkapan biasa.

Atas ialah kandungan terperinci Mengapakah `string.replace` Menghasilkan Rentetan Kosong Apabila Menggantikan dengan Tanda Dolar ($)?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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