[英]Modern browsers detection?
哪些版本的浏览器实际上可以命名为现代? 哪里支持 css3 和或多或少的现代功能?
谢谢!
function isOldBrowser() {
var isOld = false;
var detect = function(){
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+(\.\d+)?)/g.exec(ua) || [];
return 'IE '+(tem[1] || '');
}
M = M[2] ? [M[1].toLowerCase(), parseInt(M[2],10)] : [navigator.appName.toLowerCase(), parseInt(navigator.appVersion,10), '-?'];
if((tem= ua.match(/version\/([\.\d]+)/i))!= null) M[2]= tem[1];
return M;
};
var browser = detect();
if (document.all && !document.querySelector) isOld = true; //IE7 or lower
else if (document.all && document.querySelector && !document.addEventListener) isOld = true; //IE8
else if (browser[0] == 'firefox' && browser[1] < 4) isOld = true; //FF4+
else if (browser[0] == 'safari' && browser[1] < 5) isOld = true; //Safari 5+
return isOld;
}
浏览器嗅探几乎总是一个坏主意。 如果您希望支持旧浏览器,请改用Modernizr和功能检测来提供替代内容。 您也可以参考caniuse来了解哪些浏览器支持哪些功能。
这对我有用:
var isModernBrowser = typeof(Intl) != "undefined";
这样做的另一件事是,如果您运行的是 Internet Explorer 11,但在 SharePoint 下(即使使用最新的 SharePoint 2016),它将正确返回 false,因为 SharePoint 强制页面为 document.documentMode == 8。
菲利普沃尔顿对此有很好的阅读: https : //philipwalton.com/articles/loading-polyfills-only-when-needed/
让您的代码对大多数用户立即运行,但在为所有其他用户加载 polyfills 之前停止执行的最简单方法是构建您的站点,以便所有代码路径都有一个入口点。
在上面链接的网站的情况下,这里是使用的功能:
function browserSupportsAllFeatures() {
return window.Promise && window.fetch && window.Symbol;
}
就我而言,我正在使用类似的东西:
const isModernBrowser = () => {
return 'fetch' in window &&
'Promise' in window &&
'assign' in Object &&
'keys' in Object
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.