Pular para o conteúdo principal
Versão: 7.x

Apelidos

Apelidos permitem que você instale pacotes com nomes personalizados.

Vamos supor que você use lodash em todo o seu projeto. Há um erro no lodash que quebra seu projeto. Você tem uma correção, mas lodash não a mesclará. Normalmente você instalaria lodash diretamente do seu fork (como uma dependência hospedada no git) ou o publicaria com um nome diferente. Se você usar a segunda solução você tem que substituir todos os "require" em seu projeto pelo novo nome de dependência (require('lodash') => require('awesome-dasloh')). Com apelidos, você tem uma terceira opção.

Publicar um novo pacote chamado incrível-lodash e instalá-lo usando lodash como seu apelido:

pnpm add lodash@npm:awesome-lodash

Nenhuma alteração no código é necessária. Todos os "require" de lodash agora serão resolvidos para awesome-lodash.

Às vezes você vai querer usar duas versões diferentes de um pacote em seu projeto. Fácil:

pnpm add lodash1@npm:lodash@1
pnpm add lodash2@npm:lodash@2

Agora você pode exigir a primeira versão do lodash via require('lodash1') e a segunda versão via require('lodash2').

Isso fica ainda mais poderoso quando combinado com ganchos. Talvez você queira substituir lodash por awesome-lodash em todos os pacotes em node_modules. Você pode facilmente alcançar isso com o seguinte .pnpmfile.cjs:

function readPackage(pkg) {
if (pkg.dependencies && pkg.dependencies.lodash) {
pkg.dependencies.lodash = 'npm:awesome-lodash@^1.0.0'
}
return pkg
}

module.exports = {
hooks: {
readPackage
}
}