Доброе время суток. Я почитал документацию к 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. Т.е нам не нужен промежуточный файл получается.
Верно ли я все понимаю? Пожалуйста, поправьте!
Помимо зависимостей, package.json используется так же для определения свойств проекта, описания, информации об авторе и лицензии, сценариев, в то время как package-lock.json используется исключительно для блокировки зависимостей от определенного номера версии.
Наличие package-lock.json в проекте не обязательно. Так же для отключение автоматического создания этого файла ты можешь в .npmrc прописать package-lock=false
Апостиль в Лос-Анджелесе без лишних нервов и бумажной волокиты
Основные этапы разработки сайта для стоматологической клиники
Продвижение своими сайтами как стратегия роста и независимости