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

資訊專欄INFORMATION COLUMN

前端構(gòu)建之webpack

MartinHan / 1741人閱讀

摘要:前端構(gòu)建之之前寫了一個前端構(gòu)建之,同樣的目的寫一個,內(nèi)容基本上和一樣,主要用來自己學(xué)習(xí)記錄。合并很方便的實現(xiàn)合并最后附上完整的源代碼。

前端構(gòu)建之webpack
之前寫了一個前端構(gòu)建之gulp,同樣的目的寫一個webpack, 內(nèi)容基本上和gulp一樣,主要用來自己學(xué)習(xí)記錄。
為什么需要前端構(gòu)建
不解釋
本文大致分為以下幾個內(nèi)容:

規(guī)范校驗js代碼(jslint)

js解釋器(babel)

合并js代碼(concat)

壓縮js代碼(uglify)

sourcemap

規(guī)范校驗css代碼(csslint)

css解釋器

合并css代碼

壓縮css代碼

規(guī)范校驗js代碼
1. 用webpack檢測js代碼規(guī)范

js檢測工具用來

檢測自己寫的js是否有語法錯誤

是否根據(jù)我們設(shè)定的規(guī)則寫的

常用的js檢測工具有jshint、jslint、eslint等, 推薦用eslint。
在webpack中,推薦用eslint這個插件。使用eslint時配置一個.eslintrc文件,用來編寫自定義js規(guī)則。
如果用到了es模塊,需要在.eslintrc配置中指定parserOptions的sourceType為module。

{
  "root": true,
  "env": {
    "browser": true,
    "node": true,
    "es6": true
  },
  "parserOptions": {
    "sourceType": "module"
  },
  "extends": "eslint:recommended",  //使用推薦的eslint語法
  "rules": {
    "indent": ["error", 4], //自定義indent為4個空格,級別為error
    "semi": ["off", "always"],
    "no-console": "off",
    "no-unused-vars": "off"
  }
}
2. 使用prettier強制修改js代碼

使用prettier, 根據(jù)prettier自定義來強制修改js代碼。
可以在使用prettier時添加options,或者建立一個config文件來配置options也可以。
參考這里

        {
            singleQuote: true,
            trailingComma: "all",
            bracketSpacing : true,
            semi: true,
            tabWidth: 4,  //定義indent為4個空格
            printWidth: 120
        }
3. precommit

這個插件目的是在commit之前,執(zhí)行相關(guān)操作
"precommit": "gulp format_js"

4. husky

這個插件目的是建立和git之間的hooks(鉤子), 通常和precommit結(jié)合用,
比如使用git commit這個命令時, 會通過hooks調(diào)用precommit語句。
這樣我們就不需要專門去執(zhí)行npm run precommit這個命令了,
當(dāng)我們git commit的時候,husky會自動調(diào)用npm run precommit

5. lint-staged

但是還有一個問題, 上面執(zhí)行完git commit 后,通過prettier修改了所有的js文件,
有些便不是我自己修改的文件,也會被強制修改,
于是可以通過lint-staged這個node模塊來指定stage中的文件。
思想很簡單,只對git stage中的文件處理。
可以參考這里

通常使用它的思想:

執(zhí)行git commit時,通過husky調(diào)用precommit

precommit 執(zhí)行lint-staged,即只對git stage中的文件進(jìn)行處理

lint-staged中配置prettier修改js文件(添加一個config文件來配置)

lint-staged中配置eslintjs檢測文件(添加一個eslintrc文件來配置)

如果正常通過, 則把通過prettier修改和eslint檢測的js文件,通過git add 添加

  "scripts": {  
    "precommit": "lint-staged"
  },
  "lint-staged": {
    "*.js": [                 // 要處理的js路徑
      "prettier --write",  //要處理的文件上修改
      "eslint  --fix",       // 參數(shù)fix的意思是:根據(jù)eslint配置文件自動修復(fù)js文件
      "git add"
    ]
  },

prettier 能強制修改js,eslint --fix也能強制修改js, 區(qū)別是什么呢???
我的理解prettier更強一點,eslint --fix 強制修改有限。

這里有一個注意點,prettier的配置參數(shù), 通過添加一個config文件來配置。

可以在使用prettier時添加options,或者建立一個config文件來配置options也可以。

"lint-staged"的配置的意思是,
對git stage中的文件的操作,如eslint *.js, git add *.js, 不能用寫gulp *.js
參考這里

