React、Vue在IE的兼容问题(react 兼容ie)

Vue在IE10中无法获取父元素

原始

let parent = this.$el.parentElement

解决

这玩意还能咋解决 用原生呗 class、id都行

let parent = document.getElementsByClassName(\’top-chart\’)[0]

router-link在IE中没有作用

原始

<router-link to=\”a\” tag=\”div\” />

解决

  • 方案1
  • 由于URL的hashChange浏览器没有响应 故我们加个判断

if ( \’-ms-scroll-limit\’ in document.documentElement.style && \’-ms-ime-align\’ in document.documentElement.style) { // detect it\’s IE11 window.addEventListener(\”hashchange\”, function(event) { var currentPath = window.location.hash.slice(1); if (store.state.route.path !== currentPath) { router.push(currentPath) } }, false)}复制代码

如果还没有解决 换到方案二

  • 方案2
  • 如果浏览器直接没有触发到hashChange 那么我们手动调用history的API

<div @click=\”handleLink\” />handleLink () { this.$router.push({name:\’a\’})}复制代码

Excel表单导出异常

原始

原先通过axios的拦截器来获取响应内容的格式 然后进行下载 但在IE表现不一致 由于IE浏览器res.request.responseURL属性不存在 导致出错

const downloadUrl = url => { let iframe = document.createElement(\’iframe\’); iframe.style.display = \’none\’; iframe.src = url; iframe.onload = function () { document.body.removeChild(iframe); }; document.body.appendChild(iframe);};// 拦截二进制响应流if (res.headers && (res.headers[\’content-type\’] === \’application/vnd.ms-excel;charset=UTF-8\’ || res.headers[\’content-type\’] === \’application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\’ || res.headers[\’content-type\’] === \’application/octet-stream;charset=UTF-8\’)) {downloadUrl(res.request.responseURL);return}复制代码

解决

丢弃已有的轮子 闭门造车写个原生的Ajax

utils.exportFiles = (type = \’GET\’, url = null) => { var xhr = null if (window.XMLHttpRequest) { // Mozilla 浏览器 xhr = new XMLHttpRequest() } else { if (window.ActiveXObject) { try { xhr = new ActiveXObject(\’Microsoft.XMLHTTP\’) } catch (e) { try { xhr = new ActiveXObject(\’Msxml2.XMLHTTP\’) } catch (e) { } } } } xhr.open(type, url, true) xhr.responseType = \’blob\’ if (type === \’POST\’) { xhr.setRequestHeader(\’Content-type\’, \’application/json\’) } xhr.onload = function (res) { var contentDisposition = xhr.getResponseHeader(\’content-disposition\’) var contentType = xhr.getResponseHeader(\’content-type\’) var filename = contentDisposition.split(\’;\’)[2] // eslint-disable-next-line no-eval eval(filename) filename = decodeURI(filename) if (this.status === 201) { var blob = this.response if (typeof window.navigator.msSaveBlob !== \’undefined\’) { // IE 浏览器进行下载 window.navigator.msSaveBlob(blob, filename) } else { // 非浏览器进行下载 var downloadUrl = document.createElement(\’a\’) downloadUrl.download = filename downloadUrl.style.display = \’none\’ downloadUrl.href = URL.createObjectURL(blob) document.body.appendChild(downloadUrl) downloadUrl.click() URL.revokeObjectURL(downloadUrl.href) document.body.removeChild(downloadUrl) } } else { console.log(\’导出错误\’) } } xhr.send()}复制代码

React中remove()不兼容

解决

找到该节点的父节点 使用removeChild()方法删除

node.parentNode.removeChild(node)

flex在IE中子元素宽度无效

原始

问题出现在想做一个横向滚动 Apple官网有类似需求

<div class=\”node-list\”> <div class=\”node-item\”> </div></div>复制代码

当node-item的宽度设定 且个数超过node-list的可容纳个数时 子元素的宽度失效 所有的子元素都将显示出来

解决

给父元素 即node-list动态设置宽度

<div class=\”node-list\” v-if=\”nodeList\”> <div class=\”node-list\” v-if=\”nodeList\” :style=\”{width:`${nodeWidth}px`}\”> </div></div>复制代码

IE隐藏滚动条

解决

overflow: scroll; -ms-scroll-chaining: chained; -ms-overflow-style: none; -ms-content-zooming: zoom; -ms-scroll-rails: none; -ms-content-zoom-limit-min: 100%; -ms-content-zoom-limit-max: 500%; -ms-scroll-snap-type: proximity; -ms-scroll-snap-points-x: snapList(100%, 200%, 300%, 400%, 500%); -ms-overflow-style: none;复制代码

总结

大概就是这么多 后续如果有遇到新的问题再加进去 也欢迎大家提出一点不同的解决和新的问题 造福切图仔

作者:虚竹子

链接:https://juejin.im/post/5d6742f86fb9a06b2116fb34

来源:掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

React、Vue在IE的兼容问题(react 兼容ie)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年12月28日 上午10:32
下一篇 2023年12月28日 上午10:43

相关推荐

  • 浪潮阵列卡软件

    浪潮阵列卡软件: 集成式数据中心解决方案 浪潮是中国领先的云计算和大数据解决方案提供商之一,其阵列卡软件是该公司的核心产品之一。浪潮阵列卡软件为用户提供了高效的数据存储和管理功能,…

    科研百科 2024年10月17日
    1
  • 留言板管理系统项目背景

    留言板管理系统项目背景 随着互联网的发展,社交媒体已经成为人们交流的重要方式。在社交媒体上,人们可以发布文字、图片、视频等多种形式的信息,并且可以方便地与他人互动。然而,传统的留言…

    科研百科 2025年1月20日
    2
  • 智慧党建系统存在问题和改进意见

    智慧党建系统存在问题和改进意见 近年来,随着数字化、信息化的快速发展,智慧党建系统已经成为了党员教育和管理工作中不可或缺的一部分。然而,智慧党建系统在实际应用中也存在着一些问题和改…

    科研百科 2024年10月16日
    98
  • 科研项目工作的不足之处

    科研项目工作的不足之处 科研项目是科学研究的重要组成部分,但是它们也会存在不足之处。这些不足之处可能是技术问题,也可能是管理问题,或者是其他因素引起的。在这篇文章中,我将讨论一些科…

    科研百科 2025年5月13日
    1
  • 进度计划的软件有哪些

    进度计划软件有哪些 进度计划软件是一种用于管理项目或任务的软件,可以帮助用户更好地跟踪项目或任务的进度,并制定合理的计划。目前市面上有很多进度计划软件,以下是一些比较常用的软件: …

    科研百科 2024年5月31日
    84
  • 软硬技术项目型管理系统

    软硬技术项目型管理系统 随着信息技术的不断发展,软件开发、硬件制造和项目管理等领域也在不断地更新和改进。为了更好地管理项目,软件和硬件技术团队都引入了项目型管理系统。本文将介绍软硬…

    科研百科 2025年1月8日
    0
  • 系统集成ict项目管理心得及提问

    系统集成ict项目管理心得及提问 系统集成ict项目管理是指对系统集成ict项目进行有效的管理,包括项目计划,资源分配,风险管理,质量管理和进度控制等。作为一个ict项目经理,我分…

    科研百科 2025年1月29日
    3
  • 棉花所3个品种入选2013年农业主导品种

        日前,中国农业科学院棉花研究所育成的中棉所63、中棉所49和中棉所41等3个品种入选农业部组织遴选的2013年农业主导品种。  &n…

    科研百科 2022年5月17日
    261
  • 评论科研项目的文章

    科研项目是一种重要的研究领域,它为人类提供了许多新的发现和解决问题的方法。在过去的几年中,许多科研项目都取得了巨大的进展,并且对人类产生了深远的影响。然而,有些科研项目也可能存在一…

    科研百科 2025年3月28日
    1
  • 科研项目评奖投票规则

    科研项目评奖投票规则 随着科技的不断发展,科研项目评奖投票规则也在不断地更新和完善。为了更好地评估和奖励优秀的科研项目,保证公正性和透明度,我们将在下面介绍科研项目评奖投票规则。 …

    科研百科 2025年2月6日
    0