詳解React項目中碰到的IE問題
最近接手一個React項目,在IE下碰到了倆問題
IE11報錯如下:
跟蹤一下之后,發(fā)現(xiàn)是一些其他的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的很多帖子之后,在這個帖子里找到,發(fā)現(xiàn)是Object.setPrototypeOf
的問題,Object.setPrototypeOf說是支持了IE9-11, 實際在源碼里只實現(xiàn)了11+(https://github.com/paulmillr/es6-shim/blame/master/README.md#L78)
解決辦法可以是在polyfill url后加上excludes=Object.setPrototypeOf
, 或者自己實現(xiàn)Object.setPrototypeOf
方法,我這里引入了一個庫setprototypeof,然后在入口文件中加上Object.setPrototypeOf = require('setprototypeof');
其實這個庫里的實現(xiàn)代碼非常少, 可以簡單看下
'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 }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
ReactQuery系列之數(shù)據(jù)轉換示例詳解
這篇文章主要為大家介紹了ReactQuery系列之數(shù)據(jù)轉換示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11React?Refs?的使用forwardRef?源碼示例解析
這篇文章主要為大家介紹了React?之?Refs?的使用和?forwardRef?的源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11ahooks useVirtualList 封裝虛擬滾動列表
這篇文章主要為大家介紹了ahooks useVirtualList 封裝虛擬滾動列表詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09npx create-react-app xxx創(chuàng)建項目報錯的解決辦法
這篇文章主要介紹了npx create-react-app xxx創(chuàng)建項目報錯的解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02