我添加的是 prettier.config.js文件,

module.exports = {
    printWidth: 120,
    parser: "flow",
    singleQuote: true,
    tabWidth: 4,
    bracketSpacing : true,
    semi: true
};    
eslintrc前面已經(jīng)寫過了。

通過lint-staged就不需要第7步中生成一個臨時文件(tempjs)來過渡了, 
因為prettier就直接處理stage終端文件了。

思想:

通過lint-staged獲取想要處理的js文件

通過prettier 根據(jù)自定義規(guī)則強制修改要處理的js文件

eslint檢測通過prettier強制修改的js文件

eslint檢測通過的話, 將處理的js文件添加到git stage中

使用es6寫js時,轉(zhuǎn)化為各個瀏覽器能識別的es5
6. babel 編譯
babel用來將es6語法轉(zhuǎn)化為es5, 比如es6中的let轉(zhuǎn)化為var, 變量字符串拼接轉(zhuǎn)化為+,等等。
結(jié)合webpack用,就需要使用webpack強大的loader, 它依賴于babel-core,所以需要安裝babel-loader和babel-core。

自己的理解: babel, babel-core提供了babel的運行環(huán)境(理解有錯誤的話,之后改正)。
只有這兩個(babel, babel-core)還不能實現(xiàn)轉(zhuǎn)譯,需要transform插件(如babel-preset-env)
然后需要安裝babel-preset-env來將自己寫的es6(源碼),根據(jù)當(dāng)前執(zhí)行環(huán)境(瀏覽器),
轉(zhuǎn)化為es5(當(dāng)前環(huán)境-瀏覽器能識別的語法)
合并js

為什么需要合并js呢,通過合并js文件,可以減少http請求。

7. concat
通過webpack可以將多個js文件合并成一個js文件。
一個入口文件,一個輸出。
用法相對簡單, 

現(xiàn)在有一個新的需求task1, 需要多帶帶寫幾個js文件,
但是不想和其他js合并到一起,也就是說想多帶帶合并這幾個js文件,然后多帶帶輸出,
這個時候, 就多入口文件,多個輸出。

比起gulp來,webpack可以很方便的實現(xiàn)這個功能。

壓縮js
8. uglify

webpack中可以使用 uglifyjs-webpack-plugin用來壓縮js文件
壓縮很簡單, 獲取js原文件,合并,然后壓縮

sourcemap
9. sourcemaps
 sourcemap 的目的:還原源碼,
 什么意思呢? 當(dāng)我們將源碼經(jīng)過合并,壓縮處理后,成為了一個文件,不方便調(diào)試。
 特別是壓縮后更是面目全非,這樣我們在開發(fā)階段不能實現(xiàn)debug,比如打斷點功能就不可能實現(xiàn)了。
 sorucemap就是解決的這個問題。
 
 經(jīng)過sourcemap處理后,在目標(biāo)目錄(dest指定的)下,生成一個新文件(與轉(zhuǎn)譯前對應(yīng)的map文件),
 目錄結(jié)構(gòu)與轉(zhuǎn)譯前完全對應(yīng)。這樣我們就很容易找到某個文件,然后實現(xiàn)打斷點。
 
 webpack自帶sourcemap功能,只需要添加devtool既可以。
 
規(guī)范校驗css代碼
規(guī)范校驗js寫法的工具有jslint,jshint,最近的eslint等等,
規(guī)范校驗css寫法的工具有csslint,stylelint等等。
10. stylelint

stylelint用來檢測css是否根據(jù)配置文件來寫的,是基于postcss的一個檢測工具。
stylefmt是一個根據(jù)stylelint的配置文件來強制修改css文件的插件。有點prettier的意思。

但是可以不用stylefmt, 在stylelint的選項中添加 --fix 也可以修改css文件。

npm install postcss stylelint-loader stylelint stylelint-config-standard -save-dev

使用stylelint時,有個標(biāo)準(zhǔn)配置插件, stylelint-config-standard。

以下為 stylelint的配置文件(.stylelintrc)

{
    "extends": "stylelint-config-standard",    // 使用stylelint的默認(rèn)標(biāo)準(zhǔn)配置
    "rules": {
        "declaration-block-trailing-semicolon": null,   // 各種規(guī)則,根據(jù)自己需要可以靈活配置
        "indentation": 4,
        "block-no-empty": null,
        "max-empty-lines": 1,
        "selector-list-comma-newline-after": never-multi-line,
        "at-rule-no-unknown": null,
        "declaration-colon-space-after": null,
        "no-duplicate-selectors" : null,
        "no-descending-specificity": null,
        "selector-pseudo-element-colon-notation": null,
        "no-empty-source": null
    }
}
11. postcss

