vue-ssr中实例渲染中的script问题

发布于 2022-09-11 22:35:39 字数 1099 浏览 15 评论 0

在vue-ssr项目中渲染一个vue实例,直接像spa那样初始化vue实例的话事件不会被触发,想知道怎么给template中的dom元素绑定事件?

相关代码

const fs = require('fs')
const Vue = require('vue')
const server = require('express')()
const VueServerRenderer = require('vue-server-renderer')
const renderer = VueServerRenderer.createRenderer({
  template: fs.readFileSync('./index.template.html', 'utf-8')
})

server.get('*', (req, res) => {
  const app = new Vue({
    template: `
      <div>
        <button @click="testFun">click me</button>
        <br/>
      </div>
    `,
    methods: {
      testFun() {
        console.log('----------------')
      }
    }
  })

  renderer.renderToString(app, context).then(html => {
    res.end(`${html}`)
  }).catch(err => {
    res.status(500).end('Internal Server Error')
    return
  })
})

server.set('port', process.env.PORT || 6666)
let hostname = '127.0.0.1'
server.listen(server.get('port'), hostname, () => {
  console.log(`Server running at http://${hostname}:${server.get('port')}`)
})

希望知道怎么在ssr中写这些函数,谢谢

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文