@idio/frontend
data:image/s3,"s3://crabby-images/37df6/37df6219fe83f3d4f936b96b4e22520484bef29f" alt="npm version"
@idio/frontend
is The Middleware To Serve Front-End JavaScript. It allows to set-up the modern front-end development environment where node_modules
are served alongside compiled JSX code (without using Babel, see @a-la/jsx
).
yarn add -E @idio/frontend
Table Of Contents
data:image/s3,"s3://crabby-images/ae8a9/ae8a92614e0cc06739d113b4eeb1261486b79986" alt=""
API
The package is available by importing its default function:
import frontend from '@idio/frontend'
data:image/s3,"s3://crabby-images/48dd2/48dd27b5abf9aa31ce79037c121624277c144607" alt=""
frontend(
config: FrontendConfig,
): Middleware
The middleware constructor will initialise the middleware function to serve files from the specified directory (frontend
by default). The files will be updated on-the-fly to fix their imports to relative paths (e.g., preact
will be transformed into node_modules/preact/dist/preact.mjs
). Any CSS styles will also be served using an injector script.
FrontendConfig
: Options for the middleware.
Name | Type | Description | Default |
---|
directory | string | The directory from which to serve files. | frontend |
pragma | string | The pragma function to import. This enables to skip writing h at the beginning of each file. JSX will be transpiled to have h pragma, therefore to use React it's possible to do import { createElement: h } from 'react' . | import { h } from 'preact' |
The middleware can be used in any Koa
application, or within the idio
web server.
import core from '@idio/core'
import render from 'preact-render-to-string'
import frontend from '@idio/frontend'
(async () => {
const { url, router, app } = await core({
logger: { use: true },
frontend: {
use: true,
middlewareConstructor(_, config) {
return frontend(config)
},
config: {
directory: 'example/frontend',
},
},
})
router.get('/', async (ctx) => {
ctx.body = '<!doctype html>\n' + render(
<html>
<head><title>Example</title></head>
<body>
Hello World
<script type="module" src="example/frontend"/>
</body>
</html>)
})
app.use(router.routes())
console.log('Started on %s', url)
})()
example/frontend
├── Component.jsx
├── index.jsx
└── style.css
The entry point
import { render } from 'preact'
import Component from './Component'
render(<Component test="Welcome"/>, document.body)
The component
import './style.css'
const Component = ({ test }) => {
return <div>{test}</div>
}
export default Component
The style
body {
background: lightcyan;
}
data:image/s3,"s3://crabby-images/b69ca/b69ca219a681410d74a9aa2b07d34bf3e367c54b" alt="Chrome Example"
data:image/s3,"s3://crabby-images/7398f/7398ffb56e1bf7ee98cd5da82115272c6c917fe6" alt=""
Copyright
data:image/s3,"s3://crabby-images/bb5d2/bb5d25b45b922a09581be9a8b9f68c9eb4ead3c9" alt=""