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

相关推荐

  • 环发所“全生物降解地膜产品研发与应用”成果获北京市科学技术进步二等奖

      近日,中国农业科学院农业环境与可持续发展研究所节水新材料与地膜污染防控团队科技成果“全生物降解地膜产品研发与应用”荣获2020-2021年度北京市科学技术奖(科学技术进步类)二…

    科研百科 2022年5月12日
    253
  • 用于项目管理的软件

    用于项目管理的软件 项目管理已经成为了现代企业运营中不可或缺的一部分。通过使用专门的项目管理软件,企业可以更加高效地管理项目,确保项目按时完成,并达到预期的成果。本文将介绍一些常见…

    科研百科 2024年8月16日
    46
  • 黑龙江省工会党风廉政建设工作会议召开(黑龙江省总工会官网)

    来源:【黑龙江日报】 6月8日,黑龙江省工会党风廉政建设工作电视电话会议召开。会议强调,全省各级工会要以正风肃纪反腐的实际行动,推动工会全面从严治党向纵深发展,推进新时代龙江工运事…

    科研百科 2022年7月13日
    251
  • 厦门首个非公党建可视化平台正式上线(厦门 非公党建)

    福建日报·新福建客户端9月8日讯(记者 田圆 通讯员 傅书基 吴静泓)鼠标轻点,辖区内169个上市企业、上市后备企业、“专精特新”等企业的党建动态、业务情况、发展需求等,便一目了然…

    科研百科 2024年1月12日
    112
  • 核查表 VS 核对单 -u0026 敏捷项目管理(核对单 核查表的区别)

    数据收集技术 – 核查表 Check sheets 基本概念: 核查表 在收集数据时用作查对清单的计数表格。又称计数表,用于合理排列各种事项,以便有效地收集关于潜在质量…

    科研百科 2023年10月28日
    122
  • 县直机关党建存在问题及对策

    县直机关党建存在问题及对策 近年来,县直机关党建在推进全面从严治党、加强组织建设方面取得了一定的成绩,但同时也存在一些问题,需要采取对策加以解决。 存在问题: 1. 党员队伍结构不…

    科研百科 2024年10月13日
    13
  • 对建设工程项目管理的认识

    对建设工程项目管理的认识 建设工程项目管理是指对一项建筑工程从规划、设计、施工、验收、维护等一系列活动的管理。作为一项复杂的工程,建设工程项目管理的重要性不言而喻。本文将从以下几个…

    科研百科 2024年5月26日
    169
  • jira项目管理系统是什么

    jira项目管理系统是一种广泛使用的开源项目管理软件,可以帮助团队更好地协作和管理软件项目。本文将介绍jira项目管理系统的基本功能和优点。 jira项目管理系统是一个集中式的项目…

    科研百科 2025年1月6日
    2
  • 科研项目个人申报

    科研项目个人申报 随着科技的不断发展,科研项目的个人申报也成为了一项备受关注的活动。个人申报科研项目不仅能够为研究人员提供更多的研究资源,还能够提高研究人员的研究水平和创新能力。本…

    科研百科 2025年2月14日
    0
  • 工地进度管理

    工地进度管理 工地进度管理是指在 construction site 中,通过制定计划,控制进度,确保工程按时完成的一种管理方法。工地进度管理对于工程的质量,安全,时间和成本都有着…

    科研百科 2024年5月26日
    104