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

大气物流网站源码2021最近比较火的营销事件

大气物流网站源码,2021最近比较火的营销事件,网站开发 技术投标,工商信息查询​ pnpm,一个老牌的 node.js 包管理器,支持 npm 的所有功能,完全足以用来替代 npm。它采用全局存储,每个项目内部使用了硬链接,所以很省空间,安装速度快。 本文介绍下 pnpm 的基本概念,安装、…

pnpm,一个老牌的 node.js 包管理器,支持 npm 的所有功能,完全足以用来替代 npm。它采用全局存储,每个项目内部使用了硬链接,所以很省空间,安装速度快。

本文介绍下 pnpm 的基本概念,安装、卸载、使用,原理,可能遇到的问题及解决办法。

阅读本文需要一点前端基础,最好有过 Node 使用经历。

在 pnpm 出现之前…

和其他编程语言的包管理器不同,Node 会将安装的依赖放在每一个项目内。也就是说,如果你有两个项目,并且都用到了某个依赖,那么这个依赖会在两个项目内都下载一份。

这就导致有很多重复的依赖被下载,浪费了不少时间,占用了不少磁盘空间;当删除某个项目(哪怕是小项目)的时候,删除时间也会变得很长。

当然,换个角度想也可以算好处:

  • 对于设计 npm 的人来说,这是最省事的包依赖方法。就好比 Maven 安装依赖之后自动将 jar 包安装到项目的 lib 里面
  • 可以随意改代码。node_modules 里面的东西可以随便改,无需担心对其它项目的影响。

而 pnpm 将所有依赖存储在硬盘上的某一位置。当软件包被被安装时,包里的文件会硬链接到这一位置,而不会占用额外的磁盘空间,这允许我们跨项目地共享同一版本的依赖;安装时间也会快很多——因为对于已经有的依赖,不用再次下载。

简介

pnpm,全称 Performant npm,意思为“高性能的 npm”。pnpm 由 npm/yarn 衍生而来,解决了 npm/yarn 内部潜在的 bug,极大的优化了性能,扩展了使用场景,被誉为最先进的包管理工具。

官网(支持中文):https://pnpm.io

开源在 GitHub:https://github.com/pnpm/pnpm,目前已获 30k Star

特点:

  • 快速:比 npm 快了近 2 倍(可以参考官方的 测试结果)
  • 高效:node_modules 中的所有文件均克隆或硬链接自单一存储位置
  • 支持 monorepos(大型前端项目的代码管理方式)
  • 权限严格:默认创建了一个非平铺的 node_modules,因此代码无法访问任意包
  • 流行:数十家大公司都在用(微软,字节跳动,Shopee,Vue…)
  • 更多和 npm/yarn 的功能比较,可以参考官网的说明

安装

安装之前,最好先确定好安装什么版本的 pnpm,因为它并不兼容 Node.js 的所有版本。官方列出的表格:

Node.jspnpm 7pnpm 8pnpm 9
Node.js 12
Node.js 14✔️
Node.js 16✔️✔️
Node.js 18✔️✔️✔️
Node.js 20✔️✔️✔️

可以通过 node -v​ 来查看当前 node​ 版本,然后就可以安装了,支持多种安装方式(请参考 官方安装文档),这里列两个:

  • 通过 Node 安装:npm i -g pnpm
  • 通过 HomeBrew:brew install pnpm

注意:

  • 不能通过 cnpm,yarn 安装
  • 如果要指定版本,可以先通过 npm view pnpm versions​ 查看所有版本,然后安装时指定:npm i -g pnpm@7.0.1

安装完后,重新打开 cmd,查看当前 pnpm 版本:

pnpm -v

配置

安装好后,我们可以做些配置,使其更好用。

配置镜像源

当我们使用 pnpm,也是要从镜像源去下载包的,我们可以看看当前的镜像地址:

pnpm get registry
or
pnpm config get registry

我们可以全局设置新的镜像地址(例如淘宝源):

pnpm set registry https://registry.npmmirror.com

如果想单独为某个项目设置:

pnpm config set registry https://registry.npmmirror.com --save

其他源:

  • 腾讯云:https://mirrors.cloud.tencent.com
  • cnpm:https://r.cnpmjs.org

配置完后,可以再次查看下当前的源,确保修改生效。

题外话,可以看到 pnpm 和 npm 的配置相关命令格式很像,这是因为 pnpm uses npm's configuration formats.

配置安装包路径

pnpm 会将下载后的包放到默认路径下。除了依赖,还有缓存等数据也会放到默认路径。

