我们公司正在把我们的前沿项目之一转移到角11与Webpack 5。我们目前在角10,支持IE11。
这种迁移的原因是优先级的改变,其中之一或网络应用程序需要尽可能轻量级和快速。因此,我们想要迁移到角度11与Webpack 5,完全放弃IE,所以ES5不再编译。
问题是,我们的一些客户仍然在他们的业务环境中使用IE11。当我们检测到IE11时,我们已经显示了一条使用现代浏览器的消息,但是这条消息将不再仅在运行ES2015时显示。
由于IE11不支持ES2015,是否有一种方式显示消息供IE11用户使用不同的浏览器,而不仅仅是空白页?
发布于 2021-01-13 03:29:59
我以前也遇到过这样的问题。我检测到浏览器版本,如果IE然后呈现一些您需要的消息。如果没有IE,那么渲染应用程序。
我制作了一个新的角11应用程序,并在src/index.html中使用JavaScript来检测浏览器,代码如下:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Angular11test</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
</head>
<body>
<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 <= 11) {
supported = false;
} else if (browser.name === "Edge") {
supported = true;
}
return supported;
}
if (!isSupported) {
//render unsupported message
document.write("<h1>The app is not supported in IE. Please use other browsers!</h1>");
}
else{
//render app
var elem = document.createElement("app-root");
document.body.appendChild(elem);
}
</script>
</body>
</html>https://stackoverflow.com/questions/65682516
复制相似问题