Я нашел много JS-скриптов для определения имени и версии браузера пользователя, поэтому мне пришлось смешать их, чтобы получить именно то, что я хочу
public / index.html
<script type="text/javascript">
function get_browser() {
var ua = navigator.userAgent, tem, M = ua.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
if (/trident/i.test(M[1])) {
tem = /\brv[ :]+(\d+)/g.exec(ua) || [];
return { name: 'IE', version: (tem[1] || '') };
}
if (M[1] === 'Chrome') {
tem = ua.match(/\bOPR\/(\d+)/)
if (tem != null) { return { name: 'Opera', version: tem[1] }; }
}
if (window.navigator.userAgent.indexOf("Edge") > -1) {
tem = ua.match(/\Edge\/(\d+)/)
if (tem != null) { return { name: 'Edge', version: tem[1] }; }
}
M = M[2] ? [M[1], M[2]] : [navigator.appName, navigator.appVersion, '-?'];
if ((tem = ua.match(/version\/(\d+)/i)) != null) { M.splice(1, 1, tem[1]); }
return {
name: M[0],
version: +M[1]
};
}
var browser = get_browser()
var isSupported = isSupported(browser);
function isSupported(browser) {
var supported = false;
if (browser.name === "Chrome" && browser.version >= 48) {
supported = true;
} else if ((browser.name === "MSIE" || browser.name === "IE") && browser.version >= 10) {
supported = true;
} else if (browser.name === "Edge") {
supported = true;
}
return supported;
}
if (!isSupported) {
document.write(<h1>My message</h1>)
}
</script>
Этот скрипт позволяет пользователям продолжить работу, если их браузер имеет chrome> = 48 или ie> = 10 или любую версию edge.В противном случае отображается специальное сообщение с просьбой обновить или изменить свой браузер.
Вы также можете настроить этот скрипт в соответствии со своими потребностями, изменив функцию isSupported ().