Rumah > hujung hadapan web > tutorial js > Bagaimanakah Saya Boleh Mengesan Penyemak Imbas dan Versi Menggunakan JavaScript?

Bagaimanakah Saya Boleh Mengesan Penyemak Imbas dan Versi Menggunakan JavaScript?

Barbara Streisand
Lepaskan: 2024-12-04 17:00:15
asal
804 orang telah melayarinya

How Can I Reliably Detect Browser and Version Using JavaScript?

Pengesanan Penyemak Imbas dalam JavaScript Dilawati Semula

Menentukan penyemak imbas dan versi yang tepat menggunakan JavaScript boleh menjadi alat yang berharga untuk pengalaman web yang disesuaikan. Begini cara anda boleh mencapai ini:

API Navigator:

Harta navigator dalam JavaScript menyediakan akses kepada maklumat penyemak imbas. Sifat userAgentnya mengandungi rentetan yang mengenal pasti penyemak imbas dan versinya.

Menggunakan Ungkapan Regex:

Untuk mengekstrak nama dan versi penyemak imbas daripada rentetan userAgent, anda boleh menggunakan ungkapan biasa. Kod sampel berikut menggunakan regex komprehensif untuk mengesan pelbagai penyemak imbas dan versinya:

navigator.saysWho = (() => {
  const { userAgent } = navigator;
  let match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
  let temp;

  // Handle special cases
  if (/trident/i.test(match[1])) {
    temp = /\brv[ :]+(\d+)/g.exec(userAgent) || [];
    return `IE ${temp[1] || ''}`;
  }

  if (match[1] === 'Chrome') {
    temp = userAgent.match(/\b(OPR|Edge)\/(\d+)/);
    if (temp !== null) {
      return temp.slice(1).join(' ').replace('OPR', 'Opera');
    }

    temp = userAgent.match(/\b(Edg)\/(\d+)/);
    if (temp !== null) {
      return temp.slice(1).join(' ').replace('Edg', 'Edge (Chromium)');
    }
  }

  // Construct the browser information string
  match = match[2] ? [match[1], match[2]] : [navigator.appName, navigator.appVersion, '-?'];
  temp = userAgent.match(/version\/(\d+)/i);
  if (temp !== null) {
    match.splice(1, 1, temp[1]);
  }

  return match.join(' ');
})();

console.log(navigator.saysWho); // outputs: `Chrome 89`
Salin selepas log masuk

Skrip ini memadankan rentetan ejen pengguna terhadap pelbagai corak penyemak imbas dan mengembalikan penyemak imbas dan versi yang diekstrak sebagai rentetan.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengesan Penyemak Imbas dan Versi Menggunakan JavaScript?. 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