欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解webpack4.x之搭建前端開發(fā)環(huán)境

 更新時間:2019年03月28日 09:00:19   作者:Gerryli  
這篇文章主要介紹了詳解webpack4.x之搭建前端開發(fā)環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

webpack是一個現(xiàn)代JavaScript應(yīng)用程序的靜態(tài)模塊打包器,借用官網(wǎng)的一張圖,它能夠?qū)⒁恍╊A(yù)處理語言,js的最新語法轉(zhuǎn)換成瀏覽器識別的內(nèi)容?,F(xiàn)在一般的前端框架都有比較成熟的腳手架,大多數(shù)對webpack都有個較好的集成,我們只需要敲一些簡單的命令就能生成一個通用的項目模板,比較便捷,但是要知其然知其所以然,所以今天就嘗試著從零開始搭建一個前端開發(fā)環(huán)境。

項目源碼:

https://github.com/gerryli0214/webpack-demo

webpack的四個核心概念:

1.、入口(entry)

2、輸出(output)

3、loader

4、插件(plugins)

首先,我們執(zhí)行下npm init;初始化一個node工程,填寫項目的信息,整個項目的目錄結(jié)構(gòu)如下:

全部安裝webpack-cli:

npm install webpack-cli -g

新建一個 webpack.config.js, 這個是webpack默認配置文件,在里面我們可以配置打包信息,初始化文件為:

const config = {};
module.exports = config;

入口(entry):

項目的入口文件,可以配置單個/多個,為入口文件的相對路徑,type: string/object; 我們項目入口文件為index.js。

const config = {
  entry: './src/index.js'
}

module.exports = config;

輸出(output):

打包后的文件路徑和配置信息,path為打包文件路徑,filename為輸出文件名稱,name為原始文件名稱,hash為打包后的hash地址:

output: {
  path: path.resolve(__dirname, 'dist'),
  filename: '[name].[hash].min.js'
}

loader:

loader能夠處理非JavaScript文件,webpack默認只能處理JavaScript文件。在使用loader時,首先要安裝下指定loader的依賴,此部分的配置規(guī)則與之前版本有所差異,具體配置如下:

npm install babel-loader css-loader -D
module: {
    rules: [{
        test: /\.css$/,
        use: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          use: 'css-loader'
        })
      },
      {
        test: /\.js/,
        exclude: /node_modules/, //過濾node_modules文件夾
        use: [{
          loader: 'babel-loader'
        }]
      }
    ]
  }

插件(plugins):

插件是webpack最為強大的功能之一,利用插件,我們可以進行代碼的混淆、壓縮、重新定義項目環(huán)境變量等。插件分為webpack內(nèi)置插件和第三方插件,第三方插件在使用時首先要安裝依賴和導(dǎo)入依賴模塊。詳細的使用方法可以參考npm。下面羅列了幾個項目中常用的插件:

html-webpack-plugin:

主要作用:

1、為html文件中引入的外部資源如 scriptlink 動態(tài)添加每次compile后的hash,防止引用緩存的外部文件問題

2、可以生成創(chuàng)建html入口文件,比如單頁面可以生成一個html文件入口,配置多個就可以打包成多頁面

extract-text-webpack-plugin:

主要作用:分離打包的css文件

uglifyjs-webpack-plugin:

主要作用:混淆js代碼

webpack-bundle-analyzer:

主要作用:生成打包文件報告,可以看到各個模塊打包后文件大小信息

clean-webpack-plugin:

主要作用:每次打包之前清除dist文件夾

配置信息如下:

const path = require('path');
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const CleanWebpackPlugin = require('clean-webpack-plugin');

const config = {
  entry: './src/index.js',
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[hash].min.js'
  },
  module: {
    rules: [{
        test: /\.css$/,
        use: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          use: 'css-loader'
        })
      },
      {
        test: /\.js/,
        exclude: /node_modules/, //過濾node_modules文件夾
        use: [{
          loader: 'babel-loader'
        }]
      }
    ]
  },
  optimization: {
    splitChunks: {
      name: "vendor",
      filename: 'vendor-[hash].min.js'
    },
    minimizer: [new UglifyJsPlugin()]
  },
  plugins: [
    new HtmlWebpackPlugin({ template: './src/index.html' }),
    new ExtractTextPlugin({
      filename: 'build.min.css',
      allChunks: true,
    }),
    new webpack.BannerPlugin({
      banner: `構(gòu)建時間:${new Date().getFullYear()}-${new Date().getMonth()+1}-${new Date().getDate()}`
    }),
    new CleanWebpackPlugin(),
    // new webpack.EnvironmentPlugin({ NODE_ENV: 'production' }),
    new BundleAnalyzerPlugin()
  ]
};

module.exports = config;

以上為打包的基礎(chǔ)配置信息,在我們實際開發(fā)中,經(jīng)常會用到前端開發(fā)服務(wù),模塊熱更新以及前端的跨域請求代理,webpack中提供了webpack-dev-server來滿足我們的需求,在使用之前先安裝下webpack-dev-server的依賴:

npm install webpack-dev-server -D

具體文件配置如下:

devServer: {
    contentBase: path.join(__dirname, 'dist'),
    compress: true,
    host: '0.0.0.0',
    port: 9000,
    hot: true, //是否熱更新
    proxy: { //代理
      '/api': 'http://localhost:3000'
    }
  }

package.json中啟動命令配置如下:

"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "start": "webpack-dev-server --mode development",
    "build": "webpack --mode production"
  }

執(zhí)行npm run start,執(zhí)行結(jié)果如下:

