npm install --save @zeit/next-preact preact preact-compat preact-context
or
yarn add @zeit/next-preact preact preact-compat preact-context
Create a next.config.js
in your project
// next.config.js
const withPreact = require('@zeit/next-preact')
module.exports = withPreact()
Then create a server.js
// server.js
require('@zeit/next-preact/alias')()
const { createServer } = require('http')
const next = require('next')
const app = next({ dev: process.env.NODE_ENV !== 'production' })
const port = process.env.PORT || 3000
const handle = app.getRequestHandler()
app.prepare()
.then(() => {
createServer(handle)
.listen(port, () => {
console.log(`> Ready on http://localhost:${port}`)
})
})
Optionally you can add your custom Next.js configuration as parameter
// next.config.js
const withPreact = require('@zeit/next-preact')
module.exports = withPreact({
webpack(config, options) {
return config
}
})