Node.js ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਸਰਲ
Node.js ਅਤੇ npm ਦੀ ਦੁਨੀਆ ਵਿੱਚ, ਇੱਕ ਸਥਿਰ ਵਿਕਾਸ ਵਾਤਾਵਰਣ ਨੂੰ ਬਣਾਈ ਰੱਖਣ ਲਈ ਨਿਰਭਰਤਾਵਾਂ ਦਾ ਕੁਸ਼ਲਤਾ ਨਾਲ ਪ੍ਰਬੰਧਨ ਕਰਨਾ ਮਹੱਤਵਪੂਰਨ ਹੈ। ਹਾਲ ਹੀ ਵਿੱਚ, ਤੁਸੀਂ ਪੈਕੇਜ.json ਫਾਈਲ ਵਿੱਚ npm ਦੁਆਰਾ ਪੈਕੇਜ ਸੰਸਕਰਣਾਂ ਨੂੰ ਸੁਰੱਖਿਅਤ ਕਰਨ ਦੇ ਤਰੀਕੇ ਵਿੱਚ ਇੱਕ ਤਬਦੀਲੀ ਦੇਖੀ ਹੋ ਸਕਦੀ ਹੈ।
Node.js ਅਤੇ npm ਦੇ ਨਵੀਨਤਮ ਸਥਿਰ ਸੰਸਕਰਣਾਂ ਵਿੱਚ ਅੱਪਗਰੇਡ ਕਰਨ ਤੋਂ ਬਾਅਦ, npm install moment --save ਚੱਲਣਾ ਹੁਣ ਪਹਿਲਾਂ ਵਰਤੇ ਗਏ ਟਿਲਡ (~) ਅਗੇਤਰ ਦੀ ਬਜਾਏ, ਇੱਕ ਕੈਰੇਟ (^) ਪ੍ਰੀਫਿਕਸ ਨਾਲ ਨਿਰਭਰਤਾ ਨੂੰ ਬਚਾਉਂਦਾ ਹੈ। ਇਹ ਲੇਖ ਪੜਚੋਲ ਕਰਦਾ ਹੈ ਕਿ ਇਹ ਤਬਦੀਲੀਆਂ ਕਿਉਂ ਕੀਤੀਆਂ ਗਈਆਂ ਸਨ ਅਤੇ ਟਿਲਡ (~) ਅਤੇ ਕੈਰੇਟ (^) ਸੰਸਕਰਨ ਰਣਨੀਤੀਆਂ ਵਿਚਕਾਰ ਅੰਤਰ।
ਹੁਕਮ | ਵਰਣਨ |
---|---|
fs.writeFileSync | ਇੱਕ ਫਾਈਲ ਨੂੰ ਸਮਕਾਲੀ ਰੂਪ ਵਿੱਚ ਡੇਟਾ ਲਿਖਦਾ ਹੈ, ਇੱਕ ਨਵੀਂ ਫਾਈਲ ਬਣਾਉਂਦਾ ਹੈ ਜੇਕਰ ਇਹ ਮੌਜੂਦ ਨਹੀਂ ਹੈ ਜਾਂ ਮੌਜੂਦਾ ਫਾਈਲ ਨੂੰ ਬਦਲਣਾ. |
require('fs') | Node.js ਵਿੱਚ ਫਾਈਲ ਹੈਂਡਲਿੰਗ ਓਪਰੇਸ਼ਨਾਂ ਨੂੰ ਸਮਰੱਥ ਕਰਨ ਲਈ ਫਾਈਲ ਸਿਸਟਮ ਮੋਡੀਊਲ ਸ਼ਾਮਲ ਕਰਦਾ ਹੈ। |
express() | ਇੱਕ ਐਕਸਪ੍ਰੈਸ ਐਪਲੀਕੇਸ਼ਨ ਬਣਾਉਂਦਾ ਹੈ, ਜੋ ਕਿ ਐਕਸਪ੍ਰੈਸ ਫਰੇਮਵਰਕ ਦੀ ਇੱਕ ਉਦਾਹਰਣ ਹੈ। |
app.get() | ਇੱਕ ਖਾਸ ਮਾਰਗ ਲਈ GET ਬੇਨਤੀਆਂ ਲਈ ਇੱਕ ਰੂਟ ਹੈਂਡਲਰ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ। |
app.listen() | ਇੱਕ ਸਰਵਰ ਸ਼ੁਰੂ ਕਰਦਾ ਹੈ ਅਤੇ ਆਉਣ ਵਾਲੀਆਂ ਬੇਨਤੀਆਂ ਲਈ ਇੱਕ ਨਿਸ਼ਚਿਤ ਪੋਰਟ 'ਤੇ ਸੁਣਦਾ ਹੈ। |
require('express') | Node.js ਵਿੱਚ ਵੈੱਬ ਐਪਲੀਕੇਸ਼ਨ ਬਣਾਉਣ ਲਈ ਐਕਸਪ੍ਰੈਸ ਮੋਡੀਊਲ ਸ਼ਾਮਲ ਕਰਦਾ ਹੈ। |
Node.js ਸਕ੍ਰਿਪਟਾਂ ਦੀ ਵਿਸਤ੍ਰਿਤ ਵਿਆਖਿਆ
ਬੈਕਐਂਡ ਸਕ੍ਰਿਪਟ ਦਰਸਾਉਂਦੀ ਹੈ ਕਿ a ਵਿੱਚ ਨਿਰਭਰਤਾ ਸੰਸਕਰਣਾਂ ਦਾ ਪ੍ਰਬੰਧਨ ਕਿਵੇਂ ਕਰਨਾ ਹੈ package.json ਟਿਲਡ (~) ਅਤੇ ਕੈਰੇਟ (^) ਅਗੇਤਰਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਫਾਈਲ। ਪਹਿਲਾਂ, ਅਸੀਂ ਫਾਈਲ ਸਿਸਟਮ ਮੋਡੀਊਲ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਸ਼ਾਮਲ ਕਰਦੇ ਹਾਂ require('fs') ਫਾਈਲ ਹੈਂਡਲਿੰਗ ਕਾਰਜਾਂ ਨੂੰ ਸਮਰੱਥ ਕਰਨ ਲਈ. ਅਸੀਂ ਫਿਰ ਇੱਕ ਬੁਨਿਆਦੀ ਬਣਾਉਂਦੇ ਹਾਂ package.json ਨਿਰਭਰਤਾ ਦੇ ਨਾਲ ਬਣਤਰ moment ਟਿਲਡ (~) ਵਰਜਨਿੰਗ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਨਿਰਧਾਰਤ ਕੀਤਾ ਗਿਆ ਹੈ। ਇਹ ਫਾਈਲ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਡਿਸਕ ਤੇ ਲਿਖੀ ਜਾਂਦੀ ਹੈ fs.writeFileSync, ਬਣਾਉਣਾ package-tilde.json. ਅੱਗੇ, ਅਸੀਂ ਸੋਧਦੇ ਹਾਂ package.json ਲਈ ਕੈਰੇਟ (^) ਅਗੇਤਰ ਦੀ ਵਰਤੋਂ ਕਰਨ ਲਈ moment ਨਿਰਭਰਤਾ ਅਤੇ ਇਸ ਨੂੰ ਲਿਖੋ package-caret.json. ਸਕ੍ਰਿਪਟ ਦੋਨਾਂ ਫਾਈਲਾਂ ਦੀ ਸਿਰਜਣਾ ਨੂੰ ਦਰਸਾਉਣ ਵਾਲੇ ਇੱਕ ਸੰਦੇਸ਼ ਨੂੰ ਲੌਗ ਕਰਨ ਦੁਆਰਾ ਖਤਮ ਹੁੰਦੀ ਹੈ।
ਫਰੰਟਐਂਡ ਸਕ੍ਰਿਪਟ ਇੱਕ ਸਧਾਰਨ ਸਰਵਰ ਸਥਾਪਤ ਕਰਨ ਲਈ ਐਕਸਪ੍ਰੈਸ ਫਰੇਮਵਰਕ ਦੀ ਵਰਤੋਂ ਕਰਦੀ ਹੈ ਜੋ ਸੰਸਕਰਣ ਜਾਣਕਾਰੀ ਪ੍ਰਦਾਨ ਕਰਦਾ ਹੈ। ਅਸੀਂ ਐਕਸਪ੍ਰੈਸ ਮੋਡੀਊਲ ਨੂੰ ਸ਼ਾਮਲ ਕਰਕੇ ਸ਼ੁਰੂ ਕਰਦੇ ਹਾਂ require('express') ਅਤੇ ਵਰਤ ਕੇ ਇੱਕ ਐਪਲੀਕੇਸ਼ਨ ਉਦਾਹਰਨ ਬਣਾਓ express(). ਇੱਕ ਰੂਟ ਹੈਂਡਲਰ ਨਾਲ ਪਰਿਭਾਸ਼ਿਤ ਕੀਤਾ ਗਿਆ ਹੈ app.get() ਮਾਰਗ ਲਈ /versioning, ਜੋ ਪਹਿਲਾਂ ਬਣਾਏ ਗਏ ਪੜ੍ਹਦਾ ਹੈ package-tilde.json ਅਤੇ package-caret.json ਫਾਈਲਾਂ। ਹੈਂਡਲਰ ਸੰਸਕਰਣ ਜਾਣਕਾਰੀ ਦੇ ਨਾਲ ਇੱਕ JSON ਜਵਾਬ ਭੇਜਦਾ ਹੈ। ਸਰਵਰ ਚਾਲੂ ਹੋ ਗਿਆ ਹੈ ਅਤੇ ਪੋਰਟ 3000 ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਸੁਣਦਾ ਹੈ app.listen(), ਇਹ ਦਰਸਾਉਣ ਲਈ ਕਿ ਸਰਵਰ ਚੱਲ ਰਿਹਾ ਹੈ, ਇੱਕ ਸੁਨੇਹਾ ਲੌਗ ਕਰਨਾ।
Node.js ਵਿੱਚ ਨਿਰਭਰਤਾ ਸੰਸਕਰਣ ਨੂੰ ਸਮਝਣਾ
JavaScript - Node.js
// Backend script to demonstrate the use of tilde (~) and caret (^) in package.json
// Assuming a basic Node.js setup with npm initialized
// Create a simple package.json file
const fs = require('fs');
const packageJson = {
"name": "versioning-demo",
"version": "1.0.0",
"dependencies": {
"moment": "~2.29.1" // Using tilde (~) versioning
}
};
fs.writeFileSync('package-tilde.json', JSON.stringify(packageJson, null, 2));
packageJson.dependencies.moment = "^2.29.1"; // Change to caret (^) versioning
fs.writeFileSync('package-caret.json', JSON.stringify(packageJson, null, 2));
console.log('Created package-tilde.json and package-caret.json');
npm ਵਿੱਚ ਵਰਜਨਿੰਗ ਅਗੇਤਰਾਂ ਦੀ ਪੜਚੋਲ ਕਰਨਾ
JavaScript - ਐਕਸਪ੍ਰੈਸ ਦੇ ਨਾਲ Node.js
// Frontend script to fetch versioning information from the server
const express = require('express');
const app = express();
const port = 3000;
app.get('/versioning', (req, res) => {
const packageTilde = require('./package-tilde.json');
const packageCaret = require('./package-caret.json');
res.send({
tildeVersion: packageTilde.dependencies.moment,
caretVersion: packageCaret.dependencies.moment
});
});
app.listen(port, () => {
console.log(`Server running at http://localhost:${port}`);
});
npm ਵਿੱਚ ਸੰਸਕਰਣ ਰੇਂਜਾਂ ਦੀ ਪੜਚੋਲ ਕੀਤੀ ਜਾ ਰਹੀ ਹੈ
npm ਵਿੱਚ ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਦੇ ਇੱਕ ਹੋਰ ਪਹਿਲੂ ਵਿੱਚ ਇਹ ਸਮਝਣਾ ਸ਼ਾਮਲ ਹੈ ਕਿ ਸੰਸਕਰਣ ਰੇਂਜ ਪੈਕੇਜਾਂ ਦੀ ਸਥਾਪਨਾ ਨੂੰ ਕਿਵੇਂ ਪ੍ਰਭਾਵਤ ਕਰਦੇ ਹਨ। ਟਿਲਡ (~) ਅਤੇ ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਦੋਵੇਂ ਵਰਜਨ ਰੇਂਜਾਂ ਨੂੰ ਨਿਸ਼ਚਿਤ ਕਰਨ ਲਈ ਵਰਤੇ ਜਾਂਦੇ ਹਨ, ਪਰ ਉਹ ਵੱਖਰੇ ਨਿਯਮਾਂ ਦੀ ਪਾਲਣਾ ਕਰਦੇ ਹਨ। ਟਿਲਡ (~) ਚਿੰਨ੍ਹ ਉਹਨਾਂ ਅੱਪਡੇਟਾਂ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ ਜੋ ਖੱਬੇ-ਪੱਖੀ ਗੈਰ-ਜ਼ੀਰੋ ਅੰਕ ਨੂੰ ਨਹੀਂ ਬਦਲਦੇ ਹਨ, ਮਤਲਬ ਕਿ ਇਹ ਉਸੇ ਮਾਮੂਲੀ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਨਵੇਂ ਪੈਚ ਸੰਸਕਰਣਾਂ ਲਈ ਅੱਪਡੇਟ ਹੋਵੇਗਾ। ਉਦਾਹਰਣ ਲਈ, ~1.2.3 ਸੰਸਕਰਣਾਂ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਦੇਵੇਗਾ 1.2.x ਪਰ ਨਾ 1.3.0.
ਦੂਜੇ ਪਾਸੇ, ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ, ਉਹਨਾਂ ਅੱਪਡੇਟਾਂ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ ਜੋ ਮੁੱਖ ਸੰਸਕਰਣ ਦੇ ਸਭ ਤੋਂ ਖੱਬੇ ਪਾਸੇ ਦੇ ਗੈਰ-ਜ਼ੀਰੋ ਅੰਕ ਨੂੰ ਨਹੀਂ ਬਦਲਦੇ, ਇਸ ਨੂੰ ਹੋਰ ਲਚਕਦਾਰ ਬਣਾਉਂਦੇ ਹਨ। ਉਦਾਹਰਣ ਦੇ ਲਈ, ^1.2.3 ਕਿਸੇ ਵੀ ਸੰਸਕਰਣ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਦੇਵੇਗਾ 1.x.x ਪਰ ਨਾ 2.0.0. ਇਹ ਲਚਕਤਾ ਉਸੇ ਮੁੱਖ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਅਨੁਕੂਲਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹੋਏ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਅੱਪ-ਟੂ-ਡੇਟ ਰੱਖਣ ਲਈ ਲਾਭਦਾਇਕ ਹੋ ਸਕਦੀ ਹੈ, ਜਿਸ ਵਿੱਚ ਅਕਸਰ ਪਿਛੜੇ-ਅਨੁਕੂਲ ਤਬਦੀਲੀਆਂ ਸ਼ਾਮਲ ਹੁੰਦੀਆਂ ਹਨ।
npm ਵਰਜਨਿੰਗ ਬਾਰੇ ਆਮ ਸਵਾਲ
- npm ਸੰਸਕਰਣ ਵਿੱਚ ਟਿਲਡ (~) ਚਿੰਨ੍ਹ ਦਾ ਕੀ ਅਰਥ ਹੈ?
- ਟਿਲਡ (~) ਚਿੰਨ੍ਹ ਖਾਸ ਮਾਮੂਲੀ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਪੈਚ ਸੰਸਕਰਣਾਂ ਲਈ ਅੱਪਡੇਟ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ।
- npm ਸੰਸਕਰਣ ਵਿੱਚ ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਦਾ ਕੀ ਅਰਥ ਹੈ?
- ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਖਾਸ ਮੁੱਖ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਮਾਮੂਲੀ ਅਤੇ ਪੈਚ ਸੰਸਕਰਣਾਂ ਨੂੰ ਅਪਡੇਟ ਕਰਨ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ।
- npm ਟਿਲਡ (~) ਤੋਂ ਕੈਰੇਟ (^) ਵਿੱਚ ਕਿਉਂ ਬਦਲਿਆ?
- npm ਨੇ ਵਧੇਰੇ ਲਚਕਦਾਰ ਅਤੇ ਅਪ-ਟੂ-ਡੇਟ ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਦੀ ਆਗਿਆ ਦੇਣ ਲਈ ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਨੂੰ ਅਪਣਾਇਆ।
- ਕੀ ਨਿਰਭਰਤਾ ਲਈ ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਦੀ ਵਰਤੋਂ ਕਰਨਾ ਸੁਰੱਖਿਅਤ ਹੈ?
- ਹਾਂ, ਇਹ ਆਮ ਤੌਰ 'ਤੇ ਸੁਰੱਖਿਅਤ ਹੁੰਦਾ ਹੈ ਕਿਉਂਕਿ ਇਹ ਉਸੇ ਪ੍ਰਮੁੱਖ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਅੱਪਡੇਟ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ, ਜੋ ਅਕਸਰ ਪਿਛੜੇ ਅਨੁਕੂਲਤਾ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ।
- ਮੈਂ ਇੱਕ ਪੈਕੇਜ ਦਾ ਸਹੀ ਸੰਸਕਰਣ ਕਿਵੇਂ ਨਿਰਧਾਰਤ ਕਰਾਂ?
- ਤੁਸੀਂ ਬਿਨਾਂ ਕਿਸੇ ਅਗੇਤਰ ਦੇ ਸੰਸਕਰਣ ਨੰਬਰ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਇੱਕ ਸਹੀ ਸੰਸਕਰਣ ਨਿਰਧਾਰਤ ਕਰ ਸਕਦੇ ਹੋ, ਜਿਵੇਂ ਕਿ "1.2.3".
- ਕੀ ਮੈਂ ਇੱਕੋ ਵਿੱਚ ਟਿਲਡ (~) ਅਤੇ ਕੈਰੇਟ (^) ਦੋਵਾਂ ਦੀ ਵਰਤੋਂ ਕਰ ਸਕਦਾ ਹਾਂ package.json?
- ਹਾਂ, ਤੁਸੀਂ ਦੋਨਾਂ ਚਿੰਨ੍ਹਾਂ ਨੂੰ ਇੱਕੋ ਵਿੱਚ ਵਰਤ ਸਕਦੇ ਹੋ package.json ਵੱਖ-ਵੱਖ ਸੰਸਕਰਨ ਰਣਨੀਤੀਆਂ ਨਾਲ ਵੱਖ-ਵੱਖ ਨਿਰਭਰਤਾ ਦਾ ਪ੍ਰਬੰਧਨ ਕਰਨ ਲਈ ਫਾਈਲ.
- ਕੀ ਹੁੰਦਾ ਹੈ ਜੇਕਰ ਮੈਂ ਕਿਸੇ ਵਰਜਨ ਪ੍ਰੀਫਿਕਸ ਦੀ ਵਰਤੋਂ ਨਹੀਂ ਕਰਦਾ ਹਾਂ?
- ਜੇਕਰ ਕੋਈ ਵਰਜਨ ਪ੍ਰੀਫਿਕਸ ਨਹੀਂ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ, ਤਾਂ npm ਨਿਰਦਿਸ਼ਟ ਸੰਸਕਰਣ ਨੂੰ ਸਥਾਪਿਤ ਕਰੇਗਾ।
- ਮੈਂ ਸਾਰੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਉਹਨਾਂ ਦੇ ਨਵੀਨਤਮ ਸੰਸਕਰਣਾਂ ਵਿੱਚ ਕਿਵੇਂ ਅਪਡੇਟ ਕਰ ਸਕਦਾ ਹਾਂ?
- ਤੁਸੀਂ ਕਮਾਂਡ ਦੀ ਵਰਤੋਂ ਕਰ ਸਕਦੇ ਹੋ npm update ਸਾਰੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਉਹਨਾਂ ਦੇ ਨਵੀਨਤਮ ਸੰਸਕਰਣਾਂ ਲਈ ਨਿਰਧਾਰਤ ਸੰਸਕਰਣ ਰੇਂਜਾਂ ਦੇ ਅਨੁਸਾਰ ਅਪਡੇਟ ਕਰਨ ਲਈ।
- npm ਵਿੱਚ ਅਰਥ ਸੰਸਕਰਣ ਕੀ ਹੈ?
- ਸਿਮੈਂਟਿਕ ਵਰਜ਼ਨਿੰਗ (ਸੇਮਵਰ) ਇੱਕ ਵਰਜਨਿੰਗ ਸਕੀਮ ਹੈ ਜੋ ਤਿੰਨ-ਭਾਗ ਵਾਲੇ ਸੰਸਕਰਣ ਨੰਬਰ ਦੀ ਵਰਤੋਂ ਕਰਦੀ ਹੈ: major.minor.patch, ਅਨੁਕੂਲਤਾ ਅਤੇ ਸੌਫਟਵੇਅਰ ਵਿੱਚ ਤਬਦੀਲੀਆਂ ਨੂੰ ਦਰਸਾਉਂਦੀ ਹੈ।
ਐਨਪੀਐਮ ਸੰਸਕਰਣ 'ਤੇ ਅੰਤਮ ਵਿਚਾਰ
ਸੰਖੇਪ ਵਿੱਚ, npm ਸੰਸਕਰਣ ਵਿੱਚ ਟਿਲਡ (~) ਅਤੇ ਕੈਰੇਟ (^) ਵਿਚਕਾਰ ਅੰਤਰ ਨੂੰ ਸਮਝਣਾ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਲਈ ਜ਼ਰੂਰੀ ਹੈ। ਟਿਲਡ (~) ਚਿੰਨ੍ਹ ਉਸੇ ਛੋਟੇ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਪੈਚ ਸੰਸਕਰਣਾਂ ਲਈ ਅੱਪਡੇਟਾਂ ਨੂੰ ਪ੍ਰਤਿਬੰਧਿਤ ਕਰਦਾ ਹੈ, ਜਦੋਂ ਕਿ ਕੈਰੇਟ (^) ਚਿੰਨ੍ਹ ਉਸੇ ਵੱਡੇ ਸੰਸਕਰਣ ਦੇ ਅੰਦਰ ਅੱਪਡੇਟ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ। ਡਿਫੌਲਟ ਤੌਰ 'ਤੇ ਕੈਰੇਟ (^) ਦੀ ਵਰਤੋਂ ਕਰਨ ਲਈ ਸ਼ਿਫਟ ਵਧੇਰੇ ਲਚਕਤਾ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਦਾ ਹੈ ਅਤੇ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਅਨੁਕੂਲਤਾ ਨਾਲ ਸਮਝੌਤਾ ਕੀਤੇ ਬਿਨਾਂ ਨਿਰਭਰਤਾਵਾਂ ਵਧੇਰੇ ਅੱਪ-ਟੂ-ਡੇਟ ਹਨ। ਇਹਨਾਂ ਸੰਸਕਰਣ ਰਣਨੀਤੀਆਂ ਨੂੰ ਅਪਣਾ ਕੇ, ਡਿਵੈਲਪਰ ਇੱਕ ਸਥਿਰ ਅਤੇ ਕੁਸ਼ਲ Node.js ਵਿਕਾਸ ਵਾਤਾਵਰਣ ਨੂੰ ਕਾਇਮ ਰੱਖ ਸਕਦੇ ਹਨ।