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

資訊專欄INFORMATION COLUMN

使用webpack打包多頁jquery項目

wuyangnju / 3366人閱讀

摘要:雖然已經(jīng)年了不過有一些項目還是需要用到的不過考慮到使用的一堆兼容性問題也為了可以順利地使用來擼代碼研究使用打包代碼來發(fā)布幾個重點為了將模塊分割加載,不至于一個文件過大,一個頁面中使用多個文件由于是多頁項目多個,每個頁面使用的文件都不一致基于

雖然已經(jīng)2019年了
不過有一些項目
還是需要用到j(luò)query的
不過考慮到使用jquery的一堆兼容性問題
也為了可以順利地使用ES6來擼代碼
研究使用webpack+babel打包代碼來發(fā)布

幾個重點:
1.為了將模塊分割加載,不至于一個js文件過大,一個頁面中使用多個js文件
2.由于是多頁項目(多個html),每個頁面使用的js文件都不一致
基于以上兩點,需要配置多個入口文件
3.會把小圖片轉(zhuǎn)換成base64,所以可能css轉(zhuǎn)成的js文件會比較大,所以css文件都多帶帶設(shè)置入口js

例如,我們有三個頁面:index、share、assist
三個頁面有通用的css文件:common.css
設(shè)置入口文件時,可以這樣設(shè)置

entry: {
    // 通用css
    commoncss: path.resolve(__dirname, "./src/css/common.css.js"),

    // 主頁
    indexcss: path.resolve(__dirname, "./src/css/index.css.js"),
    index: path.resolve(__dirname, "./src/index.js"),

    // 頁1
    sharecss: path.resolve(__dirname, "./src/css/share.css.js"),
    share: path.resolve(__dirname, "./src/share.js"),

    // 頁2
    assistcss: path.resolve(__dirname, "./src/css/assist.css.js"),
    assist: path.resolve(__dirname, "./src/assist.js"),

}

其中,common.css.js文件中,只有幾行代碼

import "../css/base.css";
import "../css/plugin.css";
import "../css/common.css";

common.css.js文件結(jié)束
由于會有一些圖片的base64,所以大小大約100+KB

類似的還有index.css.js和share.css.js和assist.css.js
index.css.js如下

import "../css/index.css";

對,就一句話
打包出來的js文件大小就看引入了多少小圖片了,一般幾百KB

然后,要使用三個webpack的插件

const HtmlWebpackPlugin = require("html-webpack-plugin");
const CopyWebpackPlugin = require("copy-webpack-plugin");
const jquery = require("jquery");

HtmlWebpackPlugin 用于打包出多個html文件
CopyWebpackPlugin 用于img標簽,后面說
jquery 就是jquery,全局引用

webpack.config.js里的plugins配置如下

plugins: [
    new webpack.ProvidePlugin({
        $:"jquery"
    }),
    new CopyWebpackPlugin([{
        from: __dirname + "/src/public/"
    }]), // 吧src下public文件夾下的所有內(nèi)容直接拷貝到dist(輸出目錄)下
    new HtmlWebpackPlugin({
        filename: "index.htm",
        template: "src/index.html",
        chunks: ["commoncss", "indexcss", "index"],
        inject: "true",
        hash: true,
    }),
    new HtmlWebpackPlugin({
        filename: "share.htm",
        template: "src/share.html",
        chunks: ["commoncss", "sharecss", "share"],
        inject: "true",
        hash: true,
    }),
    new HtmlWebpackPlugin({
        filename: "assist.htm",
        template: "src/assist.html",
        chunks: ["commoncss", "assistcss", "assist"],
        inject: "true",
        hash: true,
    })
]

src目錄下的文件如下

index.js assist.js share.js是三個文件分別的入口文件
index.html assist.html share.html是三個文件的模板,html代碼可以寫在這里
(當然想用模板文件也是可以的,只要HtmlWebpackPlugin插件支持)

dist文件夾如下


(為什么是htm而不是html,是為了便于讀者區(qū)分模板文件和輸出文件)

我們知道,webpack打包不會打包HtmlWebpackPlugin的template里的img標簽下的圖片,所以在html里使用了img標簽的圖片都要放在public文件夾下,CopyWebpackPlugin這個組件會直接把圖片復制過去

關(guān)于HtmlWebpackPlugin的具體參數(shù)的細則可以上網(wǎng)搜一下,很多這方面的內(nèi)容
其他的比如loader、babel不在這篇文章想說的重點之列,不贅述

