Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Uncaught TypeError: Cannot read property '0' of undefined at Object.require.624../cjs/react-is.development.js #94

Open
omar-enrique opened this issue Apr 7, 2021 · 0 comments

Comments

@omar-enrique
Copy link

omar-enrique commented Apr 7, 2021

I have some React components that I am bundling with browserify, and I decided to try out factor-bundle to split code between pages of my app. Here is the js file I have written to browserify with factor-bundle:

var browserify = require('browserify');
var fs = require('fs');

var pwd = './usr/local/www/documents/media/js/react/'
var dest = './usr/local/www/documents/media/js/browserified/'

var files = [ pwd + 'a.js', pwd + 'b.js' ];
var b = browserify(files);
b.plugin('factor-bundle', {
    outputs: [ dest + 'a.js', dest + 'b.js']
});
b.bundle().pipe(fs.createWriteStream(dest + 'common.js'));

When importing that newly created a.js bundle into an HTML doc, I get the following error that crashes the React component:

Uncaught TypeError: Cannot read property '0' of undefined
    at Object.require.624../cjs/react-is.development.js (eval at globalEval (jquery.min.js:2), <anonymous>:57741:18)
    at s (eval at globalEval (jquery.min.js:2), <anonymous>:1:262)
    at eval (eval at globalEval (jquery.min.js:2), <anonymous>:1:313)
    at Object.require.615../DataUtils (eval at globalEval (jquery.min.js:2), <anonymous>:57426:16)
    at s (eval at globalEval (jquery.min.js:2), <anonymous>:1:262)
    at eval (eval at globalEval (jquery.min.js:2), <anonymous>:1:313)
    at Object.require.579.../util/DataUtils (eval at globalEval (jquery.min.js:2), <anonymous>:52263:19)
    at s (eval at globalEval (jquery.min.js:2), <anonymous>:1:262)
    at eval (eval at globalEval (jquery.min.js:2), <anonymous>:1:313)
    at Object.require.587../cartesian/Area (eval at globalEval (jquery.min.js:2), <anonymous>:37928:14)

The error is not very informative, but by removing some lines of code, I was able to find that the presence of the following line was causing the issue to appear:

import {Area, AreaChart, XAxis, YAxis, CartesianGrid, Tooltip, Legend, ResponsiveContainer} from "recharts";

I am not sure to think that this issue has anything to do with recharts. If I browserify all my react code into a single bundle, I am able to import and use that bundle just fine. But if I import a.js with factor-bundle, this issue will appear.

Using the links given by the console log's error, the line that is failing looks something like this:

exports.parseChildIndex = parseChildIndex;
},{"./DataUtils":821,"./ShallowEqual":829,"lodash/flatten":650,"lodash/get":651,"lodash/isArray":656,"lodash/isNil":665,"lodash/isString":671,"react":757,"react-is":837}],837:[function(require,module,exports){
arguments[4][722][0].apply(exports,arguments)
},{"./cjs/react-is.development.js":835,"./cjs/react-is.production.min.js":836,"_process":710,"dup":722}],836:[function(require,module,exports){
....

Where the bolded [0] is what is marked as the breaking code. Not sure how or why this is happening, but using normal browserify does not cause this issue, which makes me think it has more to do with what's going on in factor-bundle than the recharts package.

I know this is an obscure issue. Any help would be appreciated because code-splitting would be very helpful for my app.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant