如何解决React项目中碰到的IE问题
这篇文章将为大家详细讲解有关如何解决React项目中碰到的IE问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了德安免费建站欢迎大家使用!
最近接手一个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项目中碰到的IE问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
本文名称:如何解决React项目中碰到的IE问题
分享URL:http://scyanting.com/article/ghpipj.html