浅谈前端开发中的版本管理(前端版本管理工具)
off999 2024-11-05 10:56 35 浏览 0 评论
软件开发和发布过程中,版本是个极其重要的因素。大至操作系统,小到功能组件,都会涉及到版本相关的问题。
本文主要讨论了静态资源的版本管理,以及前端开发使用npm之后npm包管理的相关内容。
静态资源
浏览器缓存在减少资源请求、加快页面载入速度的同时,也给开发者带来新的问题:新发布的资源因为缓存问题而无法被成功载入。
在此情况下,轻会导致新的功能无法展示,重可能会因为资源不兼容导致页面报错、功能无法使用。为了解决这一类的问题,开发者往往会在静态资源信息中添加版本信息。
版本号的来源
每次发布都不一样的值即可作为版本号来源,所以版本号可以自定义并且手工维护,也可以是发布时的时间戳的md5的值,或是通过各类工具自动生成的值。
自定义版本号:自定义的版本号简洁明了,能够清楚地知道版本的信息,但是弊端在于,需要手工的去维护版本信息。
自动生成的版本号:将时间戳、动态hash等自动生成的信息作为版本号也是比较常见的方法。在打包脚本中配置好相关信息之后,不再需要额外的干预即可自动生成版本信息。
通过webpack打包静态资源文件属于比较常见的做法,webpack中的hash/chunkhash/contenthash实现的版本号即属于自动生成的版本信息,通过适当配置,能够实现每个文件都带有不同的版本信息。
其中hash在webpack编译时动态生成,所以如果通过hash去命名资源文件,所有生成的静态文件会共享同一个hash。chunkhash是根据chunk内容生成hash,所以chunkhash够实现不同文件不同hash的目标。然而contenthash,一般只用于ExtractTextPlugin中,如打包css文件并且添加contenthash等。
chunkhash打包js代码的问题在于,如果js文件中引用了css模块,每次css模块修改而js本身不做修改的情况下,js文件对应的chunkhash也会被修改,原因在于默认的chunkhash将引入的css代码也视为该chunk的一部分,不论是更新js代码还是css代码,都会导致chunkhash的更新。webpack打包时,可以尝试引入webpack-md5-hash解决chunkhash的问题。
版本信息的位置
对于静态资源来说,版本信息一般可以追加到路径、资源名称或者查询参数中。
资源路径:对于大部分的静态文件服务器来说,资源的URI往往可以映射到服务器上的特定磁盘路径。基于版本号的请求路径,可以在文件系统中创建以版本号命名的目录,并且拷贝静态资源到该目录中。
这样做带来的好处在于,每个版本都是单独的目录,版本间做到互不影响。弊端也显而易见:部分没有改变的静态资源也会因为路径名的变换而无法实现缓存。
资源名称:将版本信息添加到文件名上意味着打包过程中,需要重命名静态资源文件,但是不需要创建新的目录,所有的静态文件放在同一目录下。基于文件内容产生的hash作为文件名,能够做到内容不变的静态文件的请求URI也不会发生变化。
查询参数:jQuery disable cache之后,GET方式请求资源的时候会在路径中添加时间戳信息即属于这种。
将版本信息追加到查询参数中,与追加到资源名称中类似,不同的地方在于资源名称不会发生变化,可能会导致不同版本间的文件相互覆盖,所以需要在发布之前将当前已存在的资源做备份。
npm下的版本管理
npm在前端开发中使用的越来越多。
npm的版本管理是基于semver实现的,包的版本应该包含主版本号、次版本号和修订版本号。通过~, ^以及<、>等约定使用的版本范围。
不论是在npm2还是npm3中,同一个包的不同版本也能够被很好的兼容,不同版本的包会被安装到各自的路径之下,并且在require/import过程中调用特定版本的npm包。但其中也有一些例外,一些约定了peerDependencies的npm包,往往需要特定版本的兼容,并且这些版本是排他的,即出现其他版本时,npm install过程中会出现警告。
npm多层级的依赖关系可能会带来另外一个问题:只能将直接依赖的npm包写在package.json中,而无法约定这些依赖自身所依赖的包,也无法确定其中的版本信息。
为了固定整个依赖关系的版本信息,npm提供了npm shrinkwap的功能。npm shrinkwrap通过将完整的依赖版本信息输出到npm-shrinkwrap.json文件中。在此后的npm install过程中,npm会优先查找并且安装npm-shrinkwrap.json文件中的依赖内容。npm shrinkwrap应该项目起始阶段就应用到项目中,并且在新的依赖添加之后,不断更新。
本文作者:于心愿(点融黑帮),就职于点融网Social前端开发团队,在成为前端开发工程师之前,做过运维开发工程师。平时喜欢JavaScript、Python等,空暇时候喜欢打乒乓球。
本文由@点融黑帮(ID:DianrongMafia)原创发布于今日头条,未经许可,禁止转载。
相关推荐
- 改名字大全生辰八字免费(改名字大全生辰八字免费五行属火的字有哪些)
-
起名步骤:1、分析生辰八字命主五行、格局,找出用神喜忌。2、选出命局所喜用所需要的五行汉字。3、根据姓氏及辈分、时代特征、性别、八字数理合理搭配将要用的字,去其忌讳用字,避开凶数.取其字的意、形、象、...
- 主题字体免费(小猫の字体)
-
在搜索栏里面输入免费字体和主题就出来了1.阿里巴巴普惠体在其官方下载渠道上,明确声明:允许任何个人和企业免费使用,包括商用用途,但禁止用于违法用途。2.方正免费字体免费字体:方正黑体、方正书宋、方正仿...
- 迅雷输入法下载(迅雷输入法最新版本)
-
您好,不管是哪个输入法,都会收集用户的密码和个人资料以及隐私内容的,希望能帮到您,祝您生活愉快!迅雷输入是指在计算机领域中,将数据从一个地方快速、高效地传输到另一个地方的过程,通常用于下载文件、上传...
- 丝瓜app破解版无限次(丝瓜app破解版apk)
-
1、单个软件缓存数据过多。可进入设置--应用程序--全部--查找点击出现闪退的软件名称--清除数据后再使用试试。2、安装位置不合适(部分机型才有该功能))部分软件对手机安装位置有所要求,安装软件更好是...
-
- 免费英语学习网站(有什么免费学英语的网站)
-
现在网上的高中学习网站很多,像高中教育网校,简单学习网,新东方在线,学而思网校,中小学教育网等。各有利弊,选择适合自己的。并且能不能提高成绩,关键还是靠学生自己努力。我们来看下这些课堂总体特点:封闭课堂在听课过程中屏蔽了聊天、游戏等对学生听...
-
2026-01-18 09:03 off999
-
- 在线铃声下载 免费下载(手机铃声制作app下载)
-
移动那叫“彩铃”,联通那叫“炫铃”,电信那叫“悦铃(可能不对)”总之,这些都是由运营商提供的,有的是免费有的是付费,需要订购。也就是需要你手机发指令或到网上营业厅或直接到柜台办理,然后在设置里设置指定某电话听到的回铃音是什么音乐(这个设置是...
-
2026-01-18 08:51 off999
- 种子搜索神器在线搜索(种子搜索神器在线搜索下载)
-
01.磁力熊磁力熊,是一个内容丰富、功能最为强大的一个磁力搜索网站,通过它不仅仅可以搜索到大量纯净的1080P高分电影,像一些比较小众的影视剧这里也都能找到。02.夕阳小站夕阳小站,虽然网站整体界面设...
-
- 模拟炒股软件app排名(模拟炒股软件app排名榜)
-
同花顺、云掌财经、东方财富网、大智慧同花顺是股民使用比较多的软件了,实时的行情更新,数据分析,模拟炒股都是同花顺的有点所在,在炒股软件使用中占有率非常高。自定义设置的8个板块等按快捷代码查看相当方便(一键查看自选股)。炒股入门首选。大智慧也...
-
2026-01-18 08:03 off999
- oa办公系统功能介绍(oa办公系统都有哪些)
-
以下是一些可能包含在OA办公系统中的常见功能:1.通讯录管理:包括添加、编辑和删除联系人信息,可按部门、职位等分类浏览联系人。2.日程管理:提供个人和团队日程安排功能,可创建、编辑和共享日程,设置...
- 绝地求生(国际服)下载官方(绝地求生国际服下载安装免费正版)
-
首先需要安装和登录Steam(一个游戏平台);然后在Steam搜索"playerunknown'sbattlegrounds"并选择购买;下载并安装游戏,选择要加入的Serv...
- 麻花影视下载(麻花影视下载官方破解版)
-
被人举报了,然后关掉了国内的服务器,现在国内用的都是海外服务器而且用的人太多了所以卡
- 诺基亚n72(诺基亚n72上市时间价格多少)
-
n72是N系列中唯一一款不支持3G的智能机,还有N70。另外说说N72的十大缺点:1、电池待机时间较短,键盘较小,按键不方便2、嘈杂状态下铃声及振动较小,通话声音也较小3、短信书写中没有常用的网络符号...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
Python 批量卸载关联包 pip-autoremove
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
