首頁 >web前端 >js教程 >webpack如何打包js與css文件

webpack如何打包js與css文件

php中世界最好的语言
php中世界最好的语言原創
2018-06-15 11:28:591555瀏覽

這次帶給大家webpack如何打包js與css文件,webpack打包js與css文件的注意事項有哪些,下面就是實戰案例,一起來看一下。

打包壓縮js與css

由於webpack本身整合了UglifyJS外掛程式(webpack.optimize.UglifyJsPlugin)來完成對JS與CSS的壓縮混淆,無需引用額外的插件,

其指令webpack -p 即表示呼叫UglifyJS來壓縮程式碼,還有不少webpack外掛程式如html-webpack-plugin 也會預設使用UglifyJS。

uglify-js的發行版本只支援ES5,如果你要壓縮ES6 程式碼請使用開發分支。

UglifyJS可用的選項有:

parse       解釋

compress    壓縮

mangle      混淆#   壓縮

mangle    

minify      最小化//在插件HtmlWebpackPlugin中使用

CLI        #AST         抽象語法樹

name        名字,並包含變數名稱、函數名稱、屬性名稱

toplevel    頂層作用域

##unreable##ccachable#dunreable##option#unreable

unreable

unreable

unreable##option#。選項

STDIN       標準輸入,指在指令列中直接輸入

STDOUT      標準輸出

STDERR     與標準錯誤輸出

110 函數#pect#p,即函數#,即函數#d除了返回外還產生別的作用,例如改了全域變數

列一份配置:

//使用插件html-webpack-plugin打包合并html
//使用插件extract-text-webpack-plugin打包独立的css
//使用UglifyJsPlugin压缩代码
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var webpack = require("webpack");
module.exports = {
  entry: {
    bundle : './src/js/main.js'
  },
  output: {
    filename: "[name]-[hash].js",
    path: __dirname + '/dist'
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: ExtractTextPlugin.extract({
          fallback: "style-loader",
          use: "css-loader"
        })
      },
      {
        test: /\.(png|jpg|jpeg|gif)$/,
        use: 'url-loader?limit=8192'
      }
    ]
  },
  resolve:{
      extensions:['.js','.css','.json'] //用于配置程序可以自行补全哪些文件后缀
  },
  plugins:[
    new HtmlWebpackPlugin({
      title: 'hello webpack',
      template:'src/component/index.html',
      inject:'body',
      minify:{ //压缩HTML文件
         removeComments:true,  //移除HTML中的注释
         collapseWhitespace:true  //删除空白符与换行符
       }
    }),
    new ExtractTextPlugin("[name].[hash].css"),
    new webpack.optimize.UglifyJsPlugin({
      compress: {   //压缩代码
        dead_code: true,  //移除没被引用的代码
        warnings: false,   //当删除没有用处的代码时,显示警告
        loops: true //当do、while 、 for循环的判断条件可以确定是,对其进行优化
      },
      except: ['$super', '$', 'exports', 'require']  //混淆,并排除关键字
    })
  ]
};
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue-router內query動態傳參如何處理

如何使用webpack vue環境區域網路

以上是webpack如何打包js與css文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn