React+Webpack+ES6 兼容低版本浏览器(IE9)解决方案
起因在准备提测的那天,顺便打开IE9看一眼(注意,这里是原生IE9,不是用IE11模拟的IE9),OMG!
排查后发现,原来是因为构造函数中使用了 class Child extends React.Component { constructor(props) { super(props); this.state = {count:this.props.count} } render(){ return (<p>child</p>) } } class Superer extends React.Component { state = {count:1} render() { return <Child count = {this.state.count}/> } } 老司机们肯定能一眼发现问题: 怎么能就这么不明不白的算了,哼! 原因既然浏览器运行的代码是经过babel编译的,那这个锅先甩给babel。查看一下babel编译后的源码。如下 "use strict"; var _createClass = function () { function defineProperties(target,props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target,descriptor.key,descriptor); } } return function (Constructor,protoProps,staticProps) { if (protoProps) defineProperties(Constructor.prototype,protoProps); if (staticProps) defineProperties(Constructor,staticProps); return Constructor; }; }(); function _classCallCheck(instance,Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self,call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass,superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function,not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype,{ constructor: { value: subClass,enumerable: false,writable: true,configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass,superClass) : subClass.__proto__ = superClass; } var Child = function (_React$Component) { _inherits(Child,_React$Component); function Child(props) { _classCallCheck(this,Child); var _this = _possibleConstructorReturn(this,(Child.__proto__ || Object.getPrototypeOf(Child)).call(this,props)); _this.state = { count: _this.props.count }; return _this; } _createClass(Child,[{ key: "render",value: function render() { return React.createElement( "p",null,"child" ); } }]); return Child; }(React.Component); var Superer = function (_React$Component2) { _inherits(Superer,_React$Component2); function Superer() { var _ref; var _temp,_this2,_ret; _classCallCheck(this,Superer); for (var _len = arguments.length,args = Array(_len),_key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this2 = _possibleConstructorReturn(this,(_ref = Superer.__proto__ || Object.getPrototypeOf(Superer)).call.apply(_ref,[this].concat(args))),_this2),_this2.state = { count: 1 },_temp),_possibleConstructorReturn(_this2,_ret); } _createClass(Superer,value: function render() { return React.createElement(Child,{ count: this.state.count }); } }]); return Superer; }(React.Component); 重点看 subClass.prototype = Object.create(superClass && superClass.prototype,configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass,superClass) : subClass.__proto__ = superClass; function Child(props) { _classCallCheck(this,Child); var _this = _possibleConstructorReturn(this,props)); _this.state = { count: _this.props.count }; return _this; } 找不到的就是 解决方法果然这个锅是babel的。 那要怎么解决呢?如果是自己写的逻辑,直接修改写法就可以了。但是,如果你用了开源组件,看了源码,找到问题,提了issue,开发者还跟你互动,就说没问题,他还说他亲测没问题,就是不改,你该怎么办?(手动微笑脸) 使用babel插件 function _inherits(subClass,superClass) { ...; if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass,superClass) : _defaults(subClass,superClass); } function _defaults(obj,defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults,key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj,key,value); } } return obj; } 至此,IE9下总是报错的问题就解决了,希望能给同样掉进此坑的小伙伴一点帮助,早点摆脱IE的魔爪。 参考文章: ES6 + Webpack + React + Babel 如何在低版本浏览器上愉快的玩耍(上) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |