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

相关推荐

  • 私有化数据标注平台报价

    私有化数据标注平台报价私有化数据标注平台报价1(一)国家资助政策中华人民共和国未成年人接受义务教育,能否获得相应的医疗补助,需要全社会的共同参与,每个公民都应该享有其法定代理人的权…

    科研百科 2024年11月28日
    0
  • 考研究生需要有科研项目

    考研究生需要有科研项目 近年来,随着研究生教育的普及,越来越多的人选择报考研究生。对于考生来说,拥有科研项目是一个重要的优势,因为它可以让他们更好地展示自己的学术能力和研究潜力。 …

    科研百科 2025年5月31日
    1
  • 第12集如何优化业务流程,让公司可持续发展!(怎样优化业务流程)

    《总裁商业思维》第12集:如何优化业务流程,让公司可持续发展! 我曾说过一句话:带好身边不如你的人,你才能够带好更多人。他的思维不如你,需要你点燃和激发。如果他能够点燃我的老板,他…

    科研百科 2024年6月12日
    72
  • 事务所、咨询公司:一文看透“内控”过去和未来(事务所内控咨询是干什么的)

    内控发展历程图 《会计改革与发展"十三五"规划纲要》中提出,要加强对企事业单位执行内部控制规范情况的监督检查,推动企事业单位全面开展内部控制体系建设。 新修订的《会计法》在第27条…

    科研百科 2024年7月10日
    53
  • 搞科研?没个大容量的资料共享网盘怎么行

    曾经有一个大学教师的朋友跟我抱怨,搞科研辛苦,大量的时间泡实验室就不说了,关键是科研项目材料太多,整理起来让人绝望,有时候找几个学生一起整理材料,信息不同步就进行不下去,最后还是得…

    2022年9月6日
    281
  • 广州项目管理

    广州项目管理 广州项目管理是一个非常重要的领域,涵盖了各种不同类型的项目,包括建筑、基础设施、能源、通信等等。在广州,项目管理已经成为了一个成熟和活跃的行业,吸引了许多优秀的企业和…

    科研百科 2024年5月27日
    67
  • 项目管理人员

    项目管理人员的工作是确保项目按时完成并达到高质量标准。作为项目管理人员,我们需要与团队成员密切合作,制定计划,监督进度,解决问题,确保项目成功完成。 在项目管理中,沟通是至关重要的…

    科研百科 2024年7月12日
    34
  • 具备项目管理能力

    具备项目管理能力非常重要。项目管理能力是指一个人能够有效地组织、计划、控制和监督一个项目的过程,确保项目按时完成,并在预算范围内完成。具备项目管理能力的人,能够有效地与团队成员沟通…

    科研百科 2024年9月23日
    22
  • 业务流程管理 软件

    业务流程管理软件:企业提高效率的利器 业务流程管理(BPM)软件是一种能够帮助企业有效地管理和优化业务流程的工具。随着现代企业越来越注重效率和竞争力,业务流程管理软件已经成为了许多…

    科研百科 2024年8月12日
    41
  • 项目管理系统ui图片

    项目管理系统UI图片示例如下: 在这个项目中,我们将使用一个现代化的UI设计,包括一个清晰的布局和易于使用的导航栏。我们的系统将包含多个功能模块,包括任务管理、进度跟踪、报告和文档…

    科研百科 2024年12月18日
    13