摘要:配置規(guī)則在文件中添加代碼如下和是中規(guī)則的名稱。安裝,命令如下這個插件將會提醒模塊腳本之間模擬瀏覽器共享全局變量的行為,因為這不適用于模塊腳本。而用編譯后的代碼使用這款解析器可以避免不必要的麻煩。
webpack中eslint使用
首先,要使webpack支持eslint,就要要安裝 eslint-loader ,命令如下:
npm install --save-dev eslint-loader
在 webpack.config.js 中添加如下代碼:
{ test: /.js$/, loader: "eslint-loader", enforce: "pre", include: [path.resolve(__dirname, "src")], // 指定檢查的目錄 options: { // 這里的配置項參數將會被傳遞到 eslint 的 CLIEngine formatter: require("eslint-friendly-formatter") // 指定錯誤報告的格式規(guī)范 } }
注:formatter默認是stylish,如果想用第三方的可以安裝該插件,如上方的示例中的 eslint-friendly-formatter 。
其次,要想webpack具有 eslint 的能力,就要安裝eslint,命令如下:
npm install --save-dev eslint
最后,項目想要使用那些eslin規(guī)則,可以創(chuàng)建一個配置項文件 ".eslintrc.js",代碼如下:
module.exports = { root: true, parserOptions: { sourceType: "module" }, env: { browser: true, }, rules: { "indent": ["error", 2], "quotes": ["error", "double"], "semi": ["error", "always"], "no-console": "error", "arrow-parens": 0 } }
這樣,一個簡單的webpack引入eslint已經完成了。
這里講一下 eslintrc.js 的配置使用,詳細細節(jié)請參考http://eslint.cn/docs/user-guide
eslint 配置項root 限定配置文件的使用范圍
parser 指定eslint的解析器
parserOptions 設置解析器選項
extends 指定eslint規(guī)范
plugins 引用第三方的插件
env 指定代碼運行的宿主環(huán)境
rules 啟用額外的規(guī)則或覆蓋默認的規(guī)則
globals 聲明在代碼中的自定義全局變量
在我們使用eslint時,配置文件中的 rules 配置項是否是不可或缺的?
答案是肯定的。不過我們也可以不用自定義reules,我們可以使用第三方的,這里我們就要使用extends配置項。
extends我們可以使用eslint官方推薦的,也可以使用一些大公司提供的的,如:aribnb, google, standard。
在開發(fā)中我們一般使用第三方的。
官方推薦只需在 .eslintrc.js 中添加如下代碼:
extends: "eslint:recommended", extends: "eslint:all",
了解詳情可以參考一下官方規(guī)則表
第三方分享使用第三方分享的,我們一般需要安裝相關的插件代碼如下:
npm install --save-dev eslint-config-airbnb // bnb npm install --save-dev eslint-config-standard // standard
在 .eslintrc.js 中添加如下代碼:
extends: "eslint:google", // or extends: "eslint:standard",
使用這些第三方的擴展,有時我們需要更新一些插件,比如standard:
eslint-plugin-import
不要慌,我們只要按照錯誤提示一步一步的安裝這些插件即可。
雖然,這些第三方的擴展很不錯,但是有時我們需要定義一些比較個性化的規(guī)則,我們就需要添加 rules 配置項。
配置規(guī)則在.eslintrc.js 文件中添加 rules, 代碼如下:
{ "rules": { "semi": ["error", "always"], "quotes": ["error", "double"] } }
"semi" 和 "quotes" 是 ESLint 中 規(guī)則 的名稱。第一個值是錯誤級別,可以使下面的值之一:
"off" or 0 - 關閉規(guī)則
"warn" or 1 - 將規(guī)則視為一個警告(不會影響退出碼)
"error" or 2 - 將規(guī)則視為一個錯誤 (退出碼為1)
這些規(guī)則一般分為兩類:
添加默認或第三庫中沒有的
覆蓋默認或第三庫的
我們的項目中可能會有一些其他的文件也需要進行格式規(guī)范,如:html, vue, react等,對于這些文件的處理,我們需要引入第三方插件。
plugins(html)安裝 eslint-plugin-html ,命令如下:
npm install --save-dev eslint-plugin-html
這個插件將會提醒模塊腳本之間模擬瀏覽器共享全局變量的行為,因為這不適用于模塊腳本。
這個插件也可以擴展文件,如:.vue,.jsx
.eslintrc.js中,添加如下配置項:
settings: { "html/html-extensions": [".html", ".vue"], "html/indent": "+2", },
而對于這種用 eslint-pulgin-html 擴展的的文件我們可以使用 eslint --ext .html,.vue src 進行檢測,如果想要在開發(fā)中邊寫邊檢測,我們可以使用相應文件的loader進行處理。然后執(zhí)行 npm run dev 就可以實現的功能。邊寫邊檢測的功能。
在開發(fā)中有時根據需要,我們可能在同一個項目不同的目錄使用不同的 .eslintrc.js 文件,這時我們就需要使用配置項 root 。
限定使用范圍 (root: true)如果我們想要在不同的目錄中使用不同的 .eslintrc, 我們就需要在該目錄中添加如下的配置項:
{ "root": true }
如果我們不設置的話,它將會繼續(xù)查找,知道更目錄,如果更目錄有配置文件它將會使用根目錄的,這樣會導致當前配置目錄配置無法起作用的問題。
在開發(fā)中針對不同的情況我們要使用不同的解析器,而我們常用的就是 babel-eslint 。
parser(指定解析器)babel-eslint 解析器是一種使用頻率很高的解析器,因為現在很多公司的很多項目目前都使用了es6,為了兼容性考慮基本都使用babel插件對代碼進行編譯。而用babel編譯后的代碼使用 babel-eslint 這款解析器可以避免不必要的麻煩。
babel-eslint 安裝命令:
npm install --save-dev babel-eslint
在 .eslintrc.js 配置文件中添加如下配置項代碼:
parser: "babel-eslint",
如果你使用的默認解析器的話,且在代碼中使用了瀏覽器有兼容性的問題的js新特性,使用webpack編譯就會出現問題,這時我們一般裝最新的eslint或者安裝是使用 babel-eslint 來解決問題。
env(環(huán)境)在 .eslintrc.js 中添加如下代碼:
"env": { "browser": true, // "node": true // }
指定了環(huán)境,你就可以放心的使用它們的全局變量和屬性。
global指定全局變量。
在 .eslintrc.js 中添加如下代碼:
"globals": { "var1": true, "var2": false }
參考源代碼
webpack干貨
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/92660.html
摘要:由于這種差異我們將對預處理器文件的配置封裝為函數,由參數生成對應配置,將文件放入文件內,將配置放在文件內。 前言 源代碼 熟悉 webpack 與 webpack4 配置。 webpack4 相對于 3 的最主要的區(qū)別是所謂的零配置,但是為了滿足我們的項目需求還是要自己進行配置,不過我們可以使用一些 webpack 的預設值。同時 webpack 也拆成了兩部分,webpack 和 w...
摘要:打開瀏覽器輸入,會看到構建的項目的主頁目錄結構使用編輯器打開推薦使用,下面具體看看目錄結構在中,根據我們在構建項目的時候的選項,有以下幾個命令。 構建一個 vue 項目最簡單的方式就是使用腳手架工具 vue-cli 。前端的三大框架都有自己的腳手架工具,其作用就是用配置好的模板迅速搭建起一個項目工程來,省去自己配置 webpack 配置文件的基本內容,大大降低了初學者構建項目的難度。這...
導語: 隨著業(yè)務的增長和開發(fā)團隊的成員快速增加,其中很多新人來自于五湖四海各大門派,在編碼的風格和習慣中也出現各異。 通常在相互 codereview 時發(fā)現很多代碼上的問題,久而久之代碼出現了代碼難以維護的問題,甚至還會出現低級錯誤。 因此,我嘗試在前端代碼質量的管控上做了些探索,也總結了一些經驗分享給大家。 作者:鄭振波 本文大綱介紹 編碼規(guī)范 冗余文件與代碼 1. 編碼規(guī)范 在一些老項...
前言 什么是webpack 本質上,webpack 是一個現代 JavaScript 應用程序的靜態(tài)模塊打包器(module bundler)。當 webpack 處理應用程序時,它會遞歸地構建一個依賴關系圖(dependency graph),其中包含應用程序需要的每個模塊,然后將所有這些模塊打包成一個或多個 bundle。webpack 有哪些功能(代碼轉換 文件優(yōu)化 代碼分割 模塊合并 自...
前言 什么是webpack 本質上,webpack 是一個現代 JavaScript 應用程序的靜態(tài)模塊打包器(module bundler)。當 webpack 處理應用程序時,它會遞歸地構建一個依賴關系圖(dependency graph),其中包含應用程序需要的每個模塊,然后將所有這些模塊打包成一個或多個 bundle。 webpack 有哪些功能(代碼轉換 文件優(yōu)化 代碼分割 模塊合并 ...
閱讀 2670·2023-04-26 02:44
閱讀 8657·2021-11-22 14:44
閱讀 2131·2021-09-27 13:36
閱讀 2528·2021-09-08 10:43
閱讀 692·2019-08-30 15:56
閱讀 1400·2019-08-30 15:55
閱讀 2895·2019-08-28 18:12
閱讀 2837·2019-08-26 13:50