#javascript #nodejs #frontend #npm #package
Доброе время суток.
Я почитал документацию к NPM, почитал форумы, но всё равно до конца не совсем понимаю,
смысловую нагрузку этого файла.
Вот то что описано на npm документации:
Этот файл предназначен для фиксации в исходных хранилищах и
предназначен для различных целей:
1) Описывает единственное представление дерева зависимостей, чтобы товарищи
по команде, разворачивая проект гарантированно
установил одинаковые зависимости.
2) Предоставьте пользователям возможность «путешествовать во времени» к
предыдущим состояниям node_modules без фиксации самого каталога.
3) Для облегчения большей видимости изменений в дереве с помощью читаемых
исходных текстов контроля.
4) И оптимизировать процесс установки, позволяя npm пропускать
повторяющиеся установленные пакеты.
Вопрос сразу по 1 пункту, ибо у меня package.json и package-lock.json не в гит игноре!
Они комитятся.
И как написано в той же документашке, когда мы делаем npm i, пакетный менеджер устанавливает
зависимости, которые описаны в файле package.json.
И скачав очередную библиотеку мы идем внутрь неё и устанавливаем её зависимости (и
так рекурсивно).
На данном этапе в package-lock.json просто выводится информация какие внутренние
зависимости основных библиотек мы скачали.
Как оно помогает "гарантированно установил одинаковые зависимости" ?
И это всё полностью вытекает из 3 пункта.
Ну и согласен с 4 пунктом, по факту если в node_modules уже есть такой пакет (с той
же версией и хешем), то его устанавливать не будут. НО, опять же эту инфу можно смотреть
не по package-lock.json, а в зависимостях основного пакета, ибо почти у каждой либы
есть внутренний package.json. Т.е нам не нужен промежуточный файл получается.
Верно ли я все понимаю? Пожалуйста, поправьте!
Ответы
Ответ 1
Помимо зависимостей, package.json используется так же для определения свойств проекта, описания, информации об авторе и лицензии, сценариев, в то время как package-lock.json используется исключительно для блокировки зависимостей от определенного номера версии. Наличие package-lock.json в проекте не обязательно. Так же для отключение автоматического создания этого файла ты можешь в .npmrc прописать package-lock=false
Комментариев нет:
Отправить комментарий