繁体   English   中英

路线未定义,laravel微风惯性反应SSR

[英]Route is not defined, laravel breeze inertia react SSR

我正在尝试在 laravel 中使用SSR惯性。

版本详情:

Php:8.1.2
Laravel:8.82.0
微风:1.7.1
惯性:0.11.0
Npm:8.1.2

/resources/js/ssr.js

createServer((page) => createInertiaApp({
  page,
  render: ReactDOMServer.renderToString,
  resolve: name => require(`./Pages/${name}`),
  setup: ({ App, props }) => <App {...props} />,
}))

/webpack.ssr.mix.js

mix
  .options({ manifest: false })
  .js('resources/js/ssr.js', 'public/js')
  .react()
  .alias({ '@': path.resolve('resources/js') })
  .webpackConfig({
    target: 'node',
    externals: [nodeExternals()],
  })

/resources/views/app.blade.php

<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
    <head>
        ...
        <link rel="stylesheet" href="{{ mix('css/app.css') }}">
        @routes
        <script src="{{ mix('js/app.js') }}" defer></script>
        @inertiaHead
    </head>
    <body class="font-sans antialiased">
        @inertia

        ...
    </body>
</html>

错误:

ReferenceError: route is not defined
at Welcome (/public/js/ssr.js:1413:19)

你试过这个吗? 它在路由 - 惯性中。

app.config.globalProperties.$route = route

首先你需要得到 ziggy-js

npm install ziggy-js

然后运行

php artisan ziggy:generate

这应该在 resources/js 目录中创建一个 ziggy.js 文件。 将您的 ssr.js 修改为

import React from 'react'
import ReactDOMServer from 'react-dom/server'
import { createInertiaApp } from '@inertiajs/inertia-react'
import createServer from '@inertiajs/server'
import route from "ziggy-js";
import { Ziggy } from '@/ziggy'


createServer((page) => createInertiaApp({
    page,
    render: ReactDOMServer.renderToString,
    resolve: name => require(`./Pages/${name}`),
    setup: ({ App, props }) => {

        // Set global function route
        global.route = (name, params, absolute, config = Ziggy) => route(name, params, absolute, config);

        return <App {...props} />
    },
}))

JefteCaro 的解决方案

更多解决方案,以防您想了解更多

代替

<script src="{{ mix('js/app.js') }}" defer></script>

<script src="{{ mix('js/ssr.js') }}" defer></script>

在 /resources/views/app.blade.php

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM