成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

為eject后的create-react-app配置ESLint

Dean / 455人閱讀

摘要:一開始我以為是的問題,然后重新手寫了一些配置依然會報錯,證明不是的問題。規(guī)則真的很嚴(yán)格。配置問題按照的文檔默認(rèn)是,按照說明應(yīng)該是不會阻止。

問題

項(xiàng)目一開始使用的是create-react-app創(chuàng)建的,配置的ESLint是用的AlloyTeam的eslint-config-alloy/react, 默認(rèn)配置已經(jīng)很合理了,并且每條配置都有相應(yīng)的說明,只需要再根據(jù)個人喜好修改一些rule即可,我個人修改的.eslintrc.json配置如下

{
    "extends": [
        "eslint-config-alloy/react"
    ],
    "globals": {
        // 這里填入你的項(xiàng)目需要的全局變量
        // 這里值為 false 表示這個全局變量不允許被重新賦值,比如:
        //
        // jQuery: false,
        // $: false
    },
    "rules": {
        "indent": [
            "warn",
            2,
            {
                "SwitchCase": 1,
                "flatTernaryExpressions": true
            }
        ],
        "semi": [
            "error",
            "never"
        ],
        "react/jsx-indent": [
            "warn",
            2
        ],
        "react/jsx-indent-props": [
            "warn",
            2
        ],
        "no-unused-vars": [
            "warn",
            {
                "vars": "all",
                "args": "none",
                "caughtErrors": "none"
            }
        ]
    }
}

但是在eject之后運(yùn)行npm start后會直接報錯

思考

按理說,eject前后配置不變,只不過是將配置彈出,npm start 應(yīng)該可以直接運(yùn)行,但是卻報了ESLint的錯誤。

一開始我以為是eslint-config-alloy/react的問題,然后重新手寫了一些配置依然會報錯,證明不是eslint-config-alloy/react的問題。google之后在一個issue發(fā)現(xiàn):

By default Eslint errors will raise webpack errors unless you change the config as shown above.

也就是說,ESLint的會在發(fā)現(xiàn)error級別錯誤的時候觸發(fā)webpack報錯,導(dǎo)致編譯失敗。

但是為什么在eject之前能通過審查的代碼在eject后就遇到error報錯了呢?

簡單粗暴我們直接看create-react-app文檔中關(guān)于ESLint的部分

If you want to enable even more accessibility rules, you can create an .eslintrc file in the root of your project with this content:

{
  "extends": ["react-app", "plugin:jsx-a11y/recommended"],
  "plugins": ["jsx-a11y"]
}

However, if you are using Create React App and have not ejected, any additional rules will only be displayed in the IDE integrations, but not in the browser or the terminal.

現(xiàn)在回想一下create-react-app中ESLint是如何工作的,終端有warning/error的信息,但是這個打印出來的信息的其實(shí)并不是依照eslint-config-alloy/react規(guī)則,而是create-react-app的默認(rèn)規(guī)則。在集成在編輯器(我用的VSCode)中的紅色波浪線功能則是根據(jù)eslint-config-alloy/react規(guī)則顯示的。

但是在eject后,編譯與波浪提示都根據(jù)eslint-config-alloy/react規(guī)則進(jìn)行代碼審查,所以eject前根據(jù)默認(rèn)規(guī)則審查通過的代碼在eject后并不能通過eslint-config-alloy/react的審查報了錯。(eslint-config-alloy/react規(guī)則真的很嚴(yán)格)。

ESLint的error該不該直接退出

在這里還有一個設(shè)計(jì)思路與使用思路上的沖突:ESLint默認(rèn)error級別直接報錯退出,是因?yàn)閷⒛撤Nrule的錯誤等級定為error時,當(dāng)出錯代碼觸發(fā)了這個rule,就意味著程序根據(jù)規(guī)則來說已經(jīng)不對了,就不需要再往后進(jìn)行編譯等等了。所以代碼必須先過了ESLint這關(guān)(也就是用戶自己對代碼定下的規(guī)則),才能放到babel里去進(jìn)行編譯。(具體的可以看zakas大神關(guān)于這個問題的討論)

(我個人之前本來比較喜歡error時不退出,然后選擇性的去修改部分有問題的代碼,有些報錯的代碼就不理會等重構(gòu)的時候再說。但是仔細(xì)一想其實(shí)違背了ESLint的思想,既然有warning和error的區(qū)分,那些不重要的error其實(shí)就應(yīng)該定義為warning。)

eslint-loader配置問題

按照ESLint-loader的文檔

failOnError (default: false)

Loader will cause the module build to fail if there are any ESLint errors.

failOnError默認(rèn)是false,按照說明應(yīng)該是不會阻止build。

ESLint-loader的作者也提到(不過遠(yuǎn)在2015年3月)

failOn* are off by default to avoid webpack to break the build for "just some linting issues". So you should not have any error/warning that break the build by default.

