Nonlinear Performance Magnification

    @pablosz/fastify-nextjs
    TypeScript icon, indicating that this package has built-in type declarations

    5.0.4 • Public • Published

    fastify-nextjs

    js-standard-style CI workflow

    React server side rendering support for Fastify with Next Framework.

    Install

    npm i fastify-nextjs next --save
    

    Usage

    Since Next needs some time to be ready on the first launch, you must declare your routes inside the after callback, after you registered the plugin.
    The plugin will expose the api next in Fastify that will handle the rendering for you.

    const fastify = require('fastify')()
    
    fastify
      .register(require('fastify-nextjs'))
      .after(() => {
        fastify.next('/hello')
      })
    
    fastify.listen(3000, err => {
      if (err) throw err
      console.log('Server listening on http://localhost:3000')
    })

    All you server rendered pages must be saved in the folder pages, as you can see in the next documentation.

    // /pages/hello.js
    export default () => <div>hello world</div>

    If you need to pass custom options to next just pass them to register as second parameter.

    fastify.register(require('fastify-nextjs'), { dev: true })

    If you need to handle the render part yourself, just pass a callback to next:

    fastify.next('/hello', (app, req, reply) => {
      // your code
      // `app` is the Next instance
      app.render(req.raw, reply.raw, '/hello', req.query, {})
    })

    Acknowledgements

    This project is kindly sponsored by:

    License

    Licensed under MIT.

    Install

    npm i @pablosz/fastify-nextjs

    DownloadsWeekly Downloads

    2

    Version

    5.0.4

    License

    MIT

    Unpacked Size

    16.4 kB

    Total Files

    13

    Last publish

    Collaborators

    • pablosz