Значение и функциональность префикса '@' в имени npm пакета

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Символ "@" в именах пакетов npm обозначает область действия (scope). Этим символом группируются связанные пакеты в одну область именования (например, "@myteam/mylib"). Также данный символ помогает избежать конфликтов имен и выступает индикатором официальных пакетов, таких как '@vue/cli', гарантируя, что этот пакет поддерживается официальными разработчиками Vue.js.

Кинга Идем в IT: пошаговый план для смены профессии

Области действия: способствуя сотрудничеству в планировании пространства имен

Пространства имен: поддерживают порядок среди хаоса

Использование пространств имен помогает предотвратить конфликты имен, избегая путаницы из-за совпадения названий пакетов. Оно схоже с присвоением уникальных наименований улицам в 'городе путаницы'. Благодаря использованию областей видимости, такой хаос минимизируется.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Пакеты с областью действия: выделяясь в среде общего доступа

В экосистеме npm области действия служат своеобразным личным пространством имен, которое помогает определить происхождение пакета. Организации, такие как Angular, Vue или ваша фирма, могут иметь свой управляемый набор пакетов с уникальным именем. Например, '@angular/router' — это библиотека для маршрутизации в Angular, которая отличается от аналогичных пакетов из сообщества.

Содействие сотрудничеству с помощью областей видимости

Области видимости предлагают превосходный механизм для кооперации. Есть комплект связанных библиотек для проекта? Объедините их в рамках пространства имен вашей команды. Более того, npm предоставляет приватные области видимости для безопасного хранения ваших закрытых библиотек, недоступных общественности.

Преимущества областей видимости

Упрощение поиска в реестрах общего доступа

Поиск публичных пакетов с областью действия проводится так же просто, как и поиск стандартных. Будь то '@babel/core' или любой другой пакет с областью действия, поиск через npm обязательно найдет нужное. Приватные пакеты не показываются и доступны только для авторизованных пользователей.

Уникальность для сообщества

Каждый пакет в рамках конкретной области действия обладает уникальной идентификацией. Забудьте о конфликтах имен, теперь вы можете спокойно публиковать свои пакеты в области действия, не боясь возникновения проблем с глобальным пространством имен.

Синтаксис установки пакетов с областью видимости

При установке пакетов важно придерживаться правильного синтаксиса: команда npm install @scope/package должна быть введена корректно. Пропуск "@" может привести к установке совершенно другого пакета.

Визуализация

Помотрим на функцию префикса "@" в названиях пакетов npm подробнее:

Markdown
Скопировать код
// Обычные пакеты npm 
Коробка (📦): [jQuery, lodash, express]
Markdown
Скопировать код
// А теперь в игру вступают пакеты со скоупом!
Коробка (📦): [@angular/core, @vue/cli, @babel/core]
Markdown
Скопировать код
// "@" — это эксклюзивный угол в реестре npm
Полка (🏷️): [@username/project1, @username/project2]
Markdown
Скопировать код
// Задача "@" — организование ваших ценных коллекций (пакетов)!
Организованная полка (🏷️📚):
- @company/auth-lib
- @company/data-utils

Область видимости (^@scope^) — это больше про организацию в npm, чем об укрытии.

Управление версиями в пакетах с областью видимости

Быстрое получение последних версий

С помощью @latest вы всегда можете установить последнюю версию пакета. Команда npm install @scope/package@latest предоставит вам самые новые обновления кода, независимо от типа пакета.

Закрепление конкретных версий

Для сохранения консистентности и стабильности важно закрепить нужные версии. Для этого используйте команду npm install packagename@version, например, npm install packagename@1.2.3.

Установка диапазонов версий

npm поддерживает механизм SemVer (семантическое версионирование), который позволяет указать диапазоны версий, такие как npm install packagename@">=1.0.0 <2.0.0". С помощью такого подхода можно устанавливать версии от 1.0.0 до 2.0.0, что обеспечивает точный контроль версий пакета.

npm и GitHub: различия в путях

Важно знать: названия пакетов без "@" могут указывать на репозитории в GitHub, а не на npm пакеты. Будьте внимательны, чтобы не отклониться от пути разработки.

Полезные материалы

Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Что обозначает символ '@' в именах пакетов npm?
1 / 5