然而,實(shí)際上build依然失敗,具體原因我也不清楚,有幾個issue也在反應(yīng)failOnError不起作用,我猜可能是ESLint-loader沒能成功的配置ESLint,這個坑以后仔細(xì)研究一下再來填(逃。

解決方案 方案1

eslint-loader的作者給出的解決方案

Like I said, you can use emitWarning: true option to force all ESLint error/warning being reported as warnings

emitWarning設(shè)為true就可以了,所有的error/warning信息都會打印出來,error也不會阻止編譯,簡單粗暴。

rules: [{
  enforce: "pre",
  test: /.jsx?$/,
  loader: "ESLint-loader",
  options: {
    emitWarning: true
  }
}]
方案2

遵照zakas大神的設(shè)計(jì)思路,報error的就阻止編譯,改到通過為止,報warning的就打印出來,個人認(rèn)為這才是正確遵照ESLint的使用方法。

方案3(粗暴)

./node_modules/ESLint-loader/index.js中的

emitter(webpack.version === 2 ? new ESLintError(messages) : messages)

直接注釋掉!不給ESLint傳遞任何錯誤信息,也不會返回錯誤碼了,這樣終端永遠(yuǎn)都是 0 errors 0 warnings(誤),錯誤就只能通過編輯器的紅線提示來看了。

tips

Also to note, the actual build still finishes and produces output. This only affects wrappers that would call webpack, such as webpack-dev-server (won"t automatically reload the browser if lint errors exist) or frontend-maven-plugin (will fail the maven build if lint errors exist).

這位仁兄提到了關(guān)于ESLint其實(shí)并不會阻止build,只是會在遇到error時阻止像webpack-dev-server這種服務(wù)器對瀏覽器的自動刷新。

參考

errors cause webpack to not build #23

MoOx/ESLint-loader

ESLint error causing Webpack to stop watching/building #168

Option to exit with success even if there are errors #2949

ESLint-loader with WebPack 2.2 #148

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90160.html

相關(guān)文章

  • React項(xiàng)目筆記之create-react-app自定義ESLint配置文件

    摘要:初始化項(xiàng)目使用創(chuàng)建項(xiàng)目此過程不做詳解,然后運(yùn)行使其暴露等配置文件自定義上述步驟并沒有暴露腳手架封裝的操作,為了使得項(xiàng)目統(tǒng)一規(guī)范化,添加操作是非常不錯的選擇關(guān)于其他的操作,請參見官網(wǎng),本文主要針對限制規(guī)范配置。 原博客地址:https://yezihaohao.github.io 前言 了解eslint基礎(chǔ)用法,若想更進(jìn)一步了解其,請查閱官網(wǎng)以及相關(guān)資料(中文網(wǎng)) 若有問題請指出或加群...

    Dogee 評論0 收藏0
  • react+express項(xiàng)目

    摘要:暴露所有內(nèi)建配置,項(xiàng)目下會新增或?qū)Σ糠峙渲梦募M(jìn)行修改。開發(fā)環(huán)境開發(fā)時,前端項(xiàng)目和后端項(xiàng)目運(yùn)行時端口端口不同,存在跨域問題。項(xiàng)目目錄結(jié)構(gòu)優(yōu)化項(xiàng)目目錄結(jié)構(gòu)優(yōu)化開發(fā)目錄主要是目錄,因此需要修改的目錄主要是目錄。 1 開發(fā)環(huán)境準(zhǔn)備(windows) 1.1 安裝nodejs和npm 1) 下載nodejs安裝包:http://nodejs.org/en/download/ nodejs安...

    Luosunce 評論0 收藏0
  • 在 React-CRA 應(yīng)用中配合 VSCode 使用 ESLint 實(shí)踐前端代碼規(guī)范

    摘要:編碼規(guī)范是獨(dú)角獸公司內(nèi)部的編碼規(guī)范,該項(xiàng)目是上很受歡迎的一個開源項(xiàng)目,在前端開發(fā)中使用廣泛,本文的配置規(guī)則就是以編碼規(guī)范和編碼規(guī)范作為基礎(chǔ)的。 更新時間:2019-01-22React.js create-react-app 項(xiàng)目 + VSCode 編輯器 + ESLint 代碼檢查工具 + Airbnb 編碼規(guī)范 前言 為什么要使用 ESLint 在項(xiàng)目開發(fā)過程中,編寫符合團(tuán)隊(duì)編碼規(guī)...

    Hujiawei 評論0 收藏0
  • 做一個基于react-scripts的腳手架

    摘要:前言作為官方的腳手架是相當(dāng)好用的。注意就是腳手架的核心配置代碼。另一個是使用,用戶通過增加修改配置。所以才有了今天的主題基于的腳手架,確切說應(yīng)該是基于的腳手架。其中一定要填寫。前言 create-react-app作為facebook官方的react腳手架是相當(dāng)好用的。主要設(shè)計(jì)原理是將配置好的如Webpack,Babel,ESLint,合并到react-scripts這npm包中,用戶就可以...

    linkFly 評論0 收藏0
  • create-react-app 源碼學(xué)習(xí)(上)

    摘要:這里通過調(diào)用方法方法主要是通過來通過命令執(zhí)行下的方法。 原文地址Nealyang/personalBlog 前言 對于前端工程構(gòu)建,很多公司、BU 都有自己的一套構(gòu)建體系,比如我們正在使用的 def,或者 vue-cli 或者 create-react-app,由于筆者最近一直想搭建一個個人網(wǎng)站,秉持著呼吸不停,折騰不止的原則,編碼的過程中,還是不想太過于枯燥。在 coding 之前...

    MkkHou 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<