Webpacker 重构后反应组件不呈现

React Component Not Rendering after Webpacker refactoring

我正在尝试将我的 Rails 5.1.3 应用程序从 react-rails 转移到 webpacker - 我正在使用 webpacker-react gem。一切似乎都加载正常(没有错误),但是 React 组件本身不会呈现。

在application.js

import WebpackerReact from 'webpacker-react'
import UserSchedule from 'components/userschedule'
console.log('First test')

在我的 erb 观点中:

<%= react_component 'UserSchedule', render(template: 'appts/user-sched.json.jbuilder') %>

在UserSchedule.jsx里面我有这个代码:

var React = require('react');
var ReactDOM = require('react-dom');

console.log('User schedule file test')

class UserSchedule extends React.Component {
  render() {
    console.log('User schedule inside render')
    return (
      <div className="container-fluid">
        <p>TEST THAT THIS WORKS</p>
      </div>
    );
  }
}

控制台日志记录适用于渲染内部以外的所有内容。

User schedule outside test
First test

所以我知道 jsx 文件正在加载。在呈现的元素内部,显示了正确的 html 标签:

<div data-react-class="UserSchedule" data-react-props="&quot;{\&quot;appts\&quot;:[{\&quot;title\&quot;:\&quot;Isobel ...

那我做错了什么?在从 react-rails 到使用 webpacker-react gem 的 webpacker 之前,还有其他人做过这种转变吗?

尝试将其添加到您的 js 文件中

WebpackerReact.setup({UserSchedule})

还有这个

var React = require('react');
var ReactDOM = require('react-dom');

console.log('User schedule file test')

class UserSchedule extends React.Component {
  render() {
    console.log('User schedule inside render')
    return (
      <div className="container-fluid">
        <p>TEST THAT THIS WORKS</p>
      </div>
    );
  }
}    
export default UserSchedule; //add this