Babel.js 服务器端呈现时,React组件返回空对象

3qpi33ja  于 2022-12-16  发布在  Babel
关注(0)|答案(1)|浏览(167)

当我尝试在react应用上实现服务器端渲染时,我遇到了一个奇怪的行为。

...
Error: Element type is invalid: expected a string (for built-in components) or a
class/function (for composite components) but got: object. 
You likely forgot to export your component from the file it's defined in,
or you might have mixed up default and named imports.
...

我意识到带有JSX扩展名的渲染文件存在一个普遍的问题。下面是我的代码。

  • ./服务器/服务器.js*
app.use('/*', (req, res, next) => {
  const context = {};
  const app = ReactDOMServer.renderToString(
    <App />
  );

  console.log(app)

  fs.readFile(path.resolve('./build/index.html'), 'utf-8', (err, data) => {
    if (err) {
      console.log(err);
      return res.status(500).send("Some Error")
    }

    return res.send(
      data.replace(
        '<div id="root"></div>',
        `<div id="root">${app}</div>`
      )
    )
  })
})
  • ./服务器/索引.js*
require("ignore-styles")

require("@babel/register")({
    ignore: [/(node_module)/],
    presets: ['@babel/preset-env', '@babel/preset-react']
})

require('./server')
  • ./源代码/应用程序.jsx*
import './App.scss';
import React from 'react';

function App() {
  return (
    <div className='app'>
     <p>Sample</p>
    </div>
  );
}

export default App;
  • ./源代码/索引.js*
import React from 'react';
import ReactDOM from 'react-dom';
import './index.scss';
import App from './App';
import reportWebVitals from './reportWebVitals';
import { BrowserRouter as Router } from "react-router-dom";

ReactDOM.hydrate(
  <Router>
    <React.StrictMode>
      <App />
    </React.StrictMode>
  </Router>,
  document.getElementById('root')
);

reportWebVitals();

../server/server.js:17:30中调用ReactDOMServer.renderToString时发生错误。问题是组件在导入后被视为空对象。我有一种感觉,这是babel的问题,但我不确定。

ctrmrzij

ctrmrzij1#

我最近在一个非常相似的设置中遇到了同样的问题。在SSR期间,扩展名为.js的组件返回了预期的React组件,而.jsx文件返回了{}
在我的示例中,我将导入从

import App from './components/App'

import App from './components/App.jsx'

并且它修复了这个问题。在这个修改之后,服务器和客户端渲染都返回了预期的组件。

相关问题