library-webpack-template:构建库library的webpack配置模板,专门用于打包库library、发布npm包

构建过程是复杂的前端项目必不可少的环节;但 业务代码 与 公用代码(如:封装的库、组件、工具等被复用的代码)的构建需求是不一样的;我发现很多 npm 贡献者都没意识到这一点,他们用传统的业务项目的 webpack 配置 去打包 公用代码,虽然能运行,但实际潜藏着许多问题;甚至都不经过编译构建,直接发布单纯的源码到 npm 上;由于本人经常封装一些东西,为了方便构建,就使用 webpack 开发并配置了一套专门用于构建公共代码的配置模板,当需要开发和构建公共代码时,直接克隆本项目即可;

注意:
为了方便下文描述,我把 业务代码 构建出的最终产品称为 应用程序;把 公用代码 构建的出产品称为 组件

1. 简介

library-webpack-template 称为 库构建模板,又称 公共代码构建模板 ,是专门用于构建 公共代码(如:封装的库、工具等) 的 webpack 配置模板,并对 webpack 配置做了二次封装,当需要开发和构建公共代码时,直接克隆本项目,并默认在的 src 目录下开发即可;如需定制化配置,只需更改项目根目录下的 project-config.js 配置文件即可,里面的配置字段 传明达意、简单易懂,且有详细的说明,摈弃了 webpack 配置的鱼龙混杂、掩人耳目;

如果您在使用的过程中遇到了问题,或者有好的建议和想法,您都可以通过以下方式联系我,期待与您的交流:

  • 给该仓库提交 issues
  • 给我 Pull requests

2. 特性

  • 极易使用,配置极其简单,配置项传明达意、简单易懂;
  • 可配置去除 公共代码 的依赖,默认去除了所有 node_modules 中的依赖;
  • 多个构建目标可同时构建,即:一次构建分别生成多个构建目标的构建包;
  • 可快速切换 开发模式 和 生产模式;
  • 自动分离 CSS 和 JavaScript 文件;
  • 支持 JavaScript、JSX、TypeScript、TSX、CSS、Sass、Less、Stylus、PostCss等等;
  • 支持 ESLint;
  • 支持 代码压缩;
  • 支持 交互式可视化树形构建分析报告,如下图:


    交互式可视化树形构建分析报告

3. 使用

git仓库 克隆或者下载本项目到本地,然后默认从 src/index 文件开始写代码即可;
通过 项目配置文件 project-config.js 可根据自己的需求进行定制;

4. 命令

library-webpack-template 项目支持如下构建命令:

  • npm start : 以开发模式构建项目;
  • npm run dev : 以开发模式构建项目;
  • npm run build : 以生产模式构建项目;

在 project-config.js 配置文件中,如果 没有配置 bundleAnalyzerReport 选项,则支持运行构建命令时 携带 --report 选项来开启 交互式可视化树形构建分析报告,如:npm start --reportnpm run dev --reportnpm run build --report,当构建完成时,会自动打开浏览器展示 交互式可视化树形构建分析报告,如下图:

交互式可视化树形构建分析报告

如果已经全局安装了 webpack 命令,也可以在项目根目录下执行如下命令:

  • webpack : 以开发模式构建项目;
  • webpack --env.production : 以生产模式构建项目;

5. 业务代码与公用代码的构建特点

5.1. 业务代码

  • 需要把所有代码及依赖(包括 公用代码)都构建在一块,作为一个整体来运行;
    因为:业务代码的最终呈现效果是应用程序,应用程序是一个完整的代码逻辑,任何依赖的缺失都会导致应用程序崩溃。

  • 运行环境单一;
    业务代码构建的应用程序要么是运行在浏览器的,要么是运行在 node 环境的;因为业务产品是最终供大众用户使用的,在开发业务产品(应用程序)之初,就已确定了业务产品的运行环境。

  • 构建目标单一;
    在构建业务代码时,往往构建目标是明确的,要么是构建浏览器应用,要么是构建 note 应用,或者其它,总之很少有同时构建多个目标的,比如同时构建浏览器和 note 环境的应用程序。

  • 有较强的包体积的限制;
    因为大部分应用程序是运行在浏览器的,较大的包体积会使应用程序加载时间过长,从而影响用户体验,所以,一般应用程序都要求包的体积尽可能的小;

  • 业务代码中通常包含 HTML、CSS、JavaScript 文件;

  • CSS 和 JavaScript 文件通常都需要在 HTML 文件中引入;
    浏览器端的应用程序都是以HTML文件为入口的,通过HTML加载 CSS 和 JavaScript 文件;

