在React组件上运行grunt-browserify时解析错误

时间:2015-04-04 15:21:10

标签: gruntjs reactjs browserify grunt-browserify

我只是在使用React并使用grunt和grunt-browserify进行基本设置,但是我得到了一个解析错误。有人知道解决方案吗?附注 - 当我不使用react / jsx时,任务运行正常。

使用基本组件:

var HelloWorld = React.createClass({
  render: function(){
    return (
      <div>
        Hello World!
      </div>
    )
  }
});

React.render(<HelloWorld />, document.getElementById('app'));

我收到此错误:

>> File "assets/javascripts/app.js" changed.
Running "browserify:dist" (browserify) task
>> /Users/username/www/reactor/assets/javascripts/app.js:4
>>       <div>
>>       ^
>> ParseError: Unexpected token
Warning: Error running grunt-browserify. Use --force to continue.

这是一项艰巨的任务:

  browserify: {
      dist: {
        files: {
          'public/javascripts/app.js' : 
          [
            'assets/javascripts/components/**/*.js',
            'assets/javascripts/app.js'
          ]
        }
      }
    },

2 个答案:

答案 0 :(得分:1)

我没有使用Dhiraj的答案,但这导致我使用了重新设置。

browserify: {
  options: {
    transform: ['reactify'],
    extensions: ['.jsx'],
    debug: true
  },
  dist: {
    files: {
      'public/javascripts/app.js' : 
      [
        'assets/javascripts/components/**/*.jsx',
        'assets/javascripts/app.jsx'
      ]
    }
  }
},

答案 1 :(得分:-1)

HelloWorld类是jsx所以grunt-browserify需要使用transform选项将jsx转换为js。

browserify: {
  dist: {
    options: {
      transform: [ require('grunt-react').browserify ] // <-- this one
    },
    client: {
      src: [assets/javascripts/components/**/*.js, assets/javascripts/app.js], // sources files
      dest: 'public/javascripts/app.js' // output file
    }
  }
}

<强> Here is a reference

希望这有帮助。