nwb provides middleware for serving a hot reloading app from your own server.
This gives you the same setup as if you'd run the nwb serve
command, using your app's nwb.config.js
file for configuration as usual if you have one.
Middleware for Express 4.x for developing apps can be imported from 'nwb/express'
.
See the nwb-react-tutorial project for an example of using it.
Your app's version of the Express module must be passed as the first argument.
-
type
- the type of project being built, must be one ofreact
,preact
,inferno
orweb
.If you don't provide a
type
, nwb will try to grab it from yournwb.config.js
file (or a different file specified using theconfig
option) instead.If you don't have a config file, you must provide a
type
or the middleware won't know what to do and will throw an error. -
config
- path to a config file [default:'nwb.config.js'
] -
entry
- entry point for the app [default:'src/index.js'
] -
hmre
- use React Transform to attempt to automatically handle Hot Module Replacement for React components and display an overlay withrender()
errors when serving a React app [default:true
] -
install
- automatically install missing npm dependencies [default:false
] -
reload
- reload the page if Hot Module Replacement is unsuccessful [default:false
]
Here's a minimal express server which serves up an app:
var express = require('express')
var app = express()
app.use(require('nwb/express')(express))
app.use(express.static('public'))
app.listen(3000, function(err) {
if (err) {
console.error('error starting server:')
console.error(err.stack)
process.exit(1)
}
console.log('server listening at http://localhost:3000')
})