ESLint结合gulp使用

ESLint结合gulp使用ESLint结合gulp使用一、安装二、使用步骤1.引入库2.读入数据总结一、安装示例:pandas是基于NumPy的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤1.引入库代码如下(示例):importnumpyasnpimportpandasaspdimportmatplotlib.pyplotaspltimportseabornassnsimportwarningswarnings.filterwarnings(‘ignore’)im

大家好,又见面了,我是你们的朋友全栈君。

ESLint结合gulp使用

一、安装

yarn add eslint gulp-eslint --dev

创建配置文件

yarn eslint --init

配置文件内容

module.exports = { 
   
  env: { 
   
    browser: true,
    es2021: true
  },
  extends: [
    'standard'
  ],
  parserOptions: { 
   
    ecmaVersion: 12
  },
  rules: { 
   
  }
}

二、使用

在gulp中,我们需要将eslint添加到编译js的构建任务当中,例如我这里的script任务

const script = () => { 
   
  return src('src/assets/scripts/*.js', { 
    base: 'src' })
    .pipe(plugins.eslint())
    .pipe(plugins.babel({ 
    presets: ['@babel/preset-env'] }))
    .pipe(dest('temp'))
    .pipe(bs.reload({ 
    stream: true }))
}

这个任务使用了babel转换源代码,我们需要做的就是将eslint集成进去,因为gulp是一种管道机制,所以集成eslint就应该在babel之前,因为这里使用了自动加载gulp插件的gulp-load-plugins,所以直接通过plugins.eslint()使用gulp-eslint。

// gulp-load-plugins使用方式
const loadPlugins = require('gulp-load-plugins')
const plugins = loadPlugins()

在打包入口文件中写一些问题代码,例:

const a = 1

执行script任务,yarn gulp script

在这里插入图片描述
提示es2021的错误,可能是版本问题导致,这里找到node_modules/eslint-config-standard/eslintrc.json和根目录下的.eslintrc.js,将其中env配置中的es2021都改成2020。

再次执行yarn gulp script

在这里插入图片描述
提示array-callback-return规则的值不能是这种格式,手动将值修改为error,接下来会有几个同类型的报错,都这样修改。

再次执行script任务。

在这里插入图片描述
任务运行正常,并没有检测出我们写的问题代码。这是因为,默认情况下,eslint只会去检测代码中的问题,而并不会根据检查结果做出任何反馈,所以正确的做法应该实在eslint处理完毕之后,我们去使用eslint的format方法在控制台中打印错误信息。之后再使用eslint的failAfterError方法,让eslint在检查到错误之后,可以直接终止任务管道。代码如下

const script = () => { 
   
  return src('src/assets/scripts/*.js', { 
    base: 'src' })
    .pipe(plugins.eslint())
    .pipe(plugins.eslint.format())
    .pipe(plugins.eslint.failAfterError())
    .pipe(plugins.babel({ 
    presets: ['@babel/preset-env'] }))
    .pipe(dest('temp'))
    .pipe(bs.reload({ 
    stream: true }))
}

再次执行script任务。提示错误Parsing error: Invalid ecmaVersion

这是因为我们前面修改了env中的es版本到es2020,而ecmaVersion还是12,将其修改为对应版本也就是11。

修改好后再次执行script,成功检测到代码问题并报出错误信息。

在这里插入图片描述

前面四个规则可能是因为版本问题找不到具体规则信息,我这里是到node_modules/eslint-config-standard/eslintrc.json文件中将这四个规则删除了。

再次执行任务。
在这里插入图片描述
主要的错误就是$和a的错误,另外的是代码风格的问题,例如空格之类的。可以通过fix自动处理代码风格问题,但这里不能使用 –fix的方法,需要将fix作为配置属性添加到plugins.eslint中

plugins.eslint({ 
   
  fix: true
 })

再次执行script任务
在这里插入图片描述
终于得到了我们想要的结果了,提示”$”未定义,”a”从未使用。

只需要将从未使用的a变量删除即可。

‘$’就是因为没有设置全局成员,解决办法就是在eslint配置中添加:

globals:{ 
   
	"$":"readonly"
}

再去执行script任务,就不会有任何错误了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/150488.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 全局获取Context的技巧

    全局获取Context的技巧

    2022年1月26日
    61
  • wsus补丁服务器如何给自己打补丁(windows补丁服务器)

    WSUS,全称Windowsserverupdateservices,是微软在其网络结构中提供的关于系统补丁更新的一个解决方案,完全免费,现在最新的版本是WSUS3.0SP2,在生产环境中部署WSUS的应用价值主要是提高网络资源的利用率,节省带宽,同时对于客户端计算机来说呢,更新效率也更高一些。在日常大家都习惯了用第三方工具给系统打补丁,局域网的PC数量少了便罢,如果多于50台,只是给系统以及微软产品打补丁这一项工作对于网络资源的占用就不可小觑,在Windowsserver2003以前…

    2022年4月18日
    427
  • Ping 命令详解[通俗易懂]

    简述:ICMP协议是“InternetControlMessagePtotocol”(因特网控制消息协议)的缩写。它是TCP/IP协议族的一个子协议,用于在IP主机、路由器之间传递控制消息。ping(PacketInternetGroper),因特网包探索器,用于测试网络连接量的程序。Ping发送一个ICMP;回声请求消息给目的地并报告是否收到所希望的ICMPecho(ICMP回声应答)。它是用来检查网络是否通畅或者网络连接速度的命令ping命令通常用来作为网络可用性的检查。ping命

    2022年4月10日
    37
  • Oracle技术之如何分析执行计划(一)

    Oracle技术之如何分析执行计划(一)

    2021年8月26日
    69
  • 积化和差和差化积公式推导_三角函数的极化和差

    积化和差和差化积公式推导_三角函数的极化和差和差化积公式:sinx+siny=2sinx+y2cosx−y2\sinx+\siny=2\sin\frac{x+y}{2}\cos\frac{x-y}{2}sinx−siny=2cosx+y2sinx−y2\sinx-\siny=2\cos\frac{x+y}{2}\sin\frac{x-y}{2}cosx−cosy=2cosx+y2cosx−y2\cos

    2025年7月14日
    3
  • pycharm 批量替换_pycharm如何替换字符串

    pycharm 批量替换_pycharm如何替换字符串Pycharm中快速替换某个变量、某个字符可以使用Ctrl+R的快捷键来快速替换可以点击Replaceall来替换所有的匹配到的字符;如果要替换成空的,那么下面的输入框什么也不要输就可以。…

    2022年8月25日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号