5.2. 公用代码

  • 需要去除依赖;
    公共代码的依赖往往也是其它公共代码或者业务代码的依赖,当业务代码中引入公共代码时,极有可能也引入了该公共代码的依赖,如果公共代码中不去除其依赖,则会导致业务代码中包含多份公共代码的依赖,造成代码冗余,增大业务代码的体积;

  • 运行环境多样;
    公众代码是被应用程序引用的,应用程序的运行环境可能是浏览器,也可能是 node ,或者其它 ,所以公共代码的运行环境是多样性的;

  • 构建目标多样;
    因为公共代码的运行环境是多样的,所以在需要对公共代码进行构建时,往往需要针对每个运行环境分别进行构建;

  • 对包体积的没有特别强列的要求;
    公共代码最终是要被业务代码引用的,面业务代码构建成应用程序时通常需要做包体积的压缩的,所以,对包体积的压缩通常会在业务代码构建成应用程序时进行,所以,当公共代码构建成组件时,大多数情况下也可不做体积压缩;

  • 通常不包含 HTML 文件;

  • CSS 和 JavaScript 文件通常分开;
    CSS 和 JavaScript 的组织方式往往是由业务代码组织结构和构建方案决定,所以,在公共代码中,CSS 和 JavaScript 通常是分开的,具体怎么组织,由业务代码决定;

6. 构建工具的选择

前端的构建工具有很多,像:Webpack、rollup、Browserify、Parcel、Grunt、Gulp等等;

目前,对于构建公共代码的工具较常用的是 rollup,对于构建业务代码,较常用的工具是 Webpack;不过,Webpack 也是可以用于构建公共代码的。

为了统一性,我选择了用 Webpack 构建 公共代码;所以,就有了本项目————库构建模板,又称 公共代码构建模板:针对Library的Webapck构建配置模板;

7. 公共代码构建的配置目标

公共代码构建的配置目标其就是实现上文所述的公共代码的构建特点,总结如下:

  • 去除依赖
  • 一次构建可分别生成适用于不同环境的码包;
    比如:分别生成用于 node 和 浏览器 环境的包,或者 不同模块化方案的包,如 AMD、CMD、 CommonJS、UMD等等;
  • 能在 开发 和 生产 两种模式快速切换;
    开发 模式下地在需要更多的调试信息,如 Source Map ;而生产模式下需求尽可能地压缩包的体积;在开发调试的过程中,需要在开发模式下构建包;当开发完毕,准备发布时,需要在生产模式下构建包;
  • 分离 CSS 和 JavaScript 文件;

8. 组织结构

模板项目中默认包含了一些文件和目录,它们的组织结构和作用如下所示:

library-webpack-template/   # 构建前端库的webpack打包配置模板项目根目录
   ├── .editorconfig           # 编辑器的通用配置文件
   ├── .eslintignore           # ESLint 的忽略配置文件
   ├── .eslintrc.js            # ESLint 的配置文件
   ├── .gitignore              # git 的忽略配置文件
   ├── .npmignore              # npm 上传包时的忽略配置文件
   ├── .postcssrc.js           # PostCSS 的配置文件
   ├── tsconfig.json           # 项目的级的 TypeScript 配置文件;同时也是 开发 和 生产 这两种模式公共的 TypeScript 配置文件;
   ├── webpack.config.js       # webpack 命令默认的配置文件;这个配置文件存在的目的是为了方便能在项目根目录下直接使用 `webpack` 命令 进行构建;它会根据执行 webpack 命令时是否携带含有设置 production 环境变量的选项来决定是加载 生产模式 还是 开发模式 的 构建配置;
   ├── package.json            # npm 的包管理配置文件
   ├── project-config.js       # 项目的配置文件;library-webpack-template 提供的 面向使用者的 对 整个项目的配置入口;
   ├── README.md               # 项目的说明文档
   ├── build/                  # 包含构建相关配置和工具的目录
   │   ├── tsconfig.dev.js          # 开发模式特有的 TypeScript 配置文件
   │   ├── tsconfig.prod.js         # 生产模式特有的 TypeScript 配置文件
   │   ├── tools.js                 # 包含与构建相关的工具函数的 JavaScript 代码文件
   │   ├── webpack.base.config.js   # 开发 和 生产两种模式公共的 webpack 配置文件;
   │   ├── webpack.dev.config.js    # 开发模式 特有的 webpack 配置文件;
   │   └── webpack.prod.config.js   # 生产模式 特有的 webpack 配置文件;
   ├── src/                    # 默认的包含项目源代码的目录
   │   └── index.js                 # 默认的构建入口文件;
   ├── dev/                    # 开发模式下默认的构建输出目录
   └── dist/                   # 生产模式下默认的构建输出目录

