Open DjebbZ opened 9 years ago
I didn't tell, but I'm using : node 0.10.25/35, borwserify latest 8.1.3, browserify-shim latest 3.8.2, jquery latest 2.1.3.
Got bit by this too. Same versions as @DjebbZ above. For now, since the only thing I'm shimming is jQuery, I'm gonna factor it out.
I strongly recommend literalify as an alternative to browserify-shim. If you are using large/well-known libraries like jQuery you probably want to include them from a separate script file/CDN anyway, and literalify makes that super easy.
Actually b-shim uses exposify to do just what you decribe, see the global feature.
@idolizesc Does it work with factor-bundle?
@zetlen Yes, it does.
I know you can do the same thing with b-shim, but it is just more work to configure in my opinion. Totally personal preference.
"literalify": {"some-dependency": "window.$"}
"browserify-shim": {"some-dependency": "global:$"}
The only difference is that b-shim doesn't support transform options for config but exposify does. And exposify is smarter for the global use case. Yes, it won't let you do arbitrary code. But it will check global
in addition to window
.
We were using browserify with browserify-shim to be able to use jQuery with a few plugins. So far so good. At this time we were creating another bundle for dependencies common across all pages, manually specifying them.
We then discovered and decided to use factor-bundle to factor common dependencies in a better way. The result was very good in terms of file size, but shims provided by browserify-shim disappeared. Since jQuery and its plugins are used in several pages, they're successfully factored out with factor-bundle, but they're produced without the shims. The problem is that jQuery plugins rely in
window.jQuery
that's no more available since there's no more shim.We ended up
require
ing jQuery manually in the HTML and expose it, with<script>var jQuery = require("jquery")</script>
. We would love factor-bundle to work with browserify-shim (or the opposite, whatever).My understanding is that since factor-bundle is a plugin that act at the bundle level, it may not call it properly. But in our setup, it successfully apply the
reactify
transform (we use React.js with JSX syntax). So I suppose it's not a problem of factor-bundle not using transforms at all, but a specific incompatibility between factor-bundle and browserify-shim. However I couln't determine the problem precisely since I'm not familiar at all with the internals of those modules.For reference in case it helps, here are relevant parts of our package.json and gulpfile (some parts are skipped to focus, it may look inconsistent/weird) :
package.json
gulpfile.js
Hope this helps identify the problem. Thanks in advance.
(Let me ping browserify-shim people : @thlorenz and @bendrucker. In case I shouldn't, sorry guys !)