eslint uniapp-eslint及vue-eslint配置


ESLint 是一个开源的 JavaScript 代码检查工具。可以让程序员在编码的过程中发现问题而不是在执行的过程中。

1. eslint的特性

请直接参考文档

附:其他文件的格式设置

一般eslint只作用在项目相关的文件内,而像package.json这类文件我们可以使用VScode中的EditorConfig for VS Code插件来配置

1// 为了与eslint统一性,一般会这样配置
2[*.{js,vue,json,html,css,less}]
3indent_style = tab
4indent_size = 4
5trim_trailing_whitespace = true
6insert_final_newline = true

2. 开始使用

  • 安装eslint

1$ npm install eslint --save-dev

  • 安装好后需初始化并设置配置文件

1// 在package.json中添加
2"scripts": {
3    "eslint": "eslint --init"
4}
5
6// 在项目下执行,并选择设置,如下图
7$ npm run eslint


这样我们就在项目中添加了.eslintrc.js

1module.exports = {
2    'env': {
3        'browser': true,
4        'es6': true,
5        'node': true
6    },
7    'extends': 'eslint:recommended',
8    'globals': {
9        'Atomics': 'readonly',
10        'SharedArrayBuffer': 'readonly'
11    },
12    'parserOptions': {
13        'ecmaVersion': 2018,
14        'sourceType': 'module'
15    },
16    'rules': {
17        'indent': [
18            'error',
19            'tab'
20        ],
21        'linebreak-style': [
22            'error',
23            'windows'
24        ],
25        'quotes': [
26            'error',
27            'single'
28        ],
29        'semi': [
30            'error',
31            'always'
32        ]
33    }
34};

具体的配置请参照文档

  • 最后我们就可以使用了

1// 在package.json中添加
2"scripts": {
3    "lint": "eslint [项目文件路径]"
4}
5
6// 执行eslint
7$ npm run lint

另外:我们都知道eslint是js的检查工具,但是我们的项目中可能有.html,.vue,.ts等等其他内容需要检查,这时候我们就需要安装配置一些插件来完成

  • ESLint 支持使用第三方插件。在使用插件之前,你必须使用 npm 安装它。

例:eslint-plugin-vue:

1// 安装
2$ npm i eslint-plugin-vue -D
3
4// 配置
5"extends": [
6    "eslint:recommended",
7    "plugin:vue/recommended"
8],
9// 每个配置继承它前面的配置
10plugins: [
11    'vue'
12]
13// plugins 属性值 可以省略包名的前缀 eslint-plugin-。

3. @vue/cli中的eslint

@vue/cli安装项目是自动安装了eslint相关的一系列插件,其中@vue/cli-plugin-eslint提供了不同模式的选择:

1? Pick an ESLint config:
2> Error prevention only
3  Airbnb
4  Standard
5  Prettier

区别如下图:


一般可以选择Error prevention only,那么eslint直接使用eslint:recommended,即eslint中一系列核心规则,可查文档

  • 同时我们查看package.json中的字段:

1"devDependencies": {
2    "@vue/cli-plugin-eslint": "^4.1.0",
3    "babel-eslint": "^10.0.3",
4    "eslint": "^5.16.0",
5    "eslint-plugin-vue": "^5.0.0",
6}

@vue/cli-plugin-eslint是一款vue-cli的eslint插件,就是它为我们初始化了一些配置:

1base: {
2    eslint: '^6.7.2',
3    'eslint-plugin-vue': '^6.1.2'
4},
5airbnb: {
6    '@vue/eslint-config-airbnb': '^5.0.2',
7    'eslint-plugin-import': '^2.20.1'
8},
9prettier: {
10    '@vue/eslint-config-prettier': '^6.0.0',
11    'eslint-plugin-prettier': '^3.1.1',
12    prettier: '^1.19.1'
13},
14standard: {
15    '@vue/eslint-config-standard': '^5.1.0',
16    'eslint-plugin-import': '^2.20.1',
17    'eslint-plugin-node': '^11.0.0',
18    'eslint-plugin-promise': '^4.2.1',
19    'eslint-plugin-standard': '^4.0.0'
20}

可以看到不同的模式提供不同的插件,而其中base是默认一定会安装的项目

  • base提供的默认配置如下:

