Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Mensimulasikan Pandangan Negatif di Belakang dalam Ungkapan Biasa JavaScript?

Bagaimanakah Saya Boleh Mensimulasikan Pandangan Negatif di Belakang dalam Ungkapan Biasa JavaScript?

Barbara Streisand
Barbara Streisandasal
2024-12-14 15:48:11637semak imbas

How Can I Simulate Negative Lookbehind in JavaScript Regular Expressions?

JavaScript Equivalent of Negative Look Behind

Negative Lookbacks, yang sepadan dengan rentetan yang tidak bermula dengan set aksara tertentu, tidak disokong secara langsung oleh Ungkapan biasa JavaScript. Walau bagaimanapun, terdapat pendekatan alternatif untuk mencapai hasil yang serupa.

Pandangan Positif dan Pembalikan Rentetan

Memandangkan JavaScript menyokong pandangan positif (?=), satu kaedah melibatkan:

  1. Menterbalikkan rentetan input.
  2. Menggunakan regex terbalik dengan pandangan positif ke hadapan.
  3. Menterbalikkan dan memformat semula perlawanan.

Contoh:

const reverse = s => s.split('').reverse().join('');
const regexp = /m(?!([abcdefg]))/;

test(['jim', 'm', 'jam'], regexp);

function test(strings, regexp) {
  strings.map(reverse).forEach((s, i) => {
    match = regexp.test(s);
    console.log(strings[i], match, 'Token: ', match ? reverse(regexp.exec(s)[0]) : 'Ø');
  });
}

Keputusan:

jim true Token: m
m true Token: m
jam false Token: Ø

Sokongan Penegasan Lihat di Sebalik (Sejak 2018)

Pada tahun 2018, penegasan pandang belakang, termasuk pandangan belakang negatif, menjadi sebahagian daripada spesifikasi bahasa ECMAScript. Ia boleh digunakan seperti berikut:

Pandang Negatif:

(?<!...)

Pandangan Positif:

(?<=...)

Contoh:

Untuk dipadankan "tinggi maks" tetapi bukan "tinggi garis":

regexp = /thgieh(?!(-enil))/;
test(['max-height', 'line-height'], regexp);

Keputusan:

max-height true Token: height
line-height false Token: Ø

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mensimulasikan Pandangan Negatif di Belakang dalam Ungkapan Biasa JavaScript?. 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