神秘的ESLint解析错误

时间:2015-12-07 01:35:54

标签: javascript reactjs react-jsx eslint

在以下代码的第4行,ESLint给出了一个解析错误:

  

意外的令牌=

我想知道为什么会这样?代码运行正常。我做错了什么?

import { Component, PropTypes } from 'react';

export default class MainApp extends Component {
  static propTypes = {
    children: PropTypes.any.isRequired
  }

  componentWillMount() {
    require('./styles/main.styl');
  }

  render() {
    return (
      <div>
        {this.props.children}
      </div>
    );
  }
}

2 个答案:

答案 0 :(得分:19)

我能够解决这个问题:

1)安装babel-eslint

$ npm i --save-dev babel-eslint

OR

$ yarn add babel-eslint --dev

2)配置ESLint以使用babel-eslint作为解析器

只需将"parser": "babel-eslint",添加到.eslintrc文件中即可。

示例.eslintrc使用babel-eslint和airbnb的配置以及一些自定义规则:

{
  "parser": "babel-eslint",
  "extends": "airbnb",
  "rules": {
    "arrow-body-style": "off",
    "no-console": "off",
    "no-continue": "off"
  }
}

答案 1 :(得分:7)

你不能在类中拥有属性,只能有方法。

参考:http://www.2ality.com/2015/02/es6-classes-final.html#inside_the_body_of_a_class_definition