1{
2    parser: require.resolve('vue-eslint-parser'),
3    parserOptions: {
4        ecmaVersion: 2018,
5        sourceType: 'module',
6        ecmaFeatures: {
7            jsx: true
8        }
9    },
10    env: {
11        browser: true,
12        es6: true
13    },
14    plugins: [
15        'vue'
16    ],
17    rules: {
18        'vue/comment-directive': 'error',
19        'vue/jsx-uses-vars': 'error'
20    }
21}

我们知道每个配置继承它前面的配置,所以@vue/cli项目中这些配置可以略去不写。

  • 关于babel-eslint的配置,正常我们会写

1{
2    parser: "babel-eslint",
3    parserOptions: {
4        //...
5    }
6}

但是eslint-plugin-vue中的很多规则都需要vue-eslint-parser检查<template>, vue-eslint-parser和babel-parser二者有冲突。所以我们使用已下写法

1parserOptions: {
2    parser: 'babel-eslint',
3    //...
4},

如果我们选择Standard模式

  • 查看package.json中的字段:

1"devDependencies": {
2    "@vue/cli-plugin-eslint": "^4.1.0",
3    "@vue/eslint-config-standard": "^4.0.0",
4    "babel-eslint": "^10.0.3",
5    "eslint": "^5.16.0",
6    "eslint-plugin-vue": "^5.0.0",
7}

根据上述的模式配置会额外安装响应的插件@vue/eslint-config-standard,这时配置是这样的:

1'extends': [
2    'plugin:vue/essential',
3    '@vue/standard'
4]

@vue/eslint-config-standard插件的配置替代了eslint的核心规则,其规则配置在./node_modules/eslint-config-standard/eslintrc.json中查看

注:当你选择其他模式的时候,即选择了模式中配置好的规则,这时一般不赞成再去修改规则,否则就用默认模式好了

4. prettier

prettier是eslint的一款插件,格式化代码工具。

  • 使用prettier却不能随意的配置我们自己想要的风格。大多数人会觉得Prettier 风格非常差,但是如果开发团队人数众多时,prettier不但节省了手动去调整代码风格的时间,而且减少了成员之间无畏的争执。

  • 如果在@vue/cli项目中,之间选择prettier模式就行了

  • 如果需要自己安装prettier,过程如下:

安装

1npm i prettier eslint-config-prettier eslint-plugin-prettier --D

配置

1{
2    "extends": [
3        ...,
4        "prettier",
5        "plugin:prettier/recommended"
6    ],
7    "plugins": ["prettier"],
8    "rules": {
9        "prettier/prettier": "error"
10    }
11}

少数配置可以自行设置.prettierrc.js文件

5. uniapp中配置eslint

你当然可以重头开始安装eslint,然后初始化,最后安装你所需要的插件,比如eslint-plugin-vue,但是uniapp小程序项目的构建也使用了@vue/cli工具,所以我们可以直接拿来用

安装

1$ vue add @vue/eslint
2
3// 同样的可以选择@vue/cli-plugin-eslint提供的四个模式
4
5? Pick an ESLint config: Basic
6? Pick additional lint features: Lint on save

在配置上,大部分是通用的,但是我们应该为小程序配置全局变量

1"globals": {
2    "swan": "readonly",
3    "wx": "readonly",
4    "uni": "readonly"
5}

执行结果如下:



长按二维码关注公众号


