详解React项目中碰到的IE问题
2019-03-28 11:00
246 查看
最近接手一个React项目,在IE下碰到了俩问题
IE11报错如下:
跟踪一下之后,发现是一些其他的npm包里面用到了startsWith这个方法,可以自己polyfill一下:
if (!String.prototype.startsWith) { String.prototype.startsWith = function (search, pos) { return this.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search } }
不过加prototype的方法毕竟不好,可以通过引入@babel/polyfill
解决,在入口文件中引入import '@babel/polyfill'
;
IE11问题解决后,IE10又出问题了。。。
犯了stackoverflow和github的很多帖子之后,在这个帖子里找到,发现是Object.setPrototypeOf
的问题,Object.setPrototypeOf说是支持了IE9-11, 实际在源码里只实现了11+(https://github.com/paulmillr/es6-shim/blame/master/README.md#L78)
解决办法可以是在polyfill url后加上excludes=Object.setPrototypeOf
, 或者自己实现Object.setPrototypeOf
方法,我这里引入了一个库setprototypeof,然后在入口文件中加上Object.setPrototypeOf = require('setprototypeof');
其实这个库里的实现代码非常少, 可以简单看下
'use strict' /* eslint no-proto: 0 */ module.exports = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array ? setProtoOf : mixinProperties) function setProtoOf (obj, proto) { obj.__proto__ = proto return obj } function mixinProperties (obj, proto) { for (var prop in proto) { if (!obj.hasOwnProperty(prop)) { obj[prop] = proto[prop] } } return obj }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章推荐
- react ice-design ie兼容问题,由于ie浏览器不支持箭头函数,导致react项目在ie中不兼容的解决办法
- 详解Springboot+React项目跨域访问问题
- 详解eclipse将项目打包成jar文件的两种方法及问题解决方法
- DWZ-JUI中碰到的问题解决方法详解
- 初次使用VS2010基于C++开发项目碰到的问题及解决方法
- 试着用React写项目-利用react-router解决跳转路由等问题(二)
- Swift 项目使用 CoreData 可能会碰到的 32 位系统问题
- Springboot+React项目跨域访问问题
- 学生宿舍管理系统 项目设计、实现以及碰到的问题
- 将标注当前位置项目,整合到其他项目中碰到的问题。
- java项目中经常碰到的内存溢出问题: java.lang.OutOfMemoryError: PermGen space, 堆内存和非堆内存,写的很好,理解很方便
- React-Native工程项目打包编译发布过程详解
- 用vue-cli和iview相关做项目不兼容ie问题
- 使用ExternalInterface.addCallback在IE中碰到的问题
- 搭建项目碰到的问题
- 解决ie下载excel文件直接在浏览器打开的问题(tomcat,web项目)
- React Native项目遇到的问题 -> 端口号修改
- react项目开发中遇到的问题
- .net1.1项目升级到.net2.0碰到的问题
- React项目中的一些问题