這樣開發(fā)環(huán)境我們的主要配置就完成了,但是當(dāng)我們用uglifyjs壓縮es6代碼時,會發(fā)現(xiàn)會報錯,因為uglifyjs不能壓縮es6的代碼,此時我們需要手動配置下babel,具體步驟如下:

1、安裝項目依賴

npm install @babel/core @babel/preset-env -D

2、新建在項目根目錄下 .babelrc 文件,填入以下配置信息

{
  "presets":["@babel/preset-env"]
}

執(zhí)行npm run build,壓縮項目代碼,結(jié)果如下:

全部代碼:

const path = require('path');
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const CleanWebpackPlugin = require('clean-webpack-plugin');

const config = {
  entry: './src/index.js',
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[hash].min.js'
  },
  module: {
    rules: [{
        test: /\.css$/,
        use: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          use: 'css-loader'
        })
      },
      {
        test: /\.js/,
        exclude: /node_modules/, //過濾node_modules文件夾
        use: [{
          loader: 'babel-loader'
        }]
      }
    ]
  },
  optimization: {
    splitChunks: {
      name: "vendor",
      filename: 'vendor-[hash].min.js'
    },
    minimizer: [new UglifyJsPlugin()]
  },
  plugins: [
    new HtmlWebpackPlugin({ template: './src/index.html' }),
    new ExtractTextPlugin({
      filename: 'build.min.css',
      allChunks: true,
    }),
    new webpack.BannerPlugin({
      banner: `構(gòu)建時間:${new Date().getFullYear()}-${new Date().getMonth()+1}-${new Date().getDate()}`
    }),
    new CleanWebpackPlugin(),
    // new webpack.EnvironmentPlugin({ NODE_ENV: 'production' }),
    new BundleAnalyzerPlugin()
  ],
  devServer: {
    contentBase: path.join(__dirname, 'dist'),
    compress: true,
    host: '0.0.0.0',
    port: 9000,
    hot: true, //是否熱更新
    proxy: { //代理
      '/api': 'http://localhost:3000'
    }
  },
  devtool: 'source-map'
};

module.exports = config;

參考資料:

webpack中文網(wǎng): https://www.webpackjs.com

webpack內(nèi)置插件列表: https://www.webpackjs.com/plugins/

第三方插件可自行搜索npm: https://www.npmjs.com/

項目源碼:https://github.com/gerryli0214/webpack-demo

文筆比較粗糙,如有問題,煩請指出,謝謝!以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript利用虛擬列表實現(xiàn)高性能渲染數(shù)據(jù)詳解

    JavaScript利用虛擬列表實現(xiàn)高性能渲染數(shù)據(jù)詳解

    在前文中我們提到可以使用時間分片的方式來對長列表進行渲染,但這種方式更適用于列表項的DOM結(jié)構(gòu)十分簡單的情況,所以本文來講講如何使用虛擬列表的方式,來同時加載大量數(shù)據(jù)吧
    2023-05-05
  • 淺談Webpack自動化構(gòu)建實踐指南

    淺談Webpack自動化構(gòu)建實踐指南

    本篇文章主要介紹了Webpack自動化構(gòu)建實踐指南,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • 跟我學(xué)習(xí)javascript的全局變量

    跟我學(xué)習(xí)javascript的全局變量

    跟我學(xué)習(xí)javascript的全局變量,告訴大家三種避免全局變量的方法,感興趣的小伙伴們可以參考一下
    2015-11-11
  • 原生js拖拽(第一課 未兼容)拖拽思路

    原生js拖拽(第一課 未兼容)拖拽思路

    第一步點擊需要拖動的元素,在點擊下的元素被選中,進行move移動,當(dāng)鼠標彈起的時候,停止動作.點擊元素oDIV的時候,可用的是oDIV區(qū)域,而move和up則是全局區(qū)域
    2013-03-03
  • Javascript前端經(jīng)典的面試題及答案

    Javascript前端經(jīng)典的面試題及答案

    最近在網(wǎng)上看到了一些關(guān)于Javascript的面試題就整理了下來,希望對有需要的朋友或者自己能有一定的幫助,后續(xù)看到再繼續(xù)補充。下面一起來看看這篇關(guān)于Javascript前端常見的面試題的文章,一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-03-03
  • js跨域請求的5中解決方式

    js跨域請求的5中解決方式

    這篇文章主要介紹了js跨域請求的5中解決方式的相關(guān)資料,需要的朋友可以參考下
    2015-07-07
  • 讓插入到 innerHTML 中的 script 跑起來的代碼

    讓插入到 innerHTML 中的 script 跑起來的代碼

    讓插入到 innerHTML 中的 script 跑起來的代碼...
    2007-11-11
  • 再談javascript常見錯誤及解決方法

    再談javascript常見錯誤及解決方法

    下面小編就為大家?guī)硪黄僬刯avascript常見錯誤及解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • 高性能js數(shù)組去重(12種方法,史上最全)

    高性能js數(shù)組去重(12種方法,史上最全)

    數(shù)組去重,一般都是在面試的時候才會碰到,一般是要求手寫數(shù)組去重方法的代碼。如果是被提問到,數(shù)組去重的方法有哪些?你能答出其中的10種,面試官很有可能對你刮目相看
    2019-12-12
  • JavaScript檢測瀏覽器是否支持CSS變量代碼實例

    JavaScript檢測瀏覽器是否支持CSS變量代碼實例

    這篇文章主要介紹了JavaScript檢測瀏覽器是否支持CSS變量代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04

最新評論