SEO middleware for express base on chrome-render, a substitute for prerender.
Modern web app use technique like react.js vue.js which render html in browser, this lead to search engine can't crawl your page content.
This project want to solve this kind of problem in a general-purpose way, it detect request is from search engine crawler then use headless chrome to render out your modern web page and return to crawler.
Here is express-middleware-seo's architecture diagram:

npm i express-middleware-seothen use it:
const express = require('express')
const path = require('path')
const app = express()
const { seoMiddleware } = require('express-middleware-seo')
app.use(
seoMiddleware({
enable: true,
render: {
useReady: true,
renderTimeout: 10000
}
})
)
app.use(express.static(__dirname + '/static'))
app.listen(3000)you can download and run this complete demo
You should install Chrome 59+ in your servers before you use this middleware
options come form chrome-render
maxTab:numbermax tab chrome will open to render pages, default is no limit,maxTabused to avoid open to many tab lead to chrome crash.ChromeRenderwill create a tab poll to reuse tab for performance improve and resource reduce as open and close tab in chrome require time, like database connection poll.renderTimeout:numberin ms,chromeRender.render()will throw error if html string can't be resolved afterrenderTimeout, default is 5000ms.useReady:booleanwhether usewindow.isPageReady=1to notify chrome-render page has ready. default is false chrome-render usedomContentEventFiredas page has ready.script:stringis an option param. inject script source to evaluate when page on load
- chrome-render general server render base on chrome.
- chrome-pool Headless chrome tabs manage pool.
- koa-chrome-render chrome-render middleware for koa
- koa-seo koa SEO middleware