9. project-config.js

project-config.js 是整个项目的配置文件,是 library-webpack-template 提供的 面向使用者的 对 整个项目的配置入口;相对于 webpack 配置文件,该配置文件具有 传明达意、简单易懂 之特点;

该配置文件中的所有配置项都保存在 projectConfig 变量中,可配置的属性如下:

  • entry:webpack 的入口配置 entry; 指示 webpack 应该使用哪个模块,来作为构建其内部 依赖图的开始
    • 类型: string | [string] | object { <key>: string | [string] } | (function: () => string | [string] | object { <key>: string | [string] })
    • 详细信息: https://webpack.docschina.org/configuration/entry-context/#entry
    • 注意: 如果修改了 entry 的值,你可能需要考虑下是否要同步更改下 package.json 中的 module 属性;
  • haveExports : 用于指示库是否有对外暴露的内容,即:是否有导出的项目;
    • 类型: boolean
      • 当值为 true 时,选择 refName 才会起作用;
      • 当值为 false 时,会忽略 refName 选项;
    • 默认值: true
  • refName :库的引用名字;与 webpack 的 output.library 选项相同;某些模块化方案(由 module 选项指定)(比如:varassignthiswindowselfglobal 等等)会在引入库时会在环境中注入特定名字的环境变量,以便引入者能够通过该环境变量来访问库对外暴露的接口,该环境变量的名字就是由该选项 refName 指定;
    • 类型: string | {root: string, commonjs: string, amd: string} | null | undefined
      • 当值为 undefined | null 时,会使用默认值;
      • 从 webpack 3.1.0 开始;对象类型 {root: string, commonjs: string, amd: string} 的值可用于 项目配置文件 project-config.js 中的 module 选项(即:webpack 中 output.libraryTarget 选项)的值为 'umd' 时;
    • 默认值: getBaseNameOfHumpFormat(package.name),即:将 package.json 文件中的 name 字段的值去除命名空间后并转成驼峰格式的字符串;getBaseNameOfHumpFormat() 是库 package-tls 导出的函数,作用是把包名去除命名空间后 并 从 中划线 或 下划线 分隔的方式 转成 驼峰式
    • 详细信息: https://webpack.docschina.org/configuration/output/#output-library
    • 注意:
      • 只有当选项 haveExports 的值为 haveExports 时,此选项 refName 才会有效;
      • 如果更改了 refName 的值,你可能需要考虑下是否要同步更改下 package.json 中的 name 属性;
  • module :配置库的构建目标(即:被构建(打包)后的包)采用的模块化方案,也可以理解为:对外暴露 库 的方式,即:库将会以哪种方式被使用;与 webpack 的 output.libraryTarget 选项相同;
  • removeDep :构建库时,是否要移除库依赖的模块;库依赖的模块由 dependencies 选项指定;
    • 类型: boolean
      • 当值为 true 时,会移除 dependencies 选项指定的依赖;
      • 当值为 false 时,不会移除任何依赖;
    • 默认值: true
  • runEnv:指定库被使用时的运行环境;与 webpack 的 target 选项相同;因为 服务器 和 浏览器 代码都可以用 JavaScript 编写,所以 webpack 提供了多种部署 target(目标)
  • outputFile :设置构建后的输出文件的名字;与 webpack 的 output.filename 相同;此选项决定了每个输出 bundle 的名称。这些 bundle 将写入到 outputDir 选项指定的目录下
    • 类型: string | function
    • 默认值:
      • 当未显式指定 module 时,outputFile 的默认值为 <package.json/name>.js
      • 当显式指定 module 时,outputFile 的默认值为 <package.json/name>.<project-config.js/module>.js
      • 注意:
        • 其中 <package.json/name> 的值为 package.json 文件中 name 的值,<project-config.js/module> 为 project-config.js 文件中 module 的值;
        • 你可以在 outputFile 中使用 webpack 提供的模板字符串,如 [name]
        • 其中 <package.json/name><project-config.js/module> 并不是 webpack 给 output.filename 字段提供的有效的模板字符串;
    • 详细信息: https://webpack.docschina.org/configuration/output/#output-filename
  • htmlTemplate :html模板文件;html-webpack-plugin
    的 template 选项;

  • htmlOut :要将 html模板文件 htmlTemplate 写入的文件。您也可以在此处指定子目录;该选项会结合 outputDir 选项 生成 html-webpack-plugin 的 filename 选项 的值;

  • staticDirectory:静态资源的原目录;该目录下的内容将会被拷贝到构建输出目录中;

    • 类型: string
  • staticOutDirectory:静态资源输出目录;设置将静态资源从原目录拷贝到构建输出目录中时,静态资源目录的名字;

    • 类型: string
  • parseNodeModules :是否要对 node_modules 中的模块进行编译;

    • 类型: boolean
    • 默认值: true
    • 说明: 如果设置为 false,则 node_modules 中的依赖会被直接包含,不会经过 webpack 相应 loader 的处理;
  • tsconfig:TypeScript相关的配置选项对象;可配置 TypeScript 的所有 编译选项,即:tsconfig.compilerOptions 中的选项;
    • 类型: Object
    • 详细信息: https://www.tslang.cn/docs/handbook/tsconfig-json.html
    • 除 TypeScript 的所有 编译选项外,还可配置如下属性:
      • loader:配置解析 TypeScript 的 loader
        • 类型: "ts-loader" | "babel-loader"
        • 默认值: "ts-loader"
        • 注意: 目前发现:
          • "ts-loader" 会忽略TypeScript中默认的导出项 export default(TypeScript 3 之后 默认禁用了 export default),这时配置项 libraryExport: "default" 可能会导致导出的值是 undefined
          • tsconfig 的相关编译选项: allowSyntheticDefaultImports:允许从没有设置默认导出的模块中默认导入。这并不影响代码的输出,仅为了类型检查。
          • "babel-loader" 暂未支持生成 声明文件 .d.ts,并且会忽略 项目中关于 TypeScript 的自定配置,如:tsconfig.json、tsconfig.dev.js、tsconfig.prod.js 中的配置
  • bundleAnalyzerReport :是否开启构建分析报告;
    • 类型: boolean
    • 默认值: process.env.npm_config_report; 即:根据执行命令时是否带有 --report 选项来决定是否启用 构建分析报告;
  • bundleAnalyzerOptions :构建分析报告的配置选项; webpack-bundle-analyzer 的 webpack 插件选项对象;
    • 类型: Object
    • 默认值: bundleAnalyzerOptions.analyzerPort 的默认值是 "auto"
    • 详细信息: https://github.com/webpack-contrib/webpack-bundle-analyzer
    • 注意: 如果你配置了多个构建目标 multipleTargets ,并且以 server 模式(这是默认的模式)开启了 构建分析报告,则建义采用以下任意一种方案来对 bundleAnalyzerOptions.analyzerPort 进行设置,这样可以防止针对每个构建目标启动一个 构建分析报告 时,因服务端口被占用而启动失败:
      • 方案1(这是默认的设置):将 所有构建目标公共的 projectConfig.bundleAnalyzerOptions.analyzerPort 设置为 auto ;
      • 方案2:分别给每一个 构建目标的 bundleAnalyzerOptions.analyzerPort 设置一个不同的值;
  • dev:开发模式的配置选项对象
    • 类型: Object
    • 可配置的属性如下:
      • outputDir :输出目录,一个绝对路径;与 webpack 的 output.path 选项相同;
        • 类型: string
        • 详细信息: https://webpack.docschina.org/configuration/output/#output-path
        • 注意:
          • 如果你使用的是 ESLint,建议你将该处配置的输出目录 增加到 ESLint 的忽略配置文件中一般在项目根目录下的 .eslintignore 文件中);
          • 如果你使用的是 TypeScript,建议你将该处配置的输出目录 增加到 项目根目录下的 TypeScript 配置选项(一般在配置文件 tsconfig.json 中)的 排除字段 "exclude" 下,如:
          "exclude":[
            "dist",
            "dev"
          ]
          
    * sourceMap :source map 的开关;用于控制是否生成 source map;
        - **类型:** `boolean`
        - **默认值:** `false`
        - **详细信息:** <https://webpack.docschina.org/configuration/devtool/>

    * devtool :与 webpack 的 `devtool` 选项相同;用于控制如何生成 source map;
        - **类型:** `string`
        - **默认值:** `false`
        - **详细信息:** <https://webpack.docschina.org/configuration/devtool/>

    * cssSourceMap :CSS source map 的开关;用于控制是否生成 CSS 的 source map;
        - **类型:** `boolean`
        - **默认值:** `false`
  • build:生产模式的配置选项对象
    • 类型: Object
    • 可配置的属性如下:
      • outputDir :输出目录,一个绝对路径;与 webpack 的 output.path 选项相同;
        • 类型: string
        • 详细信息: https://webpack.docschina.org/configuration/output/#output-path
        • 注意:
          • 如果你使用的是 ESLint,建议你将该处配置的输出目录 增加到 ESLint 的忽略配置文件中一般在项目根目录下的 .eslintignore 文件中);
          • 如果你使用的是 TypeScript,建议你将该处配置的输出目录 增加到 项目根目录下的 TypeScript 配置选项(一般在配置文件 tsconfig.json 中)的 排除字段 "exclude" 下,如:
          "exclude":[
            "dist",
            "dev"
          ]
          
    * sourceMap :source map 的开关;用于控制是否生成 source map;
        - **类型:** `boolean`
        - **默认值:** `false`
        - **详细信息:** <https://webpack.docschina.org/configuration/devtool/>

    * devtool :与 webpack 的 `devtool` 选项相同;用于控制如何生成 source map;
        - **类型:** string
        - **默认值:** `false`
        - **详细信息:** <https://webpack.docschina.org/configuration/devtool/>
  • multipleTargets :配置多个构建目标;当进行构建时,会对 multipleTargets 数组中的每个项目配置分别构建并生成对应的包;
    • 类型: undefined | null | Array<ProjecConfig | undefined | null>
    • 默认值: undefined
    • 说明:
      • 此选项是可选的,如果没有配置,或者配置的是一个长度为 0 的空数组,则会使用 默认的项目配置 projectConfig (默认的项目配置指的是 project-config.js 文件中的 projectConfig 变量保存的配置) ;
      • 如果配置的是一个数组,数组中的每个元素都会被当作一个 项目配置 并覆盖 或 合并 默认的项目配置 projectConfig 中对应的具体选项;当进行构建时,会对数组中的每个项目配置分别构建并生成对应的包;
      • 数组中的 undefined 和 null 会被当作是 默认的项目配置 projectConfig;
      • 如果配置了多个构建目标,则应注意多个构建目标的输出因命名、路径或服务端口重复导致导出相互被覆盖 或者 服务启动失败 的问题;这类问题的解决方案就是:分别为每个构建目标设置相应选项设置一个不同的值;如:
        • 分别为每个构建目标的 outputFile 设置一个不同的值,如 {runEnv: "node", outputFile: '[name].node.js' } ,这样可以防止多个构建目标的构建包相互覆盖 ;outputFile 的默认值已包含了配置变量 module,所以,如果分别为每个构建目标的 module 选项显式地指定了不同的值,则也不会出现构建输出文件相互覆盖的问题;
        • 如果以 server 模式(这是默认的模式)开启了 构建分析报告,则应该采用以下任意一种方案来对 bundleAnalyzerOptions.analyzerPort 进行设置:
          • 方案1(这是默认的设置):将 所有构建目标公共的 projectConfig.bundleAnalyzerOptions.analyzerPort 设置为 auto ;
          • 方案2:分别给每一个 构建目标的 bundleAnalyzerOptions.analyzerPort 设置一个不同的值;
  • overrideKeys :指定 在将 多构建目标 multipleTargets 中的选项 与 默认的项目配置 projectConfig 进行合并时 采用覆盖方式进行合并的 key;
    • 类型: Array<string> | undefined | null
    • 默认值: undefined
    • 说明:
      • 此选项只用于 多构建目标 multipleTargets 与 默认的项目配置 projectConfig 的合并;
      • 些选择只能配置在 projectConfig 的顶层(即:projectConfig.overrideKeys),多构建目标 multipleTargets 中的 overrideKeys 选项会被忽略;

