首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在webpacker中使用react-rails?

如何在webpacker中使用react-rails?
EN

Stack Overflow用户
提问于 2017-04-22 18:35:30
回答 3查看 3.7K关注 0票数 5

我用webpacker创建了一个示例项目react-rails。但显示错误“未捕获ReferenceError:未定义人员”。请告诉我如何在webpacker中使用react-rails?我执行的处理如下所示。

Rails版本

代码语言:javascript
复制
$ rails -v
Rails 5.0.2

Gem版本

代码语言:javascript
复制
react-rails (2.1.0)
webpacker (1.1)

创建Rails项目

代码语言:javascript
复制
$ rails new example

将webpacker和react-rails添加到Gemfile

代码语言:javascript
复制
gem 'webpacker', github: 'rails/webpacker'
gem "react-rails"

安装webpacker和react

代码语言:javascript
复制
$ rails webpacker:install
$ rails webpacker:install:react
$ rails generate react:install

创建控制器

代码语言:javascript
复制
$ bin/rails g controller home

添加路由

代码语言:javascript
复制
config/routes.rb
root "home#index"

添加react组件

代码语言:javascript
复制
$ bin/rails g react:component person name --es6

添加react_component标签

代码语言:javascript
复制
app/views/home/index.html.erb
<%= react_component("Person", { name: "Hello" }) %>

向application.html.erb添加javascript_pack_tag

代码语言:javascript
复制
app/views/layouts/application.html.erb
<%= javascript_pack_tag 'application' %>

运行服务器

代码语言:javascript
复制
$ bin/rails s
$ bin/webpack-dev-server

显示错误控制台

代码语言:javascript
复制
VM27375:1 Uncaught ReferenceError: Person is not defined
    at eval (eval at module.exports (fromGlobal.js?fc31:13), <anonymous>:1:1)
    at module.exports (fromGlobal.js?fc31:13)
    at Object.getConstructor (fromRequireContextWithGlobalFallback.js?cbbb:16)
    at Object.mountComponents (index.js?c0e8:82)
    at HTMLDocument.ReactRailsUJS.handleMount (index.js?c0e8:124)
    at HTMLDocument.dispatch (jquery.self-bd7ddd3….js?body=1:5227)
    at HTMLDocument.elemData.handle (jquery.self-bd7ddd3….js?body=1:4879)

示例项目

https://github.com/yokochi/webpacker_example

EN

回答 3

Stack Overflow用户

发布于 2017-05-03 14:15:17

app/javascript/components/person.js重命名为app/javascript/components/Person.js (例如大写)

或者改用react_component('person')

TLDR;大写很重要。

票数 2
EN

Stack Overflow用户

发布于 2017-05-12 22:20:13

@Akio Yamazaki

https://github.com/yokochi/webpacker_example/commit/55ca96c1257e611dfb17b27fe53b402a97d5dedc#diff-0c7c7cb70dec34ec9dcff19a0f5bd40bR1

你应该在你的组件和导出组件中要求(‘react’)

试试这个。

代码语言:javascript
复制
var React = require("react")

class Person extends React.Component {
  render () {
    return (
      <div>
        <div>Name: {this.props.name}</div>
      </div>
    );
  }
}

Person.propTypes = {
  name: React.PropTypes.node
};

module.exports = Person

但是这种方式会更好

代码语言:javascript
复制
import React from 'react'

class Person extends React.Component {
  constructor(props){
    super(props)
  }

  render() {
    <div>Name: {this.props.name}</div>
  }
}

export default Person

或者..。

代码语言:javascript
复制
import React from 'react'

const Person = props => (
  <div>Name: {props.name}</div>
)

export default Person

我有一个回购,也许可以提供一些参考。

https://github.com/kakas/react-rails_with_webpacker_example/commits/master

票数 2
EN

Stack Overflow用户

发布于 2019-12-28 05:33:42

也许太晚了,我遇到了同样的问题,我解决了在Gemfile中更改版本的问题;这应该是可行的:

代码语言:javascript
复制
gem 'react-rails', '~> 1.7', '>= 1.7.1'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43558186

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档