Skip to content

imtaotao/virtual-es-module

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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'

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published