Когда мы разрабатываем проект, мы хотим быть уверены, что мы используем стабильные версии фреймворка и пакетов, чтобы избежать несовместимостей или возможных ошибок. Для этого мы можем зафиксировать мажорную версию фреймворка и пакетов, используя npm.
Начнем с мажорной версии фреймворка. Когда мы создаем новый проект с помощью npm, в папке проекта появляется файл package.json. Этот файл содержит информацию о проекте, включая список зависимостей и их версии.
Чтобы зафиксировать мажорную версию фреймворка, мы можем указать специфическую версию в файле package.json. Например, если мы используем фреймворк Express, и мы хотим зафиксироваться на мажорной версии 4.x.x, мы можем добавить следующую строку в секцию "dependencies" в файле package.json:
"express": "^4.0.0"
Здесь символ ^ перед версией указывает npm, что мы хотим использовать мажорную версию, но допускаем, что будут установлены новые минорные и патч-версии фреймворка, если они доступны. Например, если текущая мажорная версия Express - 4.6.1, и новая версия - 4.7.0, символ ^ позволит npm обновить фреймворк до 4.7.0 автоматически.
Однако, если мы хотим зафиксироваться на конкретной мажорной версии фреймворка и не хотим, чтобы произошло автоматическое обновление, мы можем использовать символ ~ перед версией. Например, если мы хотим использовать только мажорную версию 4.x.x Express и не допускаем обновление до версии 5.x.x, мы можем добавить следующую строку в package.json:
"express": "~4.0.0"
Теперь давайте перейдем к пакетам, которые мы используем в нашем проекте. Также, как и с фреймворком, мы можем зафиксировать мажорную версию пакетов, указав специфическую версию в файле package.json.
Например, если мы используем пакет lodash, и хотим зафиксироваться на мажорной версии 4.x.x, мы можем добавить следующую строку в секцию "dependencies" в файле package.json:
"lodash": "^4.0.0"
Также, как и с фреймворком, символ ^ позволит npm обновлять пакет в пределах мажорной версии, если доступны новые минорные или патч-версии. Если же мы хотим зафиксироваться на конкретной мажорной версии пакета, мы можем использовать символ ~ перед версией:
"lodash": "~4.0.0"
Когда мы устанавливаем пакеты или обновляем их с помощью команды "npm install" или "npm update", npm будет учитывать указанные нами версии и устанавливать совместимые версии фреймворка и пакетов.
Важно отметить, что зафиксированное значение мажорной версии фреймворка и пакетов не является окончательным, и мы по-прежнему можем обновлять их вручную, если это необходимо. Однако, зафиксированная мажорная версия обеспечит стабильность и совместимость проекта существующими зависимостями.