0.2.0 • Published 7 years ago
trans-loader v0.2.0
trans-loader
You don't need npm and bundler.
You need just a service-worker
script.
What this script does...
- Transform
.js
with babel on service-worker - Transform
.ts
and.tsx
with typescript on service-worker - Load modules from jspm.io and cache them on serviceWorker.
CAUTION!
- development only. Do not use for production.
- It works only for modern browser(ES2015+ and ES Modules ready).
How to use
Put dist/sw.js as /sw.js
on your app root.
wget https://raw.githubusercontent.com/mizchi/trans-loader/master/dist/sw.js
Rewrite your entry js like below.
Before
<script src="/main.js"></script>
After
<script type=module>
(async () => {
const run = () => import('/main.js') // your entry js
if (navigator.serviceWorker.controller) {
run()
} else {
const reg = await navigator.serviceWorker.register("/sw.js");
await navigator.serviceWorker.ready;
navigator.serviceWorker.addEventListener('controllerchange', run)
}
})()
</script>
See working demo
Example 1: Compiled with babel
// /your-entry.js
import React from "react";
import ReactDOM from "react-dom";
ReactDOM.render(<h1>Hello</h1>, document.querySelector(".root"));
Example 2: Load relative file
index.html
sw.js
main.js
components/App.js
// main.js
import React from "react";
import ReactDOM from "react-dom";
import App from "./components/App";
ReactDOM.render(<App />, document.querySelector(".root"));
Example 3: Load typescript
index.html
sw.js
main.js
components/App.tsx
// main.js
import React from "react";
import ReactDOM from "react-dom";
import App from "./components/App.tsx"; // You need extension yet...
ReactDOM.render(<App />, document.querySelector(".root"));
Example 4: Loading with package.json
's version
index.html
sw.js
main.js
package.json
package.json
{
"dependencies": {
"react": "16.4.1",
"react-dom": "16.4.1"
}
}
Log
trans-loader: Cache https://dev.jspm.io/react@16.4.1
trans-loader: Cache https://dev.jspm.io/react-dom@16.4.1
How it works
Rewrite npm module path to dev.jspm.io
. See this code
// before
import React from "react";
// after
import React from "https://dev.jspm.io/react";
Advanced: How to build your own trans-loader
Rewrite this babel setting and rebuild this project.
// src/transformWithBabel.js
import { transform } from "@babel/core/lib/transform";
import pluginSyntaxDynamicImport from "@babel/plugin-syntax-dynamic-import";
import flow from "@babel/preset-flow";
import react from "@babel/preset-react";
import rewriteModulePath from "./rewriteModulePath";
export function transformWithBabel(source, filename = "") {
return transform(source, {
presets: [flow, react],
plugins: [
pluginSyntaxDynamicImport,
[
rewriteModulePath,
{
filename
}
]
]
}).code;
}
TODO
- Support
package.json
to load with version - Can load without extname for
.ts
LICENSE
MIT