-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.mjs
52 lines (37 loc) · 1.3 KB
/
server.mjs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import fs from 'fs'
import path from 'path'
import express from 'express'
import { createSSRApp } from 'vue'
import { createServer } from 'vite'
import { renderToString as _renderToString } from 'vue/server-renderer'
const resolve = (filePath) => path.resolve(filePath)
const renderToString = async(url) => {
const { default: App } = await vite.ssrLoadModule('/src/app.vue')
const { createRouter } = await vite.ssrLoadModule('/src/router.ts')
const app = createSSRApp(App)
const router = createRouter()
app.use(router)
router.push(url)
await router.isReady()
const html = await _renderToString(app, {})
return { html }
}
const app = express()
const vite = await createServer({
root: resolve('.'),
appType: 'custom',
server: {
middlewareMode: true,
},
})
app.use(vite.middlewares)
app.use('*', async(req, res) => {
const url = req.originalUrl || req.url
const template = await vite.transformIndexHtml(url, fs.readFileSync(resolve('index.html'), 'utf-8'))
const { html: renderedHtml } = await renderToString(url)
const html = template.replace('<div id="app"></div>', `<div id="app">${renderedHtml}</div>`)
res.status(200).set({ 'Content-Type': 'text/html' }).end(html)
})
app.listen(3000, () => {
console.log('http://localhost:3000')
})