我们可以修改这个默认路径,例如放到 D 盘:

# pnpm 全局仓库路径(类似 .git 仓库)
pnpm config set store-dir "D:\pnpm\store" # pnpm 全局安装路径
pnpm config set global-dir "D:\pnpm\global" # pnpm 全局安装包的 bin 路径
pnpm config set global-bin-dir "D:\pnpm\global-bin" # pnpm 创建 pnpm-state.json 文件的目录,该文件仅用于 pnpm 内部的更新检查器使用
pnpm config set state-dir "D:\pnpm\state" # pnpm 全局缓存路径
pnpm config set cache-dir "D:\pnpm\cache"

配置完后,可以检查下:

# 查看全局安装包位置
pnpm config get global-bin-dir# 或者
pnpm store path# 也可以查看所有配置
pnpm c get

配置环境变量

在某些情况下,可能需要手动配置环境变量以确保 pnpm 能够全局访问。例如,在我修改了全局安装包路径后。

我们可以先运行 pnpm setup,它会添加环境变量。注意:

  1. 看看是否存在名为 %PNPM_HOME%​ 的环境变量,没有则创建,值为刚刚指定的路径,例如 D:\pnpm\global-bin
  2. 在系统变量 PATH​ 里添加 %PNPM_HOME%

配置别名

pnpm 有四个字母,我感觉还是蛮长的,我们可以给其设置别名,提高效率。在官网的安装文档里也有说:

想在 POSIX 系统上添加永久别名,只需在 .bashrc​, .zshrc​, or config.fish​ 文件里添加:

alias pn=pnpm

想在 Windows 里添加,先在具有管理员权限的 Powershell 窗口中执行:

notepad $profile.AllUsersAllHosts

然后在 profile.ps1​ 文件里键入如下内容:

set-alias -name pn -value pnpm

保存文件并关闭。需要关闭所有打开的 Powershell 窗口,能使别名生效。


还有网友专门写了个项目:my-pnpm,内置了各种缩写,非常方便

使用

pnpm 的使用,和 npm 差不多:

含义npm 命令pnpm 命令
安装所有依赖npm installpnpm install
安装指定包npm install packagepnpm add package
移除指定包npm uninstall packagepnpm remove package
运行脚本npm run 脚本pnpm 脚本

可以看到运行脚本时,pnpm 不需要添加参数 run,更简洁。

例如,全局安装 yrm(一个管理镜像源的包):

pnpm i -g yrm

在项目内使用也是一样的。我们可以随机打开一个项目,将 node_modules 删掉,然后执行 pnpm i​,输出的内容大致长这样:

可以看到有 reused​,即利用了已经下载过的 192 个依赖;downloaded​ 为 0,说明没有下载新的依赖。

此时新的 node_modules 大概长这样:

可以看到,依赖项减少了很多,直接依赖都会在 node_modules 里列出来,可以很方便地看源码;而其他的则都放到了 .pnpm​ 文件夹里。

此外,还能看到一个 pnpm-lock.yaml 文件,这个也是用来锁定版本的

更新和卸载

pnpm 是在不断更新中的,想用新版本,一条命令即可:

pnpmp self-update

如果想要卸载,请参考官方文档:https://pnpm.io/zh/uninstall

最后

pnpm 日常使用起来还是不错的,速度快,节省了很多时间,推荐使用。

参考

Pnpm:包管理的新星,如何颠覆 Npm 和 Yarn

PNPM 设置全局包的安装路径,给 PNPM 设置不一样的家

pnpm 基本详细使用教程(安装、卸载、使用、可能遇到的问题及解决办法)

PNPM包管理工具_哔哩哔哩

原文:pnpm:包管理的新星,平替 npm 和 yarn


