欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

詳解webpack進階之插件篇

一、插件篇

我們注重客戶提出的每個要求,我們充分考慮每一個細節(jié),我們積極的做好成都網站建設、成都做網站服務,我們努力開拓更好的視野,通過不懈的努力,成都創(chuàng)新互聯(lián)贏得了業(yè)內的良好聲譽,這一切,也不斷的激勵著我們更好的服務客戶。 主要業(yè)務:網站建設,網站制作,網站設計,成都微信小程序,網站開發(fā),技術開發(fā)實力,DIV+CSS,PHP及ASP,ASP.Net,SQL數(shù)據庫的技術開發(fā)工程師。

1. 自動補全css3前綴

autoprefixer

官方是這樣說的:Parse CSS and add vendor prefixes to CSS rules using values from the Can I Use website,也就是說它是一個自動檢測兼容性給各個瀏覽器加個內核前綴的插件。

舉個栗子:最新的彈性盒模型flux

實際代碼:

:fullscreen a {
 display: flex
}

插件自動補充后

a {
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex
}

效果顯而易見,我們可以更專注于css布局和美化,而不需要花過多的精力都寫相同的外碼而加上不同的前綴,也減少了冗余代碼。

使用方法:

cnpm install --save-dev autoprefixer postcss-loader
var autoprefixer = require('autoprefixer');
module.exports={
 //其他配置這里就不寫了

 module:{
 loaders:[
 {
  test:/\.css$/,
  //在原有基礎上加上一個postcss的loader就可以了
  loaders:['style-loader','css-loader','postcss-loader']
  }
  ]
 },
 postcss:[autoprefixer({browsers:['last 2 versions']})]

}

2. 自動生成html插件

html-webpack-plugin

cnpm install html-webpack-plugin --save-dev
 //webpack.config.js
 var HtmlWebpackPlugin = require('html-webpack-plugin');
 module.exports={
 entry:'./index.js',
 output:{
  path:__dirname+'/dist',
  filename:'bundle.js'
 }
 plugins:[
  new HtmlWebpackPlugin()
 ]
 }

作用:它會在dist目錄下自動生成一個index.html

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title>Webpack App</title>
 </head>
 <body>
 <script src="bundle.js"></script>
 </body>
</html>

其他配置參數(shù):

{
 entry: 'index.js',
 output: {
 path: 'dist',
 filename: 'bundle.js'
 },
 plugins: [
 new HtmlWebpackPlugin({
  title: 'My App',
  filename: 'admin.html',
  template:'header.html',
  inject: 'body',
  favicon:'./images/favico.ico',
  minify:true,
  hash:true,
  cache:false,
  showErrors:false,
  "chunks": {
  "head": {
  "entry": "assets/head_bundle.js",
  "css": [ "main.css" ]
  },
  xhtml:false
 })
 ]
}
--- header.html ---
<!DOCTYPE html>
<html>
 <head>
 <meta http-equiv="Content-type" content="text/html; charset=utf-8"/>
 <title><%= htmlWebpackPlugin.options.title %></title>
 </head>
 <body>
 </body>
</html>

作用:

  1. title: 設置title的名字  
  2. filename: 設置這個html的文件名  
  3. template:要使用的模塊的路徑 
  4. inject: 把模板注入到哪個標簽后 'body',  
  5. favicon: 給html添加一個favicon  './images/favico.ico',  
  6. minify:是否壓縮  {...} | false (最新api變動,原來是ture|false 感謝@onmi指正)
  7. hash:是否hash化 true false ,    
  8. cache:是否緩存,  
  9. showErrors:是否顯示錯誤, 
  10. chunks:目前沒太明白 
  11. xhtml:是否自動畢業(yè)標簽 默認false 

3. 提取樣式插件

extract-text-webpack-plugin

官網是這么解釋的Extract text from bundle into a file.,把額外的數(shù)據加到編譯好的文件中

var ExtractTextPlugin = require("extract-text-webpack-plugin");
module.exports = {
 module: {
  loaders: [
   { test: /\.css$/, loader: ExtractTextPlugin.extract("style-loader", "css-loader") }
  ]
 },
 plugins: [
  new HtmlWebpackPlugin({
    template: './src/public/index.html',
    inject: 'body'
   }),
  new ExtractTextPlugin("[name].[hash].css")
 ]
}

說明:將css放到index.html的body上面

4. 拷貝資源插件

copy-webpack-plugin

官方這樣解釋 Copy files and directories in webpack,在webpack中拷貝文件和文件夾

cnpm install --save-dev copy-webpack-plugin
new CopyWebpackPlugin([{
 from: __dirname + '/src/public'
}]),

作用:把public 里面的內容全部拷貝到編譯目錄

參數(shù)作用其他說明
from定義要拷貝的源目錄from: __dirname + '/src/public'
to定義要烤盤膛的目標目錄from: __dirname + '/dist'
toTypefile 或者 dir可選,默認是文件
force強制覆蓋先前的插件可選 默認false
context不知道作用可選 默認 base context 可用 specific context
flatten只拷貝文件不管文件夾默認是false
ignore忽略拷貝指定的文件可以用模糊匹配

5. 全局掛載插件

webpack.ProvidePlugin [webpack內置插件 ]

new webpack.ProvidePlugin({
 $: "jquery",
 jQuery: "jquery",
 "window.jQuery": "jquery"
}))
new webpack.NoErrorsPlugin(),
new webpack.optimize.DedupePlugin(),
new webpack.optimize.UglifyJsPlugin(),
new webpack.optimize.CommonsChunkPlugin('common.js')

