Mengapakah Fungsi Gantian JavaScript Mengehadkan Penggantian kepada Contoh Pertama Sahaja?

Patricia Arquette
Lepaskan: 2024-10-23 07:58:29
asal
803 orang telah melayarinya

Why Does JavaScript's Replace Function Limit Replacements to the First Instance Only?

Mengapa Fungsi Ganti Javascript Hanya Menggantikan Contoh Pertama

Apabila menggunakan replace() dalam JavaScript, anda mungkin menghadapi situasi di mana ia menggantikan sahaja contoh pertama rentetan sasaran. Ketidakkonsistenan yang jelas ini berpunca daripada kelakuan lalai fungsi.

Memahami Gelagat replace()

Secara lalai, replace() mencari dan menggantikan kejadian pertama subrentetan yang ditentukan dalam rentetan. Jika anda ingin menggantikan semua kejadian, anda perlu menentukan bendera g (global) dalam ungkapan biasa.

Contoh: Menetapkan Bendera g

Pertimbangkan contoh disediakan dalam soalan:

var date = $('#Date').val(); // Gets value "12/31/2009"
var id = 'c_' + date.replace("/", ''); // Replaces only the first "/", resulting in "c_1231/2009"
Salin selepas log masuk

Untuk menggantikan semua kejadian garis miring ke hadapan (/), gunakan bendera g:

var id = 'c_' + date.replace(new RegExp("/", "g"), ''); // Replaces all "/" with "", resulting in "c_12312009"
Salin selepas log masuk

Sebagai alternatif, anda boleh menggunakan sintaks yang lebih mudah:

var id = 'c_' + date.replace(/\//g, ''); // Equivalent to the previous line
Salin selepas log masuk

Dengan menetapkan bendera g, ungkapan biasa sepadan dengan semua kejadian rentetan sasaran dan menggantikannya dengan nilai baharu yang ditentukan. Tingkah laku ini memastikan semua kejadian diganti seperti yang dimaksudkan.

Atas ialah kandungan terperinci Mengapakah Fungsi Gantian JavaScript Mengehadkan Penggantian kepada Contoh Pertama Sahaja?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!