最后,附上webpack.config.js文件

    let actName = "yourProjectName";// 
    let actKV = {
        name: actName,
        entry: {
            // 通用css
            commoncss: path.resolve(__dirname, "./src/css/common.css.js"),

            // 主頁
            indexcss: path.resolve(__dirname, "./src/css/index.css.js"),
            index: path.resolve(__dirname, "./src/index.js"),

            // 分享頁1
            sharecss: path.resolve(__dirname, "./src/css/share.css.js"),
            share: path.resolve(__dirname, "./src/share.js"),

            // 分享頁2
            assistcss: path.resolve(__dirname, "./src/css/assist.css.js"),
            assist: path.resolve(__dirname, "./src/assist.js"),

        }
    };
    

    return {
        entry: actKV.entry,
        target: "web",
        output: {
            path: path.resolve(__dirname + "/dist/"+actName),
            // publicPath: ".",
            filename: "js/[name].js",
            // chunkFilename: "[name].chunk.[hash].js",
        },
        plugins: [
            new webpack.ProvidePlugin({
                $:"jquery"
            }),
            new CopyWebpackPlugin([{
                from: __dirname + "/src/public/"
            }]),
            new HtmlWebpackPlugin({
                filename: "index.htm",
                template: "src/index.html",
                chunks: ["commoncss", "indexcss", "index"],
                inject: "true",
                hash: true,
            }),
            new HtmlWebpackPlugin({
                filename: "share.htm",
                template: "src/share.html",
                chunks: ["commoncss", "sharecss", "share"],
                inject: "true",
                hash: true,
            }),
            new HtmlWebpackPlugin({
                filename: "assist.htm",
                template: "src/assist.html",
                chunks: ["commoncss", "assistcss", "assist"],
                inject: "true",
                hash: true,
            })
        ],
        mode: "development",
        node: {
            __filename: true,
            __dirname: true
        },
        devtool: isProduction ? "source-map":"inline-source-map",
        devServer:{
            inline: true,
            open: true, 
            historyApiFallback: true, 
            // host: ip.address(),
            host: "localhost",
            progress: true,
            contentBase: "./dist/",
            port: 3430,
            historyApiFallback:true,
            publicPath:"/src/",
            proxy: {
                "*": {
                    target: "http://127.0.0.1:3430",
                    secure: false
                }
            },
        },
        resolve: {
            alias: {
            },
            extensions: [".js", ".less", ".css", ".vue", ".jsx"],
        },
        externals: {
        },
        module: {
            rules: [{
                test: /.vue$/,
                loader: "vue-loader",
            }, {
                test: /.js$/,
                include: path.join(__dirname,"/src"),
                exclude: path.resolve(__dirname, "node_modules"),
                use:[
                    {
                        loader: "babel-loader",
                        query: {
                            presets: ["es2015"]
                        }
                    }
                ]
            }, {
                test: /.xml$/,
                loader: "xml-loader"
            }, {
                test: /.(css|less)$/,
                loader: "style-loader!css-loader",
            }, 
            {
                test: /.(png|jpg|jpeg|gif|icon|webp)$/,
                loader: "url-loader",
                options: {
                    limit: 16384,
                    name: "images/[name].[hash:5].[ext]",
                }
            },
            {
                test: /.(woff|woff2|svg|eot|ttf)??.*$/,
                loader: "file-loader?&name=assets/fonts/[name].[ext]"
            }, {
                test: /.txt$/,
                loader: "text-loader"
            },{
                test: /.jsx$/,
                exclude: /node_modules/,
                loaders: ["jsx-loader", "babel-loader"]
            }]
        },
        
    }

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

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

相關(guān)文章

  • webpack多頁應(yīng)用架構(gòu)系列(十一):預(yù)打包Dll,實現(xiàn)webpack音速編譯

    摘要:本文首發(fā)于的技術(shù)博客實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址如果您對本系列文章感興趣,歡迎關(guān)注訂閱這里前言書承上文多頁應(yīng)用架構(gòu)系列十如何打造一個自定義的。終于,發(fā)現(xiàn)了這一大殺器,打包時間過長的問題得到完美解決。 本文首發(fā)于Array_Huang的技術(shù)博客——實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址:https://segmentfault.com/a/119000000710437...

    sixleaves 評論0 收藏0
  • webpack多頁應(yīng)用架構(gòu)系列(四):老式jQuery插件還不能丟,怎么兼容?

    摘要:本文首發(fā)于的技術(shù)博客實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。怎么來兼容老式插件呢方法有不少,下面一個一個來看。與上述的方案相反,此方案是先用加載的滿足老式插件的需要,再通過將其轉(zhuǎn)換成符合模塊化要求的。 本文首發(fā)于Array_Huang的技術(shù)博客——實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址:https://segmentfault.com/a/1190000006887523如果您對本系列文...

    Chao 評論0 收藏0
  • webpack多頁應(yīng)用架構(gòu)系列(十):如何打造一個自定義的bootstrap

    摘要:我個人慣用的是,因此本文以為例來介紹如何打造一個自定義的。引入全局的方法請看我之前的這篇文章多頁應(yīng)用架構(gòu)系列四老式插件還不能丟,怎么兼容,我的腳手架項目也是使用的這套方案。 本文首發(fā)于Array_Huang的技術(shù)博客——實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址:https://segmentfault.com/a/1190000007043716如果您對本系列文章感興趣,歡迎關(guān)注訂閱...

    jindong 評論0 收藏0
  • 使用webpack打包多頁jquery項目

    摘要:雖然已經(jīng)年了不過有一些項目還是需要用到的不過考慮到使用的一堆兼容性問題也為了可以順利地使用來擼代碼研究使用打包代碼來發(fā)布幾個重點為了將模塊分割加載,不至于一個文件過大,一個頁面中使用多個文件由于是多頁項目多個,每個頁面使用的文件都不一致基于 雖然已經(jīng)2019年了不過有一些項目還是需要用到j(luò)query的不過考慮到使用jquery的一堆兼容性問題也為了可以順利地使用ES6來擼代碼研究使用w...

    darkerXi 評論0 收藏0
  • 使用webpack打包多頁jquery項目

    摘要:雖然已經(jīng)年了不過有一些項目還是需要用到的不過考慮到使用的一堆兼容性問題也為了可以順利地使用來擼代碼研究使用打包代碼來發(fā)布幾個重點為了將模塊分割加載,不至于一個文件過大,一個頁面中使用多個文件由于是多頁項目多個,每個頁面使用的文件都不一致基于 雖然已經(jīng)2019年了不過有一些項目還是需要用到j(luò)query的不過考慮到使用jquery的一堆兼容性問題也為了可以順利地使用ES6來擼代碼研究使用w...

    GitChat 評論0 收藏0

發(fā)表評論

0條評論

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