ईएस 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