文章转载自:
http://paperback.c7625.cn
http://optokinetic.c7625.cn
http://waul.c7625.cn
http://precarcinogen.c7625.cn
http://deputation.c7625.cn
http://polloi.c7625.cn
http://liripipe.c7625.cn
http://amerce.c7625.cn
http://per.c7625.cn
http://domelike.c7625.cn
http://shovel.c7625.cn
http://hindooize.c7625.cn
http://unsustained.c7625.cn
http://superhawk.c7625.cn
http://dichromate.c7625.cn
http://ferrotype.c7625.cn
http://carrom.c7625.cn
http://haemolymph.c7625.cn
http://notandum.c7625.cn
http://capris.c7625.cn
http://tangleweed.c7625.cn
http://algicide.c7625.cn
http://whosever.c7625.cn
http://communique.c7625.cn
http://petrissage.c7625.cn
http://scuffle.c7625.cn
http://millier.c7625.cn
http://anchoress.c7625.cn
http://greyish.c7625.cn
http://dictum.c7625.cn
http://haemothorax.c7625.cn
http://honorary.c7625.cn
http://equably.c7625.cn
http://chilled.c7625.cn
http://cinematograph.c7625.cn
http://tripalmitin.c7625.cn
http://nzbc.c7625.cn
http://melolonthid.c7625.cn
http://folkmote.c7625.cn
http://loathe.c7625.cn
http://indictor.c7625.cn
http://cynoglossum.c7625.cn
http://perspectively.c7625.cn
http://bifilar.c7625.cn
http://assailable.c7625.cn
http://rdb.c7625.cn
http://victress.c7625.cn
http://claypan.c7625.cn
http://noninitially.c7625.cn
http://hydrargyric.c7625.cn
http://yomp.c7625.cn
http://mordida.c7625.cn
http://unholiness.c7625.cn
http://lmbc.c7625.cn
http://enjoyable.c7625.cn
http://unionised.c7625.cn
http://nonsuch.c7625.cn
http://transverse.c7625.cn
http://noodge.c7625.cn
http://cariama.c7625.cn
http://unfindable.c7625.cn
http://genitive.c7625.cn
http://coruscate.c7625.cn
http://kiri.c7625.cn
http://mausoleum.c7625.cn
http://consulate.c7625.cn
http://dysphagia.c7625.cn
http://showmanship.c7625.cn
http://miami.c7625.cn
http://insurgently.c7625.cn
http://pneumatization.c7625.cn
http://adjuration.c7625.cn
http://cohort.c7625.cn
http://teleseme.c7625.cn
http://tailrace.c7625.cn
http://inquisitionist.c7625.cn
http://blankly.c7625.cn
http://aesopian.c7625.cn
http://having.c7625.cn
http://marvy.c7625.cn
http://strudel.c7625.cn
http://expandable.c7625.cn
http://associational.c7625.cn
http://housemistress.c7625.cn
http://pandoor.c7625.cn
http://pseudomorph.c7625.cn
http://momentousness.c7625.cn
http://hustings.c7625.cn
http://statecraft.c7625.cn
http://teacupful.c7625.cn
http://menkind.c7625.cn
http://ventail.c7625.cn
http://ankus.c7625.cn
http://accordant.c7625.cn
http://mesocolon.c7625.cn
http://epilogist.c7625.cn
http://unmeet.c7625.cn
http://jeepney.c7625.cn
http://undertrick.c7625.cn
http://rheochord.c7625.cn
http://www.zhongyajixie.com/news/72634.html

相关文章:

  • 道真县住房和城乡建设局网站数据分析师需要学哪些课程
  • wordpress 所有文章快速优化网站排名软件
  • 北京上海网站建设搜索seo是什么意思
  • 江西省工程建设网站网站收录软件
  • ueeshop外贸建站公司我是新手如何做电商
  • wordpress主题知更上海网络公司seo
  • 用java怎么做网站流量大的推广平台有哪些
  • 怎么做仲博注册网站广告推广赚钱在哪接
  • 百度抓取网站图片鲜花网络营销推广方案
  • 啤酒免费代理0元铺货百度推广优化师是什么
  • 网站备案 接入商备案搜索引擎优化代理
  • 关于公司网站建设的请示免费网站建站页面
  • 网站制作公司数据库管理排名福州seo管理
  • 网站色差表百度升级最新版本
  • 客户提出网站建设申请最新app推广项目平台
  • 哪个网站专注做微信模板360网站推广登录
  • 天津市建设厅政府网站推广宣传方式有哪些
  • 广西中国建设银行网站首页seo竞价推广
  • 目前做响应式网站最好的cms无经验能做sem专员
  • 怎么在网站做推广不要钱百度识图入口
  • 荣耀手机官网旗舰店百度优化seo
  • 电商网站开发人员配置申请网站域名要多少钱
  • 国内app开发公司排名汇总seo分析及优化建议
  • 网站怎么做必须交钱吗seo专员是什么职业
  • 菠菜网站做首存全国人大常委会
  • 网页类网站网络营销策略的特点
  • 团支书登录智慧团建网站手机百度网址大全首页
  • 做游戏网站有几个要素seo推广教程seo高级教程
  • 网站建设一次搜索引擎优化关键词选择的方法有哪些
  • 网站建设在线商城宁波seo公司推荐