角度2:检查用户的浏览器是否兼容
Angular 2: Check whether user's browser is compatible
我正在编写一个 Angular 2 应用程序,但意识到某些用户可能没有使用可以支持 Angular 2 的浏览器。
我检查了Javascript是否已启用,我更感兴趣的是用户的浏览器是否不支持Angular 2所需的某些JS/HTML5/其他功能。
评估用户的浏览器是否支持 Angular 2 的最佳方法是什么,如果不支持,则显示消息?
我知道例如 Modernizer,但不确定从哪里开始,因为 Modernizer 的重点似乎是零碎地组装兼容性检查,而不是提供检查整个框架兼容性的解决方案。
角度 2,如果没有,则显示一条消息?
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;
}
并非所有浏览器都完全支持 ES6 (ES2015) 标准。
https://kangax.github.io/compat-table/es6/
如果你想在你的 Angular 2 应用程序中使用 ES6 语言功能,那么你应该包括 ES6 垫片,让你的浏览器达到规格:
https://cdnjs.cloudflare.com/ajax/libs/es6-shim/0.35.0/es6-shim.min.js
话虽如此,IE似乎是例外。您需要包含其他 polyfill 以支持 IE:
https://npmcdn.com/angular2/es6/dev/src/testing/shims_for_IE.js
如果要面向 ES5(旧标准),则需要确保仅使用 ES5 语言功能编写角度应用。 一般来说,对 ES5 功能的浏览器支持更多,但它并不完美:
http://kangax.github.io/compat-table/es5/
当然,这也有一个垫片:
https://cdnjs.cloudflare.com/ajax/libs/es5-shim/4.5.8/es5-shim.min.js
- jQuery检测浏览器是否支持Zoom
- 浏览器是否持久缓存脚本元素的编译版本
- 如何(功能)检测浏览器是否支持WebM alpha透明度
- 如何知道浏览器是否阻止插件
- 查看浏览器是否在React中更改了路线
- 角度2:检查用户的浏览器是否兼容
- 检查浏览器是否支持iFrame上的加载方法
- 检查浏览器是否支持 HTML 验证
- 如何检测浏览器是否正在加载
- 安卓股票浏览器是否支持WebSocket
- 检查浏览器是否已完成页面加载
- 浏览器是否在选项卡之间传播javascript变量
- 如何检测浏览器是否支持js-onscroll.立即
- 具有辅助功能的浏览器是否支持CSS或JavaScript
- 检测浏览器是否启用了 TLS
- 如何使用JavaScript /条件注释测试浏览器是否符合CSS3
- 大视频.js - 检查浏览器是否支持,背景图像回退
- 如何检测谷歌浏览器是否阻止Flash播放
- 如何检查浏览器是否支持带有javascript的svg
- 浏览器是否缓存下载的javascript