Skip to content

Latest commit

 

History

History
94 lines (69 loc) · 1.77 KB

README.md

File metadata and controls

94 lines (69 loc) · 1.77 KB

Virtual es module

NPM version

Based on the es module implemented by acorn, easy to operate in the sandbox.

Demo

<!DOCTYPE html>
<html lang="en">
<body>
  <script src="https://unpkg.com/virtual-es-module/dist/virtual-esm.umd.js"></script>
  <script type="virtual-module">
    import * as _ from 'https://unpkg.com/lodash-es';
    console.log(_);

    import * as m from './m.js';
    console.log(m);

    import('./m.js').then(mm => {
      console.log(m === mm); // true
    })
  </script>
</body>
</html>

API

Import by url

import { Runtime } from 'virtual-es-module';
const runtime = new Runtime();

const module = await runtime.importByUrl('./a.mjs');
console.log(module);

Import by code

import { Runtime } from 'virtual-es-module';
const runtime = new Runtime();

const module = await runtime.importByCode(`
  import * as m from './a.mjs';
  export default 1;
`);
console.log(module);

Custom code execution

import { Runtime } from 'virtual-es-module';

const runtime = new Runtime({
  execCode(output, provider, exec) {
    const sourcemap = `\n//@ sourceMappingURL=${output.map}`;
    const code = `${output.code}\n//${output.storeId}${sourcemap}`;

    exec(
      code,
      {
        ...provider,
        // Inject environment variables
        require(name) {
          // return ...
        },
      },
    );
  }
});

const module = await runtime.importByUrl('./a.mjs');
console.log(module);

Not support

The code executed by eval cannot be converted by this scheme.

import m from './m.js';

eval('console.log(m);') // throw error 'm is not defined'