當(dāng)我們用sass的寫法來書寫css

想在css中用變量,for循環(huán)等語法

想利用 (cssnext)[http://cssnext.io/] 書寫css時

根據(jù)不同瀏覽器自動添加前綴 (autoprefixer)

當(dāng)我們想在css中實現(xiàn)上述等功能時,可以用postcss。
postcss就是一個平臺,可以通過添加各種插件來實現(xiàn)上述等功能。

npm install postcss-cssnext postcss-simple-vars postcss-nested --save-dev

可以寫一個postcss的配置文件來專門規(guī)范postcss相關(guān)的配置,也可以直接寫在在webpack配置文件中。
css合并
webpack很方便的實現(xiàn)css合并

最后附上完整的(github源代碼)[https://github.com/zhangchch/...]。

 以上都是自己的理解,如有錯誤的地方,真心求指教。

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

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

相關(guān)文章

  • 前端每周清單第 48 期:Slack Webpack 構(gòu)建優(yōu)化,CSS 命名規(guī)范與用戶追蹤,Vue.

    摘要:發(fā)布是由團(tuán)隊開源的,操作接口庫,已成為事實上的瀏覽器操作標(biāo)準(zhǔn)。本周正式發(fā)布,為我們帶來了,,支持自定義頭部與腳部,支持增強,兼容原生協(xié)議等特性變化。新特性介紹日前發(fā)布了大版本更新,引入了一系列的新特性與提升,本文即是對這些變化進(jìn)行深入解讀。 showImg(https://segmentfault.com/img/remote/1460000012940044); 前端每周清單專注前端...

    sean 評論0 收藏0
  • 前端開發(fā)走進(jìn)Vue.js

    摘要:作為目前最熱門最具前景的前端框架之一,其提供了一種幫助我們快速構(gòu)建并開發(fā)前端項目的新的思維模式。的新版本,的簡稱。的包管理工具,用于同一管理我們前端項目中需要用到的包插件工具命令等,便于開發(fā)和維護(hù)。 Vue.js作為目前最熱門最具前景的前端框架之一,其提供了一種幫助我們快速構(gòu)建并開發(fā)前端項目的新的思維模式。本文旨在幫助大家認(rèn)識Vue.js,了解Vue.js的開發(fā)流程,并進(jìn)一步理解如何通...

    zxhaaa 評論0 收藏0
  • 前端每周清單第 12 期:支付寶前端構(gòu)建工具發(fā)展、LinkedIn用Brotli加快網(wǎng)頁響應(yīng)速度、餓

    摘要:前端每周清單第期支付寶前端構(gòu)建工具發(fā)展用加快網(wǎng)頁響應(yīng)速度餓了么升級實踐前端前端每周清單前端每周清單專注前端領(lǐng)域內(nèi)容,分為新聞熱點開發(fā)教程工程實踐深度閱讀開源項目巔峰人生等欄目。 前端每周清單第 12 期:支付寶前端構(gòu)建工具發(fā)展、LinkedIn用Brotli加快網(wǎng)頁響應(yīng)速度、餓了么PWA 升級實踐 為InfoQ中文站特供稿件,首發(fā)地址為這里;如需轉(zhuǎn)載,請與InfoQ中文站聯(lián)系。從屬于筆...

    liuchengxu 評論0 收藏0
  • Javascript五十問——從源頭細(xì)說Webpack與Gulp

    摘要:前言與是目前圈子內(nèi)比較活躍的前端構(gòu)建工具。對于初學(xué)者來說,對這二者往往容易認(rèn)識不清,今天,就從事件的源頭,說清楚與。它可以將許多松散的模塊按照依賴和規(guī)則打包成符合生產(chǎn)環(huán)境部署的前端資源。打包后形成的文件出口。 前言:Webpack 與 gulp是目前圈子內(nèi)比較活躍的前端構(gòu)建工具。網(wǎng)上有很多二者比較的文章,面試中也會經(jīng)常遇到gulp,Webpack的區(qū)別這樣的問題。對于初學(xué)者來說,對這二...

    lwx12525 評論0 收藏0

發(fā)表評論

0條評論

MartinHan

|高級講師

TA的文章

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