gpt4 book ai didi

javascript - Angular 2 : Check whether user's browser is compatible

转载 作者:太空狗 更新时间:2023-10-29 16:54:30 24 4
gpt4 key购买 nike

我正在编写一个 Angular 2 应用程序,但我意识到有些用户可能没有使用可以支持 Angular 2 的浏览器。

我检查是否启用了 Javascript,我更感兴趣的是用户的浏览器是否不支持 Angular 2 所需的某些 JS/HTML5/其他功能。

评估用户浏览器是否支持 Angular 2 并在不支持时显示消息的最佳方法是什么?

我知道例如Modernizer ,但不确定从哪里开始,因为 Modernizer 的重点似乎是零碎地组装兼容性检查,而不是提供检查整个框架兼容性的解决方案。

最佳答案

Angular 2, and display a message if not?

angular 官方支持的浏览器版本可能不是你的应用运行的浏览器版本(可能更高也可能更低)。

您必须自己进行个别浏览器检查。例如检测 IE:http://codepen.io/gapcode/pen/vEJNZN

/**
* detect IE
* returns version of IE or false, if browser is not Internet Explorer
*/
function detectIE() {
var ua = window.navigator.userAgent;

// Test values; Uncomment to check result …

// IE 10
// ua = 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)';

// IE 11
// ua = 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko';

// IE 12 / Spartan
// ua = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.71 Safari/537.36 Edge/12.0';

// Edge (IE 12+)
// ua = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2486.0 Safari/537.36 Edge/13.10586';

var msie = ua.indexOf('MSIE ');
if (msie > 0) {
// IE 10 or older => return version number
return parseInt(ua.substring(msie + 5, ua.indexOf('.', msie)), 10);
}

var trident = ua.indexOf('Trident/');
if (trident > 0) {
// IE 11 => return version number
var rv = ua.indexOf('rv:');
return parseInt(ua.substring(rv + 3, ua.indexOf('.', rv)), 10);
}

var edge = ua.indexOf('Edge/');
if (edge > 0) {
// Edge (IE 12+) => return version number
return parseInt(ua.substring(edge + 5, ua.indexOf('.', edge)), 10);
}

// other browser
return false;
}

关于javascript - Angular 2 : Check whether user's browser is compatible,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36877151/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com