10. npm包管理配置文件

library-webpack-template 中与 npm 包管理相关的配置文件有 2 个:

  • .npmignore : npm 上传包时的忽略配置文件;默认忽略了 与构建配置文件的所有文件和目录,如:build/ 等等;也忽略了开发环境默认的输出目录 dev/,还有编辑器相关的文件和目录,如:.idea.vscode
  • package.json : npm 的包管理配置文件;同时也是 通过 npm 上传、发布 包 的 配置模板文件;

注意: package.json 文件中的如下字段:

  • module : 该字段是用来指定以标准模块暴露的出口文件;
  • types | typings : 该字段是用来指定库的类型声明文件;如果库没有类型声明文件,则去除该字段;
  • "sideEffects" : boolean | Array<string> ,可以为布尔,表示整个包是否有副作用;也可以是一些有副作用文件的的路径字符串,路径支持 相对路径、绝对路径和 glob 模式; 副作用标记;表明项目中的哪些文件不是 纯的 ES2015 模块,由此不能安全地删除文件中未使用的部分,"side effect(副作用)" 的定义是,在导入时会执行特殊行为的代码,而不是仅仅暴露一个 export 或多个 export。举例说明,例如 polyfill,它影响全局作用域,并且通常不提供 export;详细内容请见 https://webpack.docschina.org/guides/tree-shaking/#将文件标记为-side-effect-free-无副作用-

