diff options
author | Florian Dold <florian.dold@gmail.com> | 2017-04-20 03:09:25 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2017-04-24 16:14:29 +0200 |
commit | 82f2b76e25a4a67e01ec67e5ebe39d14ad771ea8 (patch) | |
tree | 965f6eb89b84d65a62b49008fd972c004832ccd1 /thirdparty/systemjs/README.md | |
parent | e6e0cbc387c2a77b48e4065c229daa65bf1aa0fa (diff) |
Reorganize module loading.
We now use webpack instead of SystemJS, effectively bundling modules
into one file (plus commons chunks) for every entry point. This results
in a much smaller extension size (almost half). Furthermore we use
yarn/npm even for extension run-time dependencies. This relieves us
from manually vendoring and building dependencies. It's also easier to
understand for new developers familiar with node.
Diffstat (limited to 'thirdparty/systemjs/README.md')
-rw-r--r-- | thirdparty/systemjs/README.md | 149 |
1 files changed, 0 insertions, 149 deletions
diff --git a/thirdparty/systemjs/README.md b/thirdparty/systemjs/README.md deleted file mode 100644 index afe998a27..000000000 --- a/thirdparty/systemjs/README.md +++ /dev/null @@ -1,149 +0,0 @@ -SystemJS -======== - -[![Build Status][travis-image]][travis-url] -[](https://gitter.im/systemjs/systemjs?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) -[](https://supporterhq.com/support/33df4abbec4d39260f49015d2457eafe/SystemJS) - -Universal dynamic module loader - loads ES6 modules, AMD, CommonJS and global scripts in the browser and NodeJS. - -* [Loads any module format](docs/module-formats.md) with [exact circular reference and binding support](https://github.com/ModuleLoader/es6-module-loader/blob/v0.17.0/docs/circular-references-bindings.md). -* Loads [ES6 modules compiled into the `System.register` bundle format for production](docs/production-workflows.md), maintaining circular references support. -* Supports RequireJS-style [map](docs/overview.md#map-config), [paths](https://github.com/ModuleLoader/es6-module-loader/blob/master/docs/loader-config.md#paths-implementation), [bundles](docs/production-workflows.md#bundle-extension) and [global shims](docs/module-formats.md#shim-dependencies). -* [Loader plugins](docs/overview.md#plugin-loaders) allow custom transpilation or asset loading. - -Built to the format ES6-specified loader API from [ES6 Specification Draft Rev 27, Section 15](http://wiki.ecmascript.org/doku.php?id=harmony:specification_drafts#august_24_2014_draft_rev_27), -and will be updated to the [WhatWG loader API](https://whatwg.github.io/loader/) as soon as it can be considered stable for implementation. - -~19KB minified and gzipped, runs in IE8+ and NodeJS. - -For discussion, join the [Gitter Room](https://gitter.im/systemjs/systemjs). - -Documentation ---- - -* [ES6 Modules Overview](docs/es6-modules-overview.md) -* [SystemJS Overview](docs/overview.md) -* [Config API](docs/config-api.md) -* [Module Formats](docs/module-formats.md) -* [Production Workflows](docs/production-workflows.md) -* [System API](docs/system-api.md) -* [Creating Plugins](docs/creating-plugins.md) - -Basic Use ---- - -### Browser - -```html -<script src="system.js"></script> -<script> - // set our baseURL reference path - SystemJS.config({ - baseURL: '/js' - }); - - // loads /js/main.js - SystemJS.import('main.js'); -</script> -``` - -The above will support loading all module formats, including ES Modules transpiled into the System.register format. - -To load ES6 code with in-browser transpilation, configure one of the following transpiler plugins: - -* [Babel](https://github.com/systemjs/plugin-babel) -* [TypeScript](https://github.com/frankwallis/plugin-typescript) -* [Traceur](http://github.com/systemjs/plugin-traceur) - -### Promise Polyfill - -SystemJS relies on `Promise` being present in the environment. - -For the best performance in IE and older browsers, it is advisable to load a polyfill like [Bluebird](https://github.com/petkaantonov/bluebird) or [es6-promise](https://github.com/stefanpenner/es6-promise) before SystemJS. - -Otherwise, when Promise is not available, SystemJS will attempt to load the `system-polyfills.js` file located in the dist folder which contains the when.js Promise polyfill. - -### NodeJS - -To load modules in NodeJS, install SystemJS with: - -``` - npm install systemjs -``` - -If transpiling ES6, also install the transpiler plugin, following the instructions from the transpiler project page. - -We can then load modules equivalently in NodeJS as we do in the browser: - -```javascript -var SystemJS = require('systemjs'); - -// loads './app.js' from the current directory -SystemJS.import('./app.js').then(function(m) { - console.log(m); -}); -``` - -If you are using jspm as a package manager you will also need to load the generated configuration. -The best way to do this in node is to get your `System` instance through jspm, which will automatically load your config correctly for you: - -```js -var Loader = require('jspm').Loader; -var SystemJS = new Loader(); - -SystemJS.import('lodash').then(function (_) { - console.log(_); -}); -``` - -### Plugins - -Supported loader plugins: - -* [CSS](https://github.com/systemjs/plugin-css) -* [LESS](https://github.com/systemjs/plugin-less) -* [Image](https://github.com/systemjs/plugin-image) -* [JSON](https://github.com/systemjs/plugin-json) -* [Text](https://github.com/systemjs/plugin-text) -* [Node Binary](https://github.com/systemjs/plugin-node-binary) - -Additional Plugins: - -* [Audio](https://github.com/ozsay/plugin-audio) -* [CoffeeScript](https://github.com/forresto/plugin-coffee) -* [Ember Handlebars](https://github.com/n-fuse/plugin-ember-hbs) -* [Handlebars](https://github.com/davis/plugin-hbs) -* [HTML](https://github.com/Hypercubed/systemjs-plugin-html/) -* [Image (lazy)](https://github.com/laurentgoudet/plugin-lazyimage) -* [Jade](https://github.com/johnsoftek/plugin-jade) -* [Jade VirtualDOM](https://github.com/WorldMaker/system-jade-virtualdom) -* [jst](https://github.com/podio/plugin-jst) -* [JSX](https://github.com/floatdrop/plugin-jsx) -* [Markdown](https://github.com/guybedford/plugin-md) -* [raw](https://github.com/matthewbauer/plugin-raw) -* [SASS](https://github.com/screendriver/plugin-sass) -* [SCSS](https://github.com/kevcjones/plugin-scss) -* [sofe](https://github.com/CanopyTax/sofe) -* [SVG](https://github.com/vuzonp/systemjs-plugin-svg) -* [WebFont](https://github.com/guybedford/plugin-font) -* [WebWorkers](https://github.com/casperlamboo/plugin-worker) -* [YAML](https://github.com/tb/plugin-yaml) - -Guides: - -* [Using plugins](docs/overview.md#plugin-loaders) -* [Creating plugins](docs/creating-plugins.md) - -#### Running the tests - -To install the dependencies correctly, run `bower install` from the root of the repo, then open `test/test.html` in a browser with a local server -or file access flags enabled. - -License ---- - -MIT - -[travis-url]: https://travis-ci.org/systemjs/systemjs -[travis-image]: https://travis-ci.org/systemjs/systemjs.svg?branch=master |