JavaScript एक उच्च-स्तरीय, व्याख्यायित प्रोग्रामिंग भाषा है जिसका मुख्य उपयोग इंटरैक्टिव और गतिशील वेब अनुप्रयोग बनाने के लिए किया जाता है। यह वेब विकास का एक अनिवार्य हिस्सा है, HTML और CSS के साथ। इसे मूल रूप से ब्रेंडन आइच द्वारा नेटस्केप में काम करते समय विकसित किया गया था, JavaScript एक बहुपरकारी भाषा में विकसित हो गई है जो इवेंट-चालित, कार्यात्मक, और अनिवार्य प्रोग्रामिंग शैलियों का समर्थन करती है। यह अब वेब प्रौद्योगिकियों का एक अभिन्न हिस्सा है, जिसमें कई ढांचे, पुस्तकालय, और रनटाइम वातावरण शामिल हैं, विशेष रूप से Node.js।
JavaScript का निर्माण 1995 में मोचा नाम के तहत किया गया, जिसे बाद में लाइवस्क्रिप्ट और अंततः Java की लोकप्रियता का लाभ उठाने के लिए JavaScript नाम दिया गया। इसका पहला संस्करण नेटस्केप नेविगेटर 2.0 में जारी किया गया, जिससे डेवलपर्स को वेब पृष्ठों में गतिशील सामग्री जोड़ने की अनुमति मिली। इस भाषा को 1997 में यूरोपीय कंप्यूटर निर्माताओं संघ (ECMA) के तहत ECMAScript के रूप में मानकीकृत किया गया, जिसमें बाद के संस्करणों ने इसकी क्षमताओं का विस्तार करने वाली प्रमुख विशेषताएँ पेश कीं।
JavaScript का विकास ऐसी विशेषताओं के परिचय के साथ हुआ जैसे कि ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग और असिंक्रोनस प्रोग्रामिंग (प्रॉमिस और कॉलबैक)। विशेष रूप से, ECMAScript 5 (2009) ने "सख्त मोड," JSON समर्थन, और बेहतर एरे विधियों को पेश किया, जबकि ECMAScript 6 (2015), जिसे ES6 या ECMAScript 2015 के नाम से भी जाना जाता है, ने महत्वपूर्ण परिवर्तन लाए जैसे कि एरो फ़ंक्शंस, कक्षाएँ, और मॉड्यूल। ES6 का विमोचन एक पैरेडाइम शिफ्ट का प्रतीक था, क्योंकि इसने JavaScript को बड़े पैमाने पर अनुप्रयोग विकास के लिए एक अधिक मजबूत भाषा बना दिया।
आज, JavaScript वेब विकास में सर्वव्यापी है, जो React, Angular, और Vue.js जैसे फ्रंट-एंड ढांचों को शक्ति प्रदान करता है, साथ ही Node.js के माध्यम से बैक-एंड विकास भी करता है। यह भाषा हर साल ECMAScript के वार्षिक विमोचन के साथ विकसित होती रहती है, नई विशेषताएँ और सुधार पेश करती है। मोबाइल ऐप विकास, डेस्कटॉप अनुप्रयोगों (Electron का उपयोग करते हुए), और यहां तक कि उद्यम स्तर के अनुप्रयोगों में JavaScript के बढ़ते उपयोग के साथ, इसका प्रासंगिकता और महत्व सॉफ़्टवेयर विकास परिदृश्य में मजबूत बना हुआ है।
JavaScript एक गतिशील रूप से टाइप की गई भाषा है, जो वेरिएबल्स को किसी भी प्रकार के मान को बिना स्पष्ट प्रकार की घोषणा के रखने की अनुमति देती है।
let example = "Hello, World!";
example = 42; // कोई त्रुटि नहीं, example प्रकार बदल सकता है
JavaScript में फ़ंक्शन प्रथम श्रेणी के नागरिक होते हैं, जिसका अर्थ है कि उन्हें वेरिएबल्स में असाइन किया जा सकता है, तर्क के रूप में पास किया जा सकता है, और अन्य फ़ंक्शनों से लौटाया जा सकता है।
const greet = function(name) {
return `Hello, ${name}`;
};
console.log(greet("Alice")); // आउटपुट: Hello, Alice
ES6 में पेश किए गए एरो फ़ंक्शन फ़ंक्शन लिखने के लिए एक अधिक संक्षिप्त सिंटैक्स प्रदान करते हैं और अपने स्वयं के this
को बाइंड नहीं करते हैं।
const add = (a, b) => a + b;
console.log(add(2, 3)); // आउटपुट: 5
प्रॉमिस असिंक्रोनस प्रोग्रामिंग को सरल बनाते हैं, जो एक मान का प्रतिनिधित्व करते हैं जो भविष्य में उपलब्ध हो सकता है।
const fetchData = () => {
return new Promise((resolve, reject) => {
// एक API कॉल का अनुकरण करें
setTimeout(() => resolve("Data received!"), 1000);
});
};
fetchData().then(data => console.log(data)); // 1 सेकंड बाद आउटपुट: Data received!
टेम्पलेट लिटेरल्स आसान स्ट्रिंग इंटरपोलेशन और मल्टी-लाइन स्ट्रिंग्स की अनुमति देते हैं।
const name = "Alice";
const greeting = `Hello, ${name}!`;
console.log(greeting); // आउटपुट: Hello, Alice!
डेस्ट्रक्चरिंग असाइनमेंट एरे या ऑब्जेक्ट्स से मानों को निकालने को सरल बनाता है।
const person = { name: "Alice", age: 25 };
const { name, age } = person;
console.log(name, age); // आउटपुट: Alice 25
स्प्रेड ऑपरेटर (...
) एक इटेरेबल से तत्वों को फैलाने की अनुमति देता है, जबकि रेस्ट ऑपरेटर शेष तत्वों को एक एरे में इकट्ठा करता है।
const numbers = [1, 2, 3];
const moreNumbers = [...numbers, 4, 5]; // आउटपुट: [1, 2, 3, 4, 5]
const sum = (...args) => args.reduce((a, b) => a + b, 0);
console.log(sum(1, 2, 3)); // आउटपुट: 6
JavaScript कक्षा-आधारित ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग का समर्थन करता है, जिसमें ES6 में पेश की गई class
सिंटैक्स शामिल है।
class Animal {
constructor(name) {
this.name = name;
}
speak() {
console.log(`${this.name} makes a noise.`);
}
}
const dog = new Animal("Dog");
dog.speak(); // आउटपुट: Dog makes a noise.
JavaScript ES6 मॉड्यूल के माध्यम से मॉड्यूलर प्रोग्रामिंग का समर्थन करता है, जो import
और export
कीवर्ड का उपयोग करते हैं।
// module.js
export const name = "Alice";
export function greet() {
console.log("Hello!");
}
// main.js
import { name, greet } from './module.js';
console.log(name); // आउटपुट: Alice
greet(); // आउटपुट: Hello!
async/await सिंटैक्स प्रॉमिस के साथ काम करना सरल बनाता है, जिससे असिंक्रोनस कोड अधिक सिंक्रोनस दिखता है।
const fetchData = async () => {
const response = await fetch('https://api.example.com/data');
const data = await response.json();
return data;
};
fetchData().then(data => console.log(data));
JavaScript विभिन्न वातावरणों में चलता है, जिसमें ब्राउज़र इंजन जैसे V8 (Chrome) और SpiderMonkey (Firefox) सबसे प्रमुख हैं। Node.js JavaScript को सर्वर साइड पर निष्पादित करने की अनुमति देता है, जिससे डेवलपर्स को क्लाइंट और सर्वर दोनों में एकीकृत भाषा के साथ पूर्ण विकसित वेब अनुप्रयोग बनाने की शक्ति मिलती है।
JavaScript के लिए सामान्य IDEs और कोड संपादकों में Visual Studio Code, WebStorm, Atom, और Sublime Text शामिल हैं। ये उपकरण सिंटैक्स हाइलाइटिंग, बुद्धिमान कोड पूर्णता, और डिबगिंग समर्थन जैसी सुविधाएँ प्रदान करते हैं।
JavaScript परियोजना सेट करने के लिए, डेवलपर्स आमतौर पर npm या yarn जैसे पैकेज प्रबंधकों का उपयोग करते हैं। एक सामान्य परियोजना संरचना में वेब इंटरफेस के लिए एक index.html
फ़ाइल, एक मुख्य JavaScript फ़ाइल (अक्सर main.js
), और संभवतः पैकेज प्रबंधित करने के लिए एक package.json
फ़ाइल शामिल होती है।
npm init -y # डिफ़ॉल्ट सेटिंग्स के साथ एक नया JavaScript प्रोजेक्ट प्रारंभ करता है
npm install express # एक्सप्रेस ढांचे को स्थापित करता है
JavaScript का उपयोग कई अनुप्रयोगों में किया जाता है, जिसमें शामिल हैं:
JavaScript के मुख्य प्रतिस्पर्धी और विकल्पों में शामिल हैं:
प्रत्येक भाषा की अपनी ताकत और कमजोरियाँ होती हैं, जो किसी परियोजना या अनुप्रयोग की विशिष्ट आवश्यकताओं के आधार पर होती हैं।
JavaScript को अन्य भाषाओं में अनुवाद करने या इसके विपरीत, एक उपकरण का उपयोग किया जा सकता है जैसे Babel (आधुनिक JavaScript को पुराने संस्करणों में ट्रांसपाइल करने के लिए) या TypeScript (प्रकार-चेकिंग और JavaScript में ट्रांसपाइल करने के लिए)। jQuery जैसी पुस्तकालय भी विभिन्न वातावरणों में DOM हेरफेर में मदद कर सकती हैं, एक सुसंगत API प्रदान करके।
Babel और TypeScript के अलावा, अन्य उपकरण JavaScript कोड के अनुवाद या रूपांतरण में सहायता कर सकते हैं: