近日,npm 3.0 Beta版发布了,该版本几乎完全重写了安装器,为在Windows上使用Node.js的用户带来了利好消息。
Rebecca Turner 在发布声明中 说到 ,npm团队“很高兴且自豪地”发布了3.0 Beta版,并且“希望能与npm用户社区合作以便尽快发布生产版本”。
Turner是CLI程序员,负责几乎所有的变更,她说此次更新花费了大约8个月的时间。
npm最重要的变更之一就是依赖的更新。借助于水平依赖可以解决太多依赖导致Windows文件系统崩溃的问题,因为过深的路径会造成Explorer和其他标准工具无法处理的难题。
Turner说到:
现在,依赖将会尽可能按照水平方式进行安装,所有依赖,以及依赖的依赖都会安装到项目的node_modules目录中,并且不再嵌套。如果两个或多个模块的依赖存在冲突,那么模块之间才会出现嵌套的情况。
此次更新还意味着安装“从一开始”就是去重的,Git deps是去重的,甚至命令也是“去重”的。
Turner向InfoQ表示,作为一个用户,她觉得最激动人心之处就是自动去重的deps,这会“极大降低安装包的大小”。
其他命令的行为也会受到依赖更新的影响。在此次更新中,当使用 npm uninstall
命令进行模块卸载时,系统会删除该模块中不被其他模块需要的所有依赖,而过去则是删除安装在该模块下的依赖。值得注意的是,npm自身的依赖也是“水平、去重,且打包的”,因此npm 3.0无法由npm 2.0发布或打包。
安装器的其他一些变化还有改进了npm对于包的执行步骤。在之前的版本中,安装器在决定处理包时会立刻执行各项步骤。在3.0中,安装器会同时对所有包执行各项步骤,在继续之前会等待每一个阶段的完成。对于开发者来说,这么做可以消除很多竞态条件:让代码的编写变得更加轻松。
从实际使用的角度来看,Turner说此次更新意味着诸如生命周期脚本等将会变得更加可预测且出错的可能性更低,同时也能更加轻松地实现诸如新的 --dry-run
标志等特性。Turner说这会让开发者在执行之前就能看到将要发生的事情,同时详尽的日志会展示出安装器在进行改变前后的完整树形结构。
总而言之,Turner希望npm 3.0 Beta版能够减少Bug的出现,并且为开发者提供一个更加稳定的平台。
不出所料的是,npm 3.0 Beta版将会持续一段时间,直到团队“认为它已足够稳定,并且评估过它对社区造成的影响”之后才会发布正式版。Turner还指出,由于此次几乎是完全重写,因此还会存在一些Bug,该Beta版只能用于“每天使用的非关键的CI环境”,不能用于“产品维护或是持续部署”。
对于想要为npm贡献力量的InfoQ读者来说,方式有很多:常规的pull requests、Bug报告、文档与代码变更的特性请求等,这些都是npm所欢迎的,可以在其 问题追踪器 上进行。除了直接的贡献之外,npm团队也非常欢迎大家编写教程与文章,形式诸如“如何解决某个问题以及使用了哪些模块”,优秀的内容会被 npm Weekly 所引用。
查看英文原文: NPM 3 Beta Brings Good News for Windows Users