Rumah > hujung hadapan web > tutorial js > Mengapa Corak Ungkapan Biasa Saya Gagal dengan Bendera \'v\' dalam Atribut Corak HTML?

Mengapa Corak Ungkapan Biasa Saya Gagal dengan Bendera \'v\' dalam Atribut Corak HTML?

Barbara Streisand
Lepaskan: 2024-10-28 06:26:02
asal
222 orang telah melayarinya

Why Does My Regular Expression Pattern Fail with the

Kesahihan Corak Ungkapan Biasa dengan Bendera Unikod

Isu dengan Corak RegExp dalam Atribut Corak HTML

Apabila menggunakan corak ungkapan biasa dengan bendera 'v' dalam atribut corak HTML, anda mungkin menghadapi ralat "SyntaxError". Ralat ini berlaku kerana bendera 'v' digunakan secara automatik apabila menyusun corak ke dalam objek RegExp.

Tolak dan Melarikan Kelas Aksara

Bendera 'v' memperkenalkan peraturan pelarian yang lebih ketat, yang tidak membenarkan aksara '-' literal pada akhir kelas aksara. Ini berbeza dengan bendera 'u', di mana tiada sekatan sedemikian.

Corak Regex dengan Bendera 'u' dan 'v'

Pertimbangkan perkara berikut corak regex:

^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$
Salin selepas log masuk
Salin selepas log masuk

Dengan bendera 'u' digunakan:

<code class="js">console.log(/^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$/u.test("[email protected]")); // true</code>
Salin selepas log masuk

Dengan bendera 'v' digunakan (secara automatik dalam atribut corak HTML):

<code class="js">console.log(/^[a-zA-Z0-9+_.\-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$/v.test("[email protected]")); // SyntaxError</code>
Salin selepas log masuk

Penyelesaian

Untuk menyelesaikan ralat, anda mesti melepaskan aksara '-' di penghujung kelas aksara. Berikut ialah corak yang diperbetulkan:

^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$
Salin selepas log masuk
Salin selepas log masuk

Corak ini kini sepatutnya berfungsi dengan betul dengan dan tanpa bendera 'v'.

Atas ialah kandungan terperinci Mengapa Corak Ungkapan Biasa Saya Gagal dengan Bendera \'v\' dalam Atribut Corak HTML?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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