ईएस 6 - एरेस
मूल्यों को संग्रहीत करने के लिए चर का उपयोग निम्नलिखित सीमाएं बनाता है -
चर प्रकृति में स्केलर हैं। दूसरे शब्दों में, एक चर घोषणा में केवल एक समय में एक ही हो सकता है। इसका मतलब है कि एक प्रोग्राम में एन वैल्यूज़ को स्टोर करने के लिए एन वेरिएबल डिक्लेरेशन की ज़रूरत होगी। इसलिए, जब मूल्यों का एक बड़ा संग्रह संग्रहीत करने की आवश्यकता होती है, तो चर का उपयोग संभव नहीं होता है।
एक कार्यक्रम में चर को यादृच्छिक क्रम में मेमोरी आवंटित की जाती है, जिससे उनकी घोषणा के क्रम में मूल्यों को पुनः प्राप्त / पढ़ना मुश्किल हो जाता है।
जावास्क्रिप्ट उसी से निपटने के लिए सरणियों की अवधारणा का परिचय देता है।
एक सरणी मानों का एक समरूप संग्रह है। सरल बनाने के लिए, एक सरणी समान डेटा प्रकार के मूल्यों का एक संग्रह है। यह एक उपयोगकर्ता-परिभाषित प्रकार है।
एक ऐरे की विशेषताएं
एक सरणी घोषणा अनुक्रमिक मेमोरी ब्लॉक आवंटित करती है।
ऐरे स्थिर हैं। इसका मतलब यह है कि एक बार आरंभीकृत होने के बाद सरणी को आकार नहीं दिया जा सकता है।
प्रत्येक मेमोरी ब्लॉक एक सरणी तत्व का प्रतिनिधित्व करता है।
सरणी तत्वों की पहचान एक अद्वितीय पूर्णांक द्वारा की जाती है जिसे तत्व का उपप्रकार / सूचकांक कहा जाता है।
उपयोग किए जाने से पहले, चर की तरह ऐरे को भी घोषित किया जाना चाहिए।
सरणी आरंभीकरण सरणी तत्वों को पॉप्युलेट करने के लिए संदर्भित करता है।
ऐरे तत्व मानों को अद्यतन या संशोधित किया जा सकता है लेकिन हटाया नहीं जा सकता।
घोषणा और प्रारंभिक सारणी
जावास्क्रिप्ट में किसी ऐरे को घोषित करने और शुरू करने के लिए निम्नलिखित सिंटैक्स का उपयोग करें -
var array_name; //declaration
array_name = [val1,val2,valn..] //initialization
OR
var array_name = [val1,val2…valn]
Note - [] की जोड़ी को सरणी का आयाम कहा जाता है।
उदाहरण के लिए, एक घोषणा: var numlist = [2,4,6,8] निम्न आकृति में दिखाए गए अनुसार एक सरणी बनाएंगे।
ऐरे तत्वों तक पहुँचना
एक उप तत्व को संदर्भित करने के लिए सबस्क्रिप्ट के बाद वाले सरणी नाम का उपयोग किया जाता है।
निम्नलिखित के लिए सिंटैक्स है।
array_name[subscript]
उदाहरण: सरल ऐरे
var alphas;
alphas = ["1","2","3","4"]
console.log(alphas[0]);
console.log(alphas[1]);
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
1
2
उदाहरण: सिंगल स्टेटमेंट डिक्लेरेशन एंड इनिशियलाइज़ेशन
var nums = [1,2,3,3]
console.log(nums[0]);
console.log(nums[1]);
console.log(nums[2]);
console.log(nums[3]);
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
1
2
3
3
ऐरे ऑब्जेक्ट
सरणी ऑब्जेक्ट का उपयोग करके एक सरणी भी बनाई जा सकती है। अर्रे कंस्ट्रक्टर को निम्न के रूप में पारित किया जा सकता है -
एक संख्यात्मक मान जो सरणी के आकार का प्रतिनिधित्व करता है या।
अल्पविराम से अलग मूल्यों की एक सूची।
निम्न उदाहरण इस पद्धति का उपयोग करके एक सरणी बनाते हैं।
उदाहरण
var arr_names = new Array(4)
for(var i = 0;i<arr_names.length;i++) {
arr_names[i] = i * 2
console.log(arr_names[i])
}
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
0
2
4
6
उदाहरण: अर्रे कंस्ट्रक्टर कोमा से अलग हुए मानों को स्वीकार करता है
var names = new Array("Mary","Tom","Jack","Jill")
for(var i = 0;i<names.length;i++) {
console.log(names[i])
}
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
Mary
Tom
Jack
Jill
ऐरे तरीके
उनके विवरण के साथ ऐरे ऑब्जेक्ट के तरीकों की सूची निम्नलिखित है।
अनु क्रमांक | विधि और विवरण |
---|---|
1 | concat () इस सरणी से मिलकर एक नया सरणी लौटाता है, जो अन्य सरणी (एस) और / या मान के साथ शामिल होता है |
2 | हर एक() इस सरणी में प्रत्येक तत्व प्रदान किए गए परीक्षण फ़ंक्शन को संतुष्ट करता है, तो सही है। |
3 | फिल्टर () इस सरणी के सभी तत्वों के साथ एक नया सरणी बनाता है जिसके लिए प्रदान किया गया फ़िल्टरिंग फ़ंक्शन सही है। |
4 | प्रत्येक के लिए() सरणी में प्रत्येक तत्व के लिए एक फ़ंक्शन को कॉल करता है। |
5 | के सूचकांक() निर्दिष्ट मान के बराबर सरणी के भीतर एक तत्व का पहला (सबसे कम) सूचकांक लौटाता है, या -1 यदि कोई नहीं मिला है। |
6 | में शामिल होने के () किसी सरणी के सभी तत्वों को एक स्ट्रिंग में जोड़ता है। |
7 | lastIndexOf () किसी तत्व के अंतिम (सबसे बड़े) इंडेक्स को निर्दिष्ट मान के बराबर सरणी में लौटाता है, या -1 यदि कोई नहीं मिला है। |
8 | नक्शा() इस सरणी में प्रत्येक तत्व पर दिए गए फ़ंक्शन को कॉल करने के परिणामों के साथ एक नया सरणी बनाता है। |
9 | पॉप() किसी सरणी से अंतिम तत्व निकालता है और उस तत्व को वापस करता है। |
10 | धक्का दें() सरणी के अंत में एक या अधिक तत्व जोड़ता है और सरणी की नई लंबाई लौटाता है। |
1 1 | कम करना() किसी एक मान को कम करने के लिए सरणी के दो मूल्यों (बाएं से दाएं) के खिलाफ एक साथ एक फ़ंक्शन लागू करता है। |
12 | reduceRight () एक एकल मान को कम करने के लिए सरणी के दो मूल्यों (दाएं से बाएं) के खिलाफ एक साथ एक फ़ंक्शन लागू करता है। |
13 | उलटना() किसी सरणी के तत्वों के क्रम को उलट देता है - पहला अंतिम बन जाता है, और अंतिम पहले बन जाता है। |
14 | खिसक जाना() किसी सरणी से पहला तत्व निकालता है और उस तत्व को स्लाइस करता है। |
15 | टुकड़ा () किसी सरणी का एक भाग निकालता है और एक नया सरणी देता है। |
16 | कुछ() इस सरणी में कम से कम एक तत्व प्रदान किए गए परीक्षण फ़ंक्शन को संतुष्ट करता है, तो सही है। |
17 | toSource() किसी ऑब्जेक्ट के स्रोत कोड का प्रतिनिधित्व करता है। |
18 | प्रकार () एक सरणी के तत्वों को सॉर्ट करता है। |
19 | जोड़ () किसी सरणी से तत्वों को जोड़ता है और / या निकालता है। |
20 | तार() सरणी और उसके तत्वों का प्रतिनिधित्व करने वाला एक स्ट्रिंग लौटाता है। |
21 | unshift () एक या एक से अधिक तत्वों को एक सरणी के सामने जोड़ता है और सरणी की नई लंबाई लौटाता है। |
ईएस 6 - ऐरे तरीके
ES6 में पेश किए गए कुछ नए सरणी तरीके निम्नलिखित हैं।
Array.prototype.find
findआपको एक सरणी के माध्यम से पुनरावृत्त करने और पहला तत्व वापस लाने का कारण बनता है जो दिए गए कॉलबैक फ़ंक्शन को सही वापस लाने का कारण बनता है। एक तत्व मिल जाने के बाद, फ़ंक्शन तुरंत वापस आ जाता है। यह एक प्रभावी तरीका है जो किसी दिए गए शर्त से मेल खाता है।
Example
var numbers = [1, 2, 3];
var oddNumber = numbers.find((x) => x % 2 == 1);
console.log(oddNumber); // 1
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
1
Note - ईएस 5 filter() और ईएस 6 find()पर्यायवाची नहीं हैं। फ़िल्टर हमेशा मैचों की एक सरणी देता है (और कई मैचों को लौटाएगा), हमेशा वास्तविक तत्व वापस खोजें।
Array.prototype.findIndex
findIndex खोजने के लिए समान व्यवहार करता है, लेकिन जो तत्व मेल खाता है उसे वापस करने के बजाय, यह उस तत्व के सूचकांक को वापस करता है।
var numbers = [1, 2, 3];
var oddNumber = numbers.findIndex((x) => x % 2 == 1);
console.log(oddNumber); // 0
उपरोक्त उदाहरण आउटपुट के रूप में मूल्य 1 (0) के सूचकांक को लौटाएगा।
Array.prototype.entries
entriesएक फ़ंक्शन है जो एक सरणी Iterator देता है जिसका उपयोग सरणी की कुंजी और मान के माध्यम से लूप के लिए किया जा सकता है। प्रविष्टियाँ सरणी का एक सरणी लौटाएंगी, जहां प्रत्येक बाल सरणी एक सरणी है [सूचकांक, मूल्य]।
var numbers = [1, 2, 3];
var val = numbers.entries();
console.log(val.next().value);
console.log(val.next().value);
console.log(val.next().value);
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
[0,1]
[1.2]
[2,3]
वैकल्पिक रूप से, हम एक बार में प्रविष्टियों की एक सरणी वापस पाने के लिए प्रसार ऑपरेटर का भी उपयोग कर सकते हैं।
var numbers = [1, 2, 3];
var val= numbers.entries();
console.log([...val]);
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
[[0,1],[1,2],[2,3]]
Array.from
Array.from()ऑब्जेक्ट की तरह एक सरणी से एक नए सरणी के निर्माण को सक्षम करता है। Array.from () की मूल कार्यक्षमता दो प्रकार के मानों को Arrays में बदलना है -
एरे-जैसे मान।
सेट और मानचित्र जैसे उल्लेखनीय मूल्य।
Example
"use strict"
for (let i of Array.from('hello')) {
console.log(i)
}
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
h
e
l
l
o
Array.prototype.keys ()
यह फ़ंक्शन सरणी इंडेक्स देता है।
Example
console.log(Array.from(['a', 'b'].keys()))
उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
[ 0, 1 ]
लूप में…
एक के लिए उपयोग कर सकते हैं ... पाश में एक सरणी के माध्यम से पार करने के लिए।
"use strict"
var nums = [1001,1002,1003,1004]
for(let j in nums) {
console.log(nums[j])
}
लूप एक इंडेक्स-आधारित सरणी ट्रैवर्सल करता है। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।
1001
1002
1003
1004
जावास्क्रिप्ट में आता है
जावास्क्रिप्ट Arrays के बारे में निम्नलिखित अवधारणाओं का समर्थन करता है -
अनु क्रमांक | अवधारणा और विवरण |
---|---|
1 | बहुआयामी सरणियाँ जावास्क्रिप्ट बहुआयामी सरणियों का समर्थन करता है। बहुआयामी सरणी का सबसे सरल रूप द्वि-आयामी सरणी है |
2 | कार्यों के लिए सरणियाँ पासिंग आप एक इंडेक्स के बिना सरणी के नाम को निर्दिष्ट करके सरणी के लिए एक पॉइंटर को फ़ंक्शन को पास कर सकते हैं। |
3 | कार्यों से वापसी सरणी किसी फ़ंक्शन को सरणी वापस करने की अनुमति देता है। |
ऐरे डी-स्ट्रक्चरिंग
Destructuringएक सरणी या अलग-अलग चर में एक वस्तु से व्यक्तिगत मूल्यों को निकालने के लिए संदर्भित करता है। एक ऐसे परिदृश्य पर विचार करें जहां किसी सरणी के मानों को अलग-अलग चर के लिए सौंपा जाना चाहिए। इसे करने का पारंपरिक तरीका नीचे दिया गया है -
var a= array1[0]
var b= array1[1]
var c= array1[2]
विनाशकारी एक संक्षिप्त तरीके से उसी को प्राप्त करने में मदद करता है।
वाक्य - विन्यास
//destructuring an array
let [variable1,variable2]=[item1,item2]
//destructuring an object
let {property1,property2} = {property1:value1,property2:value2}
उदाहरण
<script>
let names = ['Mohtashim','Kannan','Kiran']
let [n1,n2,n3] = names;
console.log(n1)
console.log(n2)
console.log(n3);
//rest operator with array destructuring
let locations=['Mumbai','Hyderabad','Chennai']
let [l1,...otherValues] =locations
console.log(l1)
console.log(otherValues)
//variables already declared
let name1,name2;
[name1,name2] =names
console.log(name1)
console.log(name2)
//swapping
let first=10,second=20;
[second,first] = [first,second]
console.log("second is ",second) //10
console.log("first is ",first) //20
</script>
उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -
Mohtashim
Kannan
Kiran
Mumbai
["Hyderabad", "Chennai"]
Mohtashim
Kannan
second is 10
first is 20