Webpack 打包工具

1. webpack 概念

[文檔地址](https://www.webpackjs.com/concepts/)

2. webpack 命令使用及相關工具包

1. webpack 安裝和打包命令:
    $ npm i webpack --save-dev
    $ webpack [source] [destination]
    
2. webpack 熱部署工具安裝和使用命令:
    $ npm i webpack-dev-server --save-dev  //安裝
    $ webpack-dev-derver --open --port [port] --contentBase [content] --hot
        --open //自動打開瀏覽器
        --port //指定端口號
        --contentBase //指定根目錄
        --hot //打開熱部署

3. webpack 須要的第三方包:
    $ npm i vue-loader vue-template-complier
    $ npm i babel-core babel-loader babel-plugin-transform-runtime
    $ npm i babel-preset-env babel-preset-stage-0

3. webpack 配置文件模板

//webpack.config.js:

const path = require('path');
const webpack = require('webpack');
const htmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  entry: path.join(__dirname, './src/main.js'), //入口文件
  output: { //指定輸出項
      path: path.join(__dirname, './dist'), //輸出路徑
      filename: 'bundle.js' //指定輸出文件名
  },
  plugins: [
    new webpack.HotModuleReplacementPlugin(),   //配置熱部署
    new htmlWebpackPlugin({
        template: path.join(__dirname, './src/index.html'), //指定模板文件路徑
        filename: 'index.html'  //指定瀏覽器打開的文件名      
    })
  ],
  module: {
      rules: [
        { test: /\.css$/, use: ['style-loader', 'css-loader'] },    //處理.css文件的loader
        { test: /\.css$/, use: ['style-loader', 'css-loader', 'less-loader'] },  //處理.less文件的loader
        { test: /\.css$/, use: ['style-loader', 'css-loader', 'sass-loader'] },   //處理.scss的loader
        { test: /\.(jpg|png|gif|jpeg|bmp)$/, use: 'url-loader?limit=[limit]&name=[hash:num]-[name].[ext]' },    //處理圖片的loader
        { test: /\.(ttf|eot|svg|woff|woff2)$/, use: 'url-loader' },  //處理字體的loader
        { test: /\.js$/, use: 'babel-loader', exclude: /node_modules/ },    //配置babel轉換高級的ES語法
        { test: /\.vue$/, use: 'vue-loader' },  //處理.vue文件的loader
      ]
  },
  resolve: {
      "alias": {
          "vue$": "vue/dist/vue.js"
      }
  }
};
相關文章
相關標籤/搜索