Skip to content

Latest commit

 

History

History
 
 

6-eslint

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

6 - ESLint

Мы собираемся контролировать качество кода (англ. lint - прим. переводчика) чтобы перехватывать потенциальные проблемы. ESLint - предпочтительный анализатор кода (англ. linter - прим. переводчика) для ES6. Вместо того чтобы самим определять правила для нашего кода, мы воспользуемся конфигурацией, созданной Airbnb. В этой конфигурации используется несколько плагинов, поэтому мы их тоже установим.

  • Запустите yarn add --dev eslint eslint-config-airbnb eslint-plugin-import eslint-plugin-jsx-a11y eslint-plugin-react

Как вы видите, вы можете установить несколько пакетов одной командой. Как обычно, они все добавятся в ваш package.json.

В package.json, добавьте свойство eslintConfig с таким содержанием:

"eslintConfig": {
  "extends": "airbnb",
  "plugins": [
    "import"
  ]
},

В разделе plugins мы сообщаем ESLint что используем синтакисис ES6 import.

Замечание: Вместо свойства eslintConfig в package.json можно использовать файл .eslintrc.js в корне вашего проекта. Так же как и с конфигурацией Babel, мы стараемся избегать загромождения корневой директории большим количеством файлов, но если у вас сложная конфигурация ESLint, рассмотрите такую альтернативу.

Мы создадим задачу для Gulp, которая запускает ESLint для нас. Поэтому установим также плагин ESLint для Gulp:

  • запустите yarn add --dev gulp-eslint

Добавьте следующую задачу в ваш gulpfile.babel.js:

import eslint from 'gulp-eslint';

const paths = {
  allSrcJs: 'src/**/*.js',
  gulpFile: 'gulpfile.babel.js',
  libDir: 'lib',
};

// [...]

gulp.task('lint', () => {
  return gulp.src([
    paths.allSrcJs,
    paths.gulpFile,
  ])
    .pipe(eslint())
    .pipe(eslint.format())
    .pipe(eslint.failAfterError());
});

Здесь мы говорм Gulp, что для этой задачи мы хотим подключить gulpfile.babel.js и JS файлы, расположенные в src`.

Откорректируйте задачу build так, чтобы lint предваряла ее запуск:

gulp.task('build', ['lint', 'clean'], () => {
  // ...
});
  • Запустите yarn start. Вы должны увидеть набор ошибок кода (англ. linting errors - прим. переводчика) в этом Gulp-файле и предупреждений об использовании console.log() в index.js.

Один из видов ошибок будет: 'gulp' should be listed in the project's dependencies, not devDependencies (import/no-extraneous-dependencies) ('gulp' должен подключаться в разделе dependencies, а не devDependencies). Вообще-то это неверная ошибка. ESLint не может знать какие JS файлы будут входить только в скомпилированное приложение (англ. build - прим. переводчика ) а какие нет. Поэтому мы немного поможем ESLint используя комментарии в коде. В gulpfile.babel.js, в самом верху, добавьте:

javascript /* eslint-disable import/no-extraneous-dependencies */


Таким образом, ESLint не будет применять правило `import/no-extraneous-dependencies` в этом файле.

Теперь у нас осталась проблема с `Unexpected block statement surrounding arrow body (arrow-body-style)` (Неожиданное определение блока, окружающего тело стрелочной функции). Это важно. ESLint сообщает нам, что существует лучший способ написать следующий код:

```javascript
() => {
  return 1;
}

Это нужно переписать так:

() => 1

Потому что, когда в ES6 функция содержит только возвращаемое выражение, вы можете опустить фигурные скобки, оператор return и точку с запятой.

Так что давайте обновим Gulp-файл соответственно:

gulp.task('lint', () =>
  gulp.src([
    paths.allSrcJs,
    paths.gulpFile,
  ])
    .pipe(eslint())
    .pipe(eslint.format())
    .pipe(eslint.failAfterError())
);

gulp.task('clean', () => del(paths.libDir));

gulp.task('build', ['lint', 'clean'], () =>
  gulp.src(paths.allSrcJs)
    .pipe(babel())
    .pipe(gulp.dest(paths.libDir))
);

Последняя оставшаяся проблема связана с console.log(). Давайте скажем, что мы хотим в этом примере, чтобы использование console.log() в index.js было правомерным, а не вызывало предупреждение. Как вы, возможно, догадались мы поместим /* eslint-disable no-console */ в начале нашего index.js файла.

  • Запустите yarn start - теперь все снова без ошибок.

Замечание: В этой части мы работали с ESLint через консоль. Это хорошо для поиска ошибок во время компиляции / перед публикацией, но вы, так же, возможно, захотите интегрировать его в вашу IDE. НЕ ИСПОЛЬЗУЙТЕ встроенный в вашу среду анализатор кода для ES6. Сконфигурируйте ее так, чтобы для этого использовались модули, расположенные в директории node_modules. В этом случае будут использоваться все настройки вашего проекта, правила Airbnb и так далее. Иначе, вы получите лишь усредненный ES6 анализатор.

Следующий раздел: 7 - Клиентское приложение на основе Webpack

Назад в предыдущий раздел или Содержание.