Memahami jenis dan versi penyemak imbas pengguna adalah penting untuk reka bentuk tapak web yang disasarkan, pengoptimuman dan langkah keselamatan. JavaScript menyediakan pelbagai kaedah untuk pengesanan penyemak imbas, membenarkan pembangun menyesuaikan kandungan dan fungsi dengan sewajarnya.
Salah satu cara paling berkesan untuk mengesan penyemak imbas dalam JavaScript ialah dengan memeriksa sifat navigator.userAgent. Sifat ini mengandungi rentetan yang termasuk maklumat tentang nama penyemak imbas, versi dan sistem pengendalian, antara butiran lain. Dengan menghuraikan rentetan ini, kami boleh mengekstrak data yang berkaitan untuk tujuan kami.
Sebagai contoh, untuk menentukan penyemak imbas yang tepat dan versinya, kami boleh menggunakan fungsi yang meneliti rentetan ejen pengguna. Fungsi ini boleh menggunakan ungkapan biasa untuk memadankan corak tertentu dalam rentetan dan mengekstrak maklumat penyemak imbas dan versi, seperti yang ditunjukkan dalam coretan kod yang disediakan:
navigator.saysWho = (() => { const { userAgent } = navigator; let match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || []; let temp; 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)'); } } 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`
Fungsi ini sepadan dengan pelbagai jenis dan versi penyemak imbas, termasuk Opera, Chrome, Safari, Firefox dan Internet Explorer. Ia juga mengendalikan kes khas untuk Edge berasaskan Chromium dan IE berasaskan Trident, memastikan keserasian merentas pelbagai pelayar.
Dengan memasukkan kaedah pengesanan sedemikian ke dalam aplikasi JavaScript anda, anda boleh memperoleh cerapan berharga tentang persekitaran pengguna , tingkatkan pengalaman pengguna dan peribadikan penghantaran kandungan web berdasarkan keupayaan peranti.
Atas ialah kandungan terperinci Bagaimanakah JavaScript Boleh Digunakan untuk Mengesan dan Mengenalpasti Pelayar Pengguna dan Versinya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!