Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Melaksanakan Negatif Look Behind dalam JavaScript Regex?

Bagaimanakah Saya Boleh Melaksanakan Negatif Look Behind dalam JavaScript Regex?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-19 06:53:13454semak imbas

How Can I Implement Negative Lookbehind in JavaScript Regex?

Cara Melaksanakan Pandangan Negatif di Belakang dalam JavaScript

JavaScript tidak menyokong look belakang negatif secara asli, yang menghalang penciptaan ungkapan biasa yang sepadan dengan rentetan yang jangan mulakan dengan aksara tertentu.

Penyelesaian dengan Look Behind Penegasan (pasca 2018)

Pada tahun 2018, JavaScript memperkenalkan penegasan lihat di sebalik, membenarkan pandangan di belakang positif dan negatif:

  • Pandangan di belakang positif: (?<=...)
  • Pandangan negatif di belakang: (?

Sebagai contoh, regex berikut sepadan dengan aksara 'm' dalam 'jim' atau 'm', tetapi bukan dalam 'jam':

(?<!([abcdefg]))m

Penyelesaian Pra-2018

Sebelum 2018, satu penyelesaian melibatkan membalikkan rentetan input, memadankan dengan regex terbalik, dan kemudian membalikkan padanan. Proses ini boleh dilaksanakan seperti berikut:

const reverse = s => s.split('').reverse().join('');

const test = (stringToTests, reversedRegexp) => stringToTests
  .map(reverse)
  .forEach((s,i) => {
    const match = reversedRegexp.test(s);
    console.log(stringToTests[i], match, 'token:', match ? reverse(reversedRegexp.exec(s)[0]) : 'Ø');
  });<p><strong>Contoh</strong></p>
<p>Untuk menggambarkan penggunaannya:</p>
<ul><li>Untuk soalan awal yang disebut dalam konteksnya, regex berikut akan sepadan dengan 'm' dalam 'jim' atau 'm', tetapi tidak 'jem':</li></ul>
<pre class="brush:php;toolbar:false">test(['jim', 'm', 'jam'], /m(?!([abcdefg]))/)
  • Contoh lain, memadankan "tinggi maks" tetapi bukan "tinggi garis":
test(['max-height', 'line-height'], /thgieh(?!(-enil))/)

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Negatif Look Behind dalam JavaScript Regex?. 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