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

資訊專欄INFORMATION COLUMN

[js高手之路]深入淺出webpack教程系列5-插件使用之html-webpack-plugin配

lentoo / 2127人閱讀

摘要:上文我們講到了的配置和獲取數(shù)據(jù)的方式,本文,我們繼續(xù)深入的配置一插件中的除了自己定義了一些基本配置外,我們是可以任意的添加自定義的數(shù)據(jù)文件,就是當(dāng)前文件所在的絕對路徑輸出路徑,要用絕對路徑打包之后輸出的文件名教你學(xué)我們在中新增了個

上文我們講到了options的配置和獲取數(shù)據(jù)的方式,本文,我們繼續(xù)深入options的配置

一、html-webpack-plugin插件中的options除了自己定義了一些基本配置外,我們是可以任意的添加自定義的數(shù)據(jù)

webpack.dev.config.js文件:

var HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = {

entry : {
    main : "./src/js/main.js",
    calc : "./src/js/calc.js"
},
output : {
    //__dirname,就是當(dāng)前webpack.config.js文件所在的絕對路徑
    path : __dirname + "/dist", //輸出路徑,要用絕對路徑
    filename : "js/[name]-[hash].bundle.js" //打包之后輸出的文件名
},
plugins: [
    new HtmlWebpackPlugin({
        template : "./index.html",
        title : "ghostwu教你學(xué)webpack",
        inject : true,
        date : new Date(),
        userName : "ghostwu",
        age : 22
    })
]

};

我們在webpack.dev.config.js中新增了3個自定義數(shù)據(jù)( date,userName, age),我們在demo2目錄下面的index.html模板中可以這樣讀取

1

<%= htmlWebpackPlugin.options.date %>


2

<%= htmlWebpackPlugin.options.userName %>


3

<%= htmlWebpackPlugin.options.age %>

同樣設(shè)置好了之后,記得( npm run d )重新打包生成.

二、完整的把htmlWebpackPlugin這個實例在模板中遍歷出來

demo2下面的index.html文件:




    
    
    
    <%= htmlWebpackPlugin.options.title %>

    

<%= htmlWebpackPlugin.options.date %>

<%= htmlWebpackPlugin.options.userName %>

<%= htmlWebpackPlugin.options.age %>

    <% for ( var key in htmlWebpackPlugin ){ %> <% if ( key == "files" ) { %>

    files

    <% for( var f in htmlWebpackPlugin[key] ){ %>
  • <%= f %>, <%= htmlWebpackPlugin[key][f] %>
  • <% if ( f == "chunks") { %>

    <%= JSON.stringify( htmlWebpackPlugin[key][f] ) %>

    <% } %> <% } %> <% } else { %>

    options

    <% for( var f in htmlWebpackPlugin[key] ){ %>
  • <%= f %>, <%= htmlWebpackPlugin[key][f] %>
  • <% } %> <% } %> <% } %>

三,通過上面打印的數(shù)據(jù),我們可以自己手動指定js文件的引入,不需要自動inject

webpack.dev.config.js文件

var HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = {
    entry : {
        main : "./src/js/main.js",
        calc : "./src/js/calc.js"
    },
    output : {
        //__dirname,就是當(dāng)前webpack.config.js文件所在的絕對路徑
        path : __dirname + "/dist", //輸出路徑,要用絕對路徑
        filename : "js/[name]-[hash].bundle.js" //打包之后輸出的文件名
    },
    plugins: [
        new HtmlWebpackPlugin({
            template : "./index.html",
            title : "ghostwu教你學(xué)webpack",
            inject : false
        })
    ]
};

inject設(shè)置為false, js不會自動注入到打包之后的文件dist/index.html,所以我們就要自動指定加載的js文件.

demo2/index.html文件代碼:




    
    
    
    <%= htmlWebpackPlugin.options.title %>
    

    


執(zhí)行打包命令( npm run d ),在dist目錄下生成的index.html文件,源代碼就變成我們手動注入的js文件了

四、minify選項,壓縮html文件

他可以配置很多的值,官方參考地址:https://github.com/kangax/htm...

var HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = {
    entry : {
        main : "./src/js/main.js",
        calc : "./src/js/calc.js"
    },
    output : {
        //__dirname,就是當(dāng)前webpack.config.js文件所在的絕對路徑
        path : __dirname + "/dist", //輸出路徑,要用絕對路徑
        filename : "js/[name]-[hash].bundle.js", //打包之后輸出的文件名
    },
    plugins: [
        new HtmlWebpackPlugin({
            template : "./index.html",
            title : "ghostwu教你學(xué)webpack",
            inject : false,
            minify : {
                removeComments : true, //去掉注釋
                collapseWhitespace : true, //去掉空行
            }
        })
    ]
};

這里,我們配置了兩種常用的壓縮選項( 去掉注釋,去掉空行),那么打包生成的index.html文件,就會變成壓縮版(比如你看到的jquery.min.js這樣的文件,都是經(jīng)過壓縮處理的)

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

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

相關(guān)文章

  • [js高手]深入淺出webpack教程系列4-插件使用html-webpack-plugin

    摘要:還記得我們上文中的文件嗎那里面的標(biāo)簽還是寫死的文件,那么怎么把他們變成動態(tài)的文件,這個動態(tài)生成的文件會動態(tài)引入我們打包后生成的文件呢,我們可以使用插件,首先安裝這個插件,好的,接下來就開始用這個插件了官方參考文檔插件通用用法 還記得我們上文中的index.html文件嗎? 那里面的script標(biāo)簽還是寫死的index.bundle.js文件,那么怎么把他們變成動態(tài)的index.html...

    qpal 評論0 收藏0
  • [js高手]深入淺出webpack教程系列6-插件使用html-webpack-plugin

    摘要:上文我們對的實例進行了遍歷分析,講解了幾個常用屬性以及自定義屬性的添加,本文,我們繼續(xù)深入他的配置選項的探討一選項這個屬性非常有用,可以指定某個頁面加載哪些如文件我們可以用他做多個頁面模板的生成比如,我們在實際開發(fā)中,做一個博客網(wǎng)站,一 上文我們對html-webpack-plugin的實例htmlWebpackPlugin進行了遍歷分析,講解了幾個常用屬性( inject, mini...

    jokester 評論0 收藏0
  • [js高手]深入淺出webpack教程系列1-安裝與基本打包用法和命令參數(shù)

    摘要:,我想大家應(yīng)該都知道或者聽過,是前端一個工具可以讓各個模塊進行加載預(yù)處理再進行打包。 webpack,我想大家應(yīng)該都知道或者聽過,Webpack是前端一個工具,可以讓各個模塊進行加載,預(yù)處理,再進行打包?,F(xiàn)代的前端開發(fā)很多環(huán)境都依賴webpack構(gòu)建,比如vue官方就推薦使用webpack.廢話不多說,我們趕緊開始吧. 第一步、安裝webpack 新建文件夾webpack->再在web...

    pubdreamcc 評論0 收藏0
  • [js高手]深入淺出webpack教程系列2-置文件webpack.config.js詳解(上

    摘要:接著上文,重新在文件夾下面新建一個項目文件夾,然后用初始化項目的配置文件,然后安裝,然后創(chuàng)建基本的項目文件夾結(jié)構(gòu),好了,我們的又一個基本項目結(jié)構(gòu)就搭建好了第一開始通過文件配置我們的項目首先在項目文件夾下面,新建一個文件,這個文件可 接著上文,重新在webpack文件夾下面新建一個項目文件夾demo2,然后用npm init --yes初始化項目的package.json配置文件,然后安...

    moven_j 評論0 收藏0
  • [js高手]深入淺出webpack教程系列3-置文件webpack.config.js詳解(下

    摘要:本文繼續(xù)接著上文,繼續(xù)寫下的其他配置用法一把兩個文件打包成一個,怎么配置在上文中的中,用數(shù)組配置文件代碼,就是當(dāng)前文件所在的絕對路徑輸出路徑,要用絕對路徑打包之后輸出的文件名然后在目錄下面新建一個文件,代碼如下之前的文件的代碼告訴你怎么學(xué)習(xí) 本文繼續(xù)接著上文,繼續(xù)寫下webpack.config.js的其他配置用法. 一、把兩個文件打包成一個,entry怎么配置? 在上文中的webpa...

    xiangchaobin 評論0 收藏0

發(fā)表評論

0條評論

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