import-ponyfill v0.1.0
import-ponyfill
Loading incompatible UMD scripts for browser module and worker.
Why you need it
Some lib scripts throw errors in ES module or web worker environments because of specific/deprecated UMD wrappers, which is fixedly using this or window to access the global object.  Thus you need another mechanism to load these scripts.
How it works
- use synchronous XMLHttpRequestto load script
- use sync <script>(ornew Function().call()in web worker) to eval js code
- use /* global xxx */to mark imported UMD global vars
Case 1: In module js
If import './some.umd.js'  throws error, try importSync('./some.umd.js')
// import './some.umd.js'; /* global Some */
import {importSync} from '/node_modules/import-ponyfill/import.js';
importSync('./some.umd.js'); /* global Some */or  if import('./some.umd.js')  rejects with an error,
import('./some.umd.js').then(()=>{ /* global Some */
  console.log(Some);
});try importAsync('./some.umd.js')
import {importAsync} from '/node_modules/import-ponyfill/import.js';
importAsync('./some.umd.js').then()=>{ /* global Some */
  console.log(Some);
});Case 2: In worker js
If importScripts('./some.umd.js') throws error, try importScriptsSync('./some.umd.js') 
// importScripts('./some.umd.js');
importScripts('/node_modules/import-ponyfill/import-scripts.js'); /* global importScriptsSync importScriptsAsync */
importScriptsSync('./some.umd.js');Supported features
- supports standard module name prefixes ./..//http:andhttps:
- maintains a module registry and won't initiate multiple requests for same module
- respects commented sourceMappingURLin main-thread module
These features are designed to be conformant to spec as closer as possible.
Known limitations
- synchronous import requires synchronous XHR which may hurt performance
- use of CSP script-src requires 'unsafe-eval'
- sourceMappingURLin web worker will be ignored- For limitations above, this package gives NO WARRANTY, USE AT YOUR OWN RISK 
Install
npm install import-ponyfillExamples
To run examples,
- checkout
- npm install && npm start
- open http://localhost:8080/examples/
5 years ago