eslint配置介绍-如何在uniapp中配置eslint的更多相关文章

  1. 如何在sharepoint2010中配置Google Anlytics 分析服务

      简介 Google Analytics(分析)不仅可以帮助您衡量销售与转化情况,而且能为您提供新鲜的深入信息,帮助您了解访问者如何使用您的网站,他们如何到达您的网站,以及您可以如何吸引他们不断回访 ...

  2. 如何在IAR中配置CRC参数(转)

    源:如何在IAR中配置CRC参数 前言 STM32全系列产品都具有CRC外设,对CRC的计算提供硬件支持,为应用程序节省了代码空间.CRC校验值可以用于数据传输中的数据正确性的验证,也可用于数据存储时 ...

  3. 如何在Eclipse中配置Tomcat(免安装版)

    如何在Eclipse中配置Tomcat(免安装版) 2013-10-09 23:19wgelgrsh | 分类:JAVA相关 | 浏览642次 分享到:   2013-10-10 17:10提问者采纳 ...

  4. 如何在appconfig中配置服务的ip

    开发了一个WindowsService消息服务器,刚开始一直都是在代码中把IP地址写死,所以每次只要是更换了新的IP地址后,都需要重新编译项目.所以考虑把ip配置到config文件中, 这样做的好处是 ...

  5. Nodejs的安装配置及如何在sublimetext2中运行js

    Nodejs的安装配置及如何在sublimetext2中运行js听语音 | 浏览:4554 | 更新:2015-06-16 11:29 Nodejs的安装配置及如何在sublimetext2中运行js ...

  6. 【神经网络与深度学习】如何在Caffe中配置每一个层的结构

    如何在Caffe中配置每一个层的结构 最近刚在电脑上装好Caffe,由于神经网络中有不同的层结构,不同类型的层又有不同的参数,所有就根据Caffe官网的说明文档做了一个简单的总结. 1. Vision ...

  7. 如何在Mac中配置Python虚拟环境,踩了好多坑

    如何在Mac中配置Python虚拟环境 1.安装virtualenv pip3 install virtualenv 2.安装virtualenvwrapper pip3 install virtua ...

  8. 如何在webstrom中配置eslint和less

    webstrom 帮助文档(英文版) 1.在webstrom中使用ESLint规范代码格式: JSHint 可以帮助检测你的 JavaScript 代码中的错误和潜在的问题,而 eslint是一个 J ...

  9. 如何在idea中配置Tomcat服务器

    .IDEA 中动态 web 工程的操作         a)IDEA 中如何创建动态 web 工程        1.创建一个新模块: 2.选择你要创建什么类型的模块 3.输入你的模块名,点击[Fin ...

随机推荐

  1. CSI 工作原理与JuiceFS CSI Driver 的架构设计详解

    容器存储接口(Container Storage Interface)简称 CSI,CSI 建立了行业标准接口的规范,借助 CSI 容器编排系统(CO)可以将任意存储系统暴露给自己的容器工作负载.Ju ...

  2. 谈谈 Kubernetes Operator

    简介 你可能听过Kubernetes中Operator的概念,Operator可以帮助我们扩展Kubernetes功能,包括管理任何有状态应用程序.我们看到了它被用于有状态基础设施应用程序的许多可能性 ...

  3. 选择Key-Value Store

    [IT168 专稿]在之前的文章中,给大家介绍了<Redis快速入门:Key-Value存储系统简介>,今天进一步给大家介绍为什么选择Key-Value Store.Key-Value S ...

  4. Java线程通信

    Java线程通信 螣蛇乘雾,终为土灰. 多个线程协同工作完成某个任务时就会涉及到线程间通信问题.如何使各个线程之间同时执行,顺序执行.交叉执行等. 一.线程同时执行 创建两个线程a和b,两个线程内调用 ...

  5. java三种适配器模式详解与代码实现

    zhaoyu   取消关注   2 人赞同了该文章 1. 适配器模式定义: 适配器模式是一种结构型设计模式,通过一个适配器类把具有不同方法功能的两个类A和B组合起来,使得这个适配器类同时具有两个类的不 ...

  6. IO、NIO和AIO的区别

      IO和NIO的区别:其本质就是阻塞和非阻塞的区别. 阻塞概念:应用程序在获取网络数据的时候,如果网络传输数据很慢,那么久一直等着,知道传输完毕为止.非阻塞概念:应用程序直接可以获取已经准备就绪好的 ...

  7. Pipeline 有什么好处,为什么要用 pipeline?

    答:可以将多次 IO 往返的时间缩减为一次,前提是 pipeline 执行的指令之间没有 因果相关性.使用 redis-benchmark 进行压测的时候可以发现影响 redis 的 QPS 峰值的一 ...

  8. jQuery--事件绑定|委派|切换

    一.事件的绑定 1.事件的绑定介绍 事件绑定: bind(type,fn) 给当前对象绑定一个事件.例如:A.bind("click",fn);类似A.click(fn) unbi ...

  9. (转载)一篇文章带你分清楚JWT,JWS与JWE

    是JWS(JSON Web Signature),也往往导致了人们对于JWT的误解,但是JWT并不等于JWS,JWS只是JWT的一种实现,除了JWS外,JWE(JSON Web Encryption) ...

  10. django 三件套(render,redirect,HttpResponse)

    Django基础必备三件套**: HttpResponse 内部传入一个字符串参数,返回给浏览器. from django.shortcuts import HttpResponse def inde ...