webpack打包之 copy-webpack-plugin

copy-webpack-plugin 打包复制文件插件。

1、什么时候要使用?

在离线应用中,前端所有文件都需在在本地,有些文件(比如iconFont以及一些静态img)需要转为离线文件,这些文件可以直接引用更方便些,这就需要在打包时直接复制到打包文件下。

2、安装依赖

javascript 复制代码
npm i copy-webpack-plugin --save-dev

3、配置webpack

javascript 复制代码
const compressionPlugin = require('compression-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const path = require("path");
module.exports = {
    devServer: {
        //开发环境的跨域问题解决,后端服务ip 和 端口
        proxy: {
            '/eom': {
                target: 'http://127.0.0.1:7000',
                changeOrigin: true
            },
            '/pangu': {
                target: 'http://127.0.0.1:7000',
                changeOrigin: true
            },
            /**调用字典配置 */
            'pangu/eom/asset': {
                target: 'http://127.0.0.1:9003',
                changeOrigin: true,
                pathRewrite: {
                    '^/pangu/eom/asset': '/eom/asset'
                }
            }
        }
    },

    pages: {
        index: {
            // page 的入口
            entry: 'src/TdPluginEomServiceMain.js',
            // 模板来源
            template: 'public/index.html',
            // 输出文件名
            filename: 'index.html'
        }
    },
    publicPath: './',
    assetsDir: './eom',
    lintOnSave: false,
    productionSourceMap: false, //打包加密
    filenameHashing: process.env.NODE_ENV === 'production' ? false : true,
    configureWebpack: () => {
        if (process.env.NODE_ENV === 'production') {
            return {
                plugins: [
                    new compressionPlugin({
                        test: /\.js$|\.html$|\.css/,
                        threshold: 10240,
                        deleteOriginalAssets: false
                    }),
                    new CopyWebpackPlugin([{
                        from: path.resolve(__dirname, './src/static'),  //文件资源路径
                        to: path.resolve(__dirname, './dist/eom/assets'),//复制文件要到的目的路径
                        ignore: ['.*']
                    }]) //打包静态资源

                ],
                output: {
                    jsonpFunction: 'TdPluginEomServiceMain'
                }
            };
        }
    }
};

4、打包

相关推荐
前端互助会23 分钟前
Live2D形象展示与文本语音播报:打造生动交互体验的完整实现
前端·vue.js·microsoft·交互
努力的小郑2 小时前
今晚Cloudflare一哆嗦,我的加班计划全泡汤
前端·后端·程序员
q***64973 小时前
头歌答案--爬虫实战
java·前端·爬虫
凌波粒3 小时前
SpringMVC基础教程(4)--Ajax/拦截器/文件上传和下载
java·前端·spring·ajax
液态不合群4 小时前
DDD驱动低代码开发:从业务流程到领域模型的全链路设计
前端·低代码·架构·ddd
jonyleek4 小时前
JVS低代码开发中,如何创建自定义前端页面并接入到现有系统中,从创建到接入的全攻略
前端·低代码·前端框架·软件开发
谢尔登4 小时前
【React】React组件的渲染过程分为哪几个阶段?
前端·javascript·react.js
MediaTea4 小时前
Python 第三方库:Flask(轻量级 Web 框架)
开发语言·前端·后端·python·flask
5***o5004 小时前
前端构建工具缓存清理,解决依赖问题
前端·缓存
lcc1875 小时前
Vue Vue与VueComponent的关系
前端·vue.js