Rails 5.0.0.1
Ruby 2.3.1我想这应该是一个礼物问题,但同样,它适用于与这一起创建这的人。所以,没什么稀奇的:
Application.js
//= require jquery
//= require jquery_ujs
//= require turbolinks
//= cable
//= require_self
//= require react_ujs
window.$ = window.jQuery = global.$ = require('jquery');
var React = window.React = global.React = require('react');
var ReactDOM = window.ReactDOM = global.ReactDOM = require('react-dom');
require('./components');Components.js
require( 'babel-polyfill' );
// Manually add components to window and global
// so that react_ujs and react-server can find them and render them.
window.Home = global.Home = require("./components/Home.js").default
// same issue if use *.es6.jsxHome.js (或es6.jsx)
import React from 'react';
import ReactDOM from 'react-dom';
class Home extends React.Component {
render() {
return (
<div className="form-control">
Home baby
</div>
)
}
}
export default Home;Gemfile
gem "browserify-rails"
gem 'react-railsconfig/application.rb
# Configure Browserify to use babelify to compile ES6
config.browserify_rails.commandline_options = "-t [ babelify --presets [ es2015 ] ]"
unless Rails.env.production?
# Work around sprockets+teaspoon mismatch:
Rails.application.config.assets.precompile += %w(spec_helper.js)
# Make sure Browserify is triggered when
# asked to serve javascript spec files
config.browserify_rails.paths << lambda { |p|
p.start_with?(Rails.root.join("spec/javascripts").to_s)
}
endnpm
npm install browserify browserify-incremental babelify babel-preset-es2015 --save意料之外的令牌指的是第一个<div>,为什么?
发布于 2016-08-27 07:36:49
JSX语法没有被编译,可能是因为您需要将react预设添加到您的浏览器配置中。
安装软件包:
npm install --save-dev babel-preset-reactconfig/application.rb
config.browserify_rails.commandline_options = "-t [ babelify --presets [ es2015 react ] ]"https://stackoverflow.com/questions/39178340
复制相似问题