当前位置: 首页 > news >正文

webpack - 单独打包指定JS文件(因为不确定打出的前端包所访问的后端IP,需要对项目中IP配置文件单独拿出来,方便运维部署的时候对IP做修改)

介绍

因为不确定打出的前端包所访问的后端IP,需要对项目中IP配置文件单独拿出来,方便运维部署的时候对IP做修改。

因此,需要用webpack单独打包指定文件。

CommonsChunkPlugin

module.exports={entry:{app:APP_FILE// 入口文件},output:{publicPath:'./dist/',//输出目录,index.html寻找资源的地址path:BUILD_PATH,// 打包目录filename:'[name].[chunkhash].js',// 输出文件名chunkFilename:'[name].[chunkhash].js'// commonChunk 输出文件}}

先说一下publicPath , 这边有一个注意的点,即路径写成 ./dist 相对路径。如果写成/dist/这种绝对路径,有一个弊端是当nginx把前端的包没有放在根目录的情况下,index.html会访问资源失败。

因此推荐写成相对路径,但是当使用相对路径时,有会存在一个潜在的问题,即项目本身的路由访问如果是HTML5模式,而不是使用hash时(路由上有一个#号),那么项目一样会部署失败。

angular,react都会有这样的问题,vue没用过,应该类似。此时的解决办法是,在index.html的head中添加base标签,即:

<head><metacharset="utf-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"/><basehref="/"></head>

webpack本身基于模块化,因此大多数情况下,我们仅需要一个入口文件就可以搞定。而针对本次需求,需要在app,这个入口之外再添加一个入口文件。即:

entry:{app:APP_FILE// 入口文件ip:IP_FILE},

仅这样对webpack配置之后,dist文件会成功打出app.xxx.js及ip.xxx.js,但是打包出的项目还是会报错,解决办法是:维持IP的入口文件不变,但是把它当作commonChunk来处理。即在plugins中加入:

newwebpack.optimize.CommonsChunkPlugin({name:'ip',minChunks:Infinity}),

这样保证优先加载ip.xxx.js,避免报错。

缺点:这样打包有一个很明显的缺点,即是打包出的文件是压缩的,不方便对文件进行二次修改。(没有找到解决压缩的办法)

CopyWebpackPlugin

最终解决办法,还是通过让ip.js这个文件脱离项目的模块化,然后在index.html中单独引用。(这是最开始就想到的解决办法,但并不是自己想要的解决方案,但无奈认知有限,没有解决掉之前的问题)。

解决流程:
首先在webpack引入CopyWebpackPlugin , 配置代码:

newCopyWebpackPlugin([{from:'./src/config/ip.js',to:'ip.js'},])

在index.html中单独引入script标签,注意要配置一个随机后缀,即:

<script>document.write("<s"+"cript type='text/javascript' src='./dist/ip.js?"+Math.random().toString(36).substr(2)+"'></scr"+"ipt>");</script>

防止ip.js因为缓存导致问题。

以上,就解决了webpack单独打包指定js的问题。

http://www.jsqmd.com/news/323316/

相关文章:

  • python_django微信小程序的社区团购系统
  • Kafka 消息分区机制在大数据中的应用
  • webpack - webpack 提取 css 成单独文件、css 兼容性处理、压缩 css 等详细教程操作(示例解析 webpack 提取 css 为单独文件)
  • rustdesk自建服务器
  • 现代AI系统的六大完整技术体系概览
  • 提示管理平台架构设计:如何实现提示的自动化编排?
  • 动物粪便标本如何长期保存?中国科学院成都生物研究所研究团队提出一种可实现粪便形态、遗传信息及相关分析要素长期保存的标准化制备方法
  • shell实现根据输入的文字打印出大号字符艺术
  • Typescript - interface 关键字(通俗易懂的详细教程)
  • AI测试领域2025年度大事件盘点:标准确立、技术跃迁与市场领航
  • FoundIR: Unleashing Million-scale Training Data to Advance Foundation Models-ICCV2025
  • 魔法登录antigravity
  • Typescript - 类型守卫(typeof / in / instanceof / 自定义类型保护的类型谓词)通俗易懂详细教程
  • python_django基于微信小程序的移动医院挂号预约系统
  • 接口(集成)平台设计(一)-服务,接口,数据集和数据源
  • python_django基于微信小程序的竞赛报名系统_13348
  • 权威测评|微信小程序公司 TOP 名单,教你锁定适配服务商
  • python_django基于微信小程序的自习室座位预约付费打卡系统
  • 小程序 SaaS 制作平台超全攻略,找对适配伙伴赋能创业
  • python_django基于微信小程序的服装商城销售管理平台
  • 严选国内优质微信小程序开发公司:适配各类生意场景
  • python_django基于微信小程序的校园店铺商城电子商务系统
  • 一文吃透 Spring 生态核心:IoC/DI 原理、Bean 管理与实战指南
  • python_django基于微信小程序的班级学生作业管理助手
  • 单调队列优化dp
  • python_django个性化推荐小学生古诗词情景化学习小程序
  • 本地餐饮外卖专属:小程序开发公司甄选,生意高效跑通技巧
  • Windows CMD文件编辑器:从内置工具到第三方方案
  • 2026程序员转行AI大模型全攻略:后端开发轻松转型大模型应用开发,零基础突围路线图!非常详细建议收藏!
  • 从传统BI到大数据多维分析的迁移路径