Hello!
I have a React application bundled with Webpack and am trying to load threejs from a CDN on runtime in order to decrease bundle sizes. So far my solution has been to add:
externals: {
three: 'THREE'
}
on my webpack config, so I can import three on my code using the global variable THREE:
import * as THREE from 'three'
and add the minified three bundle to my html:
<script src="https://unpkg.com/[email protected]/build/three.min.js"></script>
This works fine until I need to use something from the examples
folder (such as GLTFLoader.js
, XREstimatedLight.js
, etc). If I add the versions on examples/js
to my html it works fine since they are referencing the THREE variable as well, but as I understand it, the examples/js
folder will be deprecated soon, correct? And there are some files I use that only exist on examples/jsm
, such as XREstimatedLight.js
, so I wouldn’t be able to use this anyway.
So my solution so far is to copy the examples I need into my project, changing the relative imports to use the THREE variable as well, but I’m not very satisfied with it: I’d need to copy and change them again whenever I want to update THREE, for example
So my question is: is there a better/recommended way to do this?