关于package.json文件的详细配置信息请参考https://docs.npmjs.com/files/package.json

11. Webpack配置文件

library-webpack-template 中包含了4个 webpack 配置文件:

  • build/webpack.base.config.js : 这个文件包含提 开发 和 生产这两个模式 公共的 webpack 配置;
  • build/webpack.dev.config.js : 这个文件仅包含提 开发模式 特有的 webpack 配置;
  • build/webpack.prod.config.js : 这个文件仅包含提 生产模式 特有的 webpack 配置;
  • webpack.config.js : 这个配置文件存在的目的是为了方便能在项目根目录下直接使用 webpack 命令 进行构建;它会根据执行 webpack 命令时是否携带含有设置 production 环境变量的选项来决定是加载 生产模式 还是 开发模式 的 构建配置;

所以,项目真正的 webpack 构建配置是放在 build/ 目录下的 3个 webpack 配置文件中的:build/webpack.base.config.jsbuild/webpack.dev.config.jsbuild/webpack.prod.config.js

关于 webpack 的详细配置信息请参考https://webpack.docschina.org/configuration/

12. TypeScript配置文件

library-webpack-template 中包含了3个 TypeScript 配置文件:

  • tsconfig.json : 这个文件是项目的级的 TypeScript 配置文件;同时也是 开发 和 生产 这两种模式公共的 TypeScript 配置文件; 并且 该文件的存在,也是为了方便能在项目根目录下直接使用 TypeScript 的编译命令 tsc
  • build/tsconfig.dev.js : 这个文件仅包含提 开发模式 特有的 TypeScript 配置;并且会覆盖 公共配置 tsconfig.json 中相应的具体选项;
  • build/tsconfig.prod.js : 这个文件仅包含提 生产模式 特有的 TypeScript 配置;并且会覆盖 公共配置 tsconfig.json 中相应的具体选项;

其中 build/ 目录下的 tsconfig 配置文件是供 ts-loader 使用的,并且只会用到 tsconfig 中的编译选项 compilerOptions,其它选项会被忽略;

关于 tsconfig 的详细配置信息请参考 https://www.typescriptlang.org/docs/handbook/tsconfig-json.html

13. 代码检查

本配置模版默认使用 ESLint 作为 JavaScript 和 TypeScript 的代码检查工具;至于为什么 TypeScript 不用 TSLint 作为代码检查工具的原因请参看 https://github.com/typescript-eslint/typescript-eslint

ESLint 相关的配置文件如下:

  • .eslintrc.js : ESLint 的配置文件,可配置 解析器、解析选项、规则 等等;默认是 TypeScript 代码检查配置;
  • .eslintignore : ESLint 的忽略文件的配置文件;

关于 ESLint 的详细配置信息请参考 http://eslint.cn/docs/user-guide/configuring


有您的支持,我会在开源的道路上,越走越远 赞赏码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 中文翻译 ng help ng build 构建您的应用程序并将其放入输出路径(dist /默认情况下)。 别名:...
    4ea0af17fd67阅读 2,030评论 0 0
  • webpack使用学习 本分享学习借鉴webpack中文官网,官网链接(中文文档):https://www.web...
    腿毛怪丶叔叔阅读 880评论 0 5
  • 前端将大型项目分成一个个单独的模块,一般封装好的每个模块都会实现一个目的明确的完成的功能。如何处理这些模块以及模块...
    pixels阅读 3,425评论 1 14
  • 原文首发于:Webpack 3,从入门到放弃 Update (2017.8.27) : 关于 output.pub...
    昵称都被用完了衰阅读 1,896评论 4 19
  • 这年头,你不背上几句广告词,都不好意思说你有文化、有内涵。下面我们就来揭晓本届魔性广告奥斯卡奖各奖项获奖名单。 N...
    KEVIN0603阅读 3,418评论 0 1