作用: 和上面5個一一對應

  1.   當模塊使用這些變量的時候,wepback會自動加載。(區(qū)別于window掛載,感謝@lihuanghe121指正)
  2.   不顯示錯誤插件
  3.   查找相等或近似的模塊,避免在最終生成的文件中出現(xiàn)重復的模塊
  4.   丑化js 混淆代碼而用
  5.   提取公共代碼的插件

二、一個完整的栗子

'use strict';

// Modules
var webpack = require('webpack');
var autoprefixer = require('autoprefixer');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var CopyWebpackPlugin = require('copy-webpack-plugin');

/**
 * Env
 * Get npm lifecycle event to identify the environment
 */
var ENV = process.env.npm_lifecycle_event;
var isTest = ENV === 'test' || ENV === 'test-watch';
var isProd = ENV === 'build';

module.exports = function makeWebpackConfig() {
 var config = {};

 config.entry = isTest ? {} : {
  app: './src/app/app.js'
 };

 config.output = isTest ? {} : {
  // Absolute output directory
  path: __dirname + '/dist',

  publicPath: isProd ? '/' : 'http://localhost:8080/',

  filename: isProd ? '[name].[hash].js' : '[name].bundle.js',

  chunkFilename: isProd ? '[name].[hash].js' : '[name].bundle.js'
 };

 if (isTest) {
  config.devtool = 'inline-source-map';
 } else if (isProd) {
  config.devtool = 'source-map';
 } else {
  config.devtool = 'eval-source-map';
 }

 config.module = {
  preLoaders: [],
  loaders: [{
   test: /\.js$/,
   loader: 'babel',
   exclude: /node_modules/
  }, {
   test: /\.css/,
   loader: isTest ? 'null' : ExtractTextPlugin.extract('style', 'css?sourceMap!postcss')
  }, {
   test: /\.(png|jpg|jpeg|gif|svg|woff|woff2|ttf|eot)$/,
   loader: 'file'
  }, {
   test: /\.json$/,
   loader: 'json'
  }, {
   test: /\.scss/,
   loader: 'style!css!sass'
  }, {
   test: /\.html$/,
   loader: 'raw'
  }]
 };
 if (isTest) {
  config.module.preLoaders.push({
   test: /\.js$/,
   exclude: [
    /node_modules/,
    /\.spec\.js$/
   ],
   loader: 'isparta-instrumenter'
  })
 }

 config.postcss = [
  autoprefixer({
   browsers: ['last 2 version']
  })
 ];

 config.plugins = [];
 if (!isTest) {
  config.plugins.push(
   new HtmlWebpackPlugin({
    template: './src/public/index.html',
    inject: 'body'
   }),

   new ExtractTextPlugin('[name].[hash].css', {disable: !isProd})
  )
 }

 if (isProd) {
  config.plugins.push(
   new webpack.NoErrorsPlugin(),

   new webpack.optimize.DedupePlugin(),

   new webpack.optimize.UglifyJsPlugin(),

   new CopyWebpackPlugin([{
    from: __dirname + '/src/public'
   }]),
   new webpack.ProvidePlugin({
    $: "jquery",
    jQuery: "jquery",
    "window.jQuery": "jquery"
   }))
 }

 config.devServer = {
  contentBase: './src/public',
  stats: 'minimal'
 };

 return config;
}();

三、調試技巧

if (isTest) {
 config.devtool = 'inline-source-map';
}

作用: 使用source-map可以在debug的時候看到源代碼,方便 查錯

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

分享題目:詳解webpack進階之插件篇
鏈接分享:http://aaarwkj.com/article34/gjgope.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供用戶體驗、服務器托管、網站設計、網站改版、網站策劃、域名注冊

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網站建設
久久国产欧美日韩精品| 亚洲最大av免费在线看| 大神厕所偷拍美女尿尿| 人妻免费精品久久一区| 久久久国产精品久久久| 久激情内射婷内射蜜桃| 精品人妻一区二区三区四| 91亚洲自偷观看高清| 97视频在线观看免费| 国产亚洲精品久久久闺蜜| 亚洲毛片在线免费播放| 在线成人影院中文字幕| 亚洲成人黄色片在线观看| 亚洲精品一品区二品区三| 中文字幕乱码视频日本| 日本免费一区中文字幕| 国产又大又长又粗又硬又猛| 国产男女猛进猛出精品91| 欧美一区二区成人精品视频| 女人天堂网av免费看| 中文字幕国产精品欧美| av在线中文字幕乱码| 黑丝美女国产精品久久久| 1区2区3区精品视频| 国产91对白在线观看| 99久久精品免费国产一区| 亚洲乱码在线中文字幕| 国产精品国产自产拍高清| 欧美一区二区三区爽| 四虎永久精品在线视频| 日本午夜理论视频在线播放| 欧美日韩久久亚洲精品| 九九九热精品视频在线观看| 亚洲香蕉视频免费在线观看| 日本免费熟女一区二区| 成人黄色大片免费看| 亚洲国产精品久久久久久99| 精品国产乱码久久蜜桃| 欧美日韩福利视频在线| 亚洲黄色片大奶子水多| 清纯唯美亚洲自拍第一页|