reactjs - Next.js( react )+ Phaser : ReferenceError: navigator is not defined

标签 reactjs next.js phaser-framework

我正在尝试使用 phaserion-phaser/react 在 Next.js 应用程序中构建包含游戏的页面。这是我的 pages/game.js(使用此处的 React 示例 https://github.com/proyecto26/ion-phaser):

import React, { Component } from 'react'
import Phaser from 'phaser'
import { IonPhaser } from '@ion-phaser/react'

class App extends Component {
  state = {
    initialize: false,
    game: {
      width: "100%",
      height: "100%",
      type: Phaser.AUTO,
      scene: {}
    }
  }
  render() {
    const { initialize, game } = this.state
    return (
      <IonPhaser game={game} initialize={initialize} />
    )
  }
}

export default App;

运行 next dev 并访问该页面会出现以下错误:

ReferenceError: navigator is not defined

This error happened while generating the page. Any console logs will be displayed in the terminal window.
Call Stack
init
file:///C:/git_projects/game/node_modules/phaser/src/device/OS.js (69:14)
Object.<anonymous>
file:///C:/git_projects/game/node_modules/phaser/src/device/OS.js (186:18)
Module._compile
internal/modules/cjs/loader.js (1063:30)
Object.Module._extensions..js
internal/modules/cjs/loader.js (1092:10)
Module.load
internal/modules/cjs/loader.js (928:32)
Function.Module._load
internal/modules/cjs/loader.js (769:14)
Module.require
internal/modules/cjs/loader.js (952:19)
require
internal/modules/cjs/helpers.js (88:18)
Object.<anonymous>
file:///C:/git_projects/floam/node_modules/phaser/src/device/index.js (32:9)
Module._compile
internal/modules/cjs/loader.js (1063:30)

为什么没有定义navigator

这些是我在 package.json 中的相关包版本:

"next": "^9.5.5",
"react": "^16.5.2",
"react-dom": "^16.5.2",
"phaser": "^3.55.2",
"@ion-phaser/react": "^1.3.0",

最佳答案

可能这个包不适合SSR。它似乎在调用 navigator 时没有检查浏览器 api 的可用性,并且在服务器端抛出错误。

如果这个包是 React 组件那么你可以尝试使用 next/dynamic导入它(使用 ssr: false 将其从 SSR 中排除):

import dynamic from 'next/dynamic'

const Phaser = dynamic(
  () => import('@ion-phaser/react'),
  { ssr: false }
)

如果这不起作用,那么您需要使用常规的非 Next.js 动态 import() 来导入整个模块(可能在 useEffect 中)

关于reactjs - Next.js( react )+ Phaser : ReferenceError: navigator is not defined,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68226699/

相关文章:

reactjs - 使用 ref 和 useEffect 监听 Formik 字段的变化

javascript - Nextjs 静态页面动态路由给出 `paths` 必须是字符串或对象数组...错误

javascript - 使用 TypeScript 中的 Next JS 设置 Jest + React 测试库——设置 jest.config.js 时出错

reactjs - 如何直接设置<Image/>组件的边距?

javascript - 移相器 3 es6 : How to create a Player class?

reactjs - 如何向“ Material UI选择”选项添加图标?

javascript - 开 Jest , enzyme - 测试返回 jsx 的方法

javascript - 如何在 react 路由器中的每次路由更改时监听窗口负载?

javascript - 使用 Phaser.js 和 Ionic 开发游戏应用程序(缓慢/不稳定的渲染)

javascript - 如何在phaser中截取游戏div的屏幕截图