Skip to content

Latest commit

 

History

History
741 lines (575 loc) · 60.1 KB

File metadata and controls

741 lines (575 loc) · 60.1 KB

ஜாவாஸ்கிரிப்ட் அடிப்படைகள்: வரிசைகள் மற்றும் லூப்புகள்

JavaScript Basics - Arrays

ஸ்கெட்ச்நோட் தொமோமி இமுரா அவர்களால்

journey
    title உங்கள் வரிசைகள் மற்றும் 반복 பயணம்
    section வரிசை அடிப்படைகள்
      வரிசைகள் உருவாக்குதல்: 5: You
      கூறுகளங்கை அணுகுதல்: 4: You
      வரிசை முறைகள்: 5: You
    section 반복 தேர்ச்சி
      For 반복ுகள்: 4: You
      While 반복ுகள்: 5: You
      நவீன இலக்கணம்: 4: You
    section தரவு செயலாக்கம்
      வரிசை + 반복ுகள்: 5: You
      உண்மையான உலக பயன்பாடுகள்: 4: You
      செயல்திறன் மேம்பாடு: 5: You
Loading

முன்-வகுப்பு க்விஸ்

முன்-வகுப்பு க்விஸ்

வலைத்தளங்கள் எப்படி ஷாப்பிங் கார்ட் பொருட்களை கண்காணிக்கிறார்கள் அல்லது உங்கள் நட்பர்களின் பட்டியலை எவ்வாறு காட்டுகிறார்கள் என்று நீங்கள் யோசித்தீர்களா? அங்கே வரிசைகள் மற்றும் லூப்புகள் உதவுகின்றன. வரிசைகள் என்பது பல தகவல் துண்டுகளை வரும் ஒரு டிஜிட்டல் தொட்டி போன்றவை, லூப்புகள் அந்தத் தகவல்களை மறுபடியும் மீண்டும் எழுதாமல் ஆகச்செய்ய உதவுகின்றன.

இரண்டும் சேர்ந்து உங்கள் திட்டங்களில் தகவலை கையாளும் அடித்தளத்தை உருவாக்குகின்றன. நீங்கள் ஒவ்வொரு படியையும் கையால் எழுதுவதிலிருந்து, நூற்றுக்கணக்கான அல்லது ஆயிரக்கணக்கான பொருட்களை விரைவில் செயலாக்கும் புத்திசாலி, திறமையான குறியீட்டை உருவாக்க கற்றுக்கொள்வீர்கள்.

இந்த பாட முடிவில், குறைந்த வரிகளை கொண்ட குறியீட்டின் மூலம் சிக்கலான தரவு பணிகளை எவ்வாறு செய்யலாம் என்பதைப் புரிந்து கொள்வீர்கள். இந்த அடிப்படையான நிரலாக்க கருத்துக்களை ஆராய்ப்போம்.

வரிசைகள்

லூப்புகள்

🎥 மேலே உள்ள படங்களை கிளிக் செய்து வரிசைகள் மற்றும் லூப்புகளின் வீடியோக்களை பார்க்கலாம்.

இந்த பாடத்துக்கு நீங்கள் Microsoft Learn இல் செல்லலாம்!

mindmap
  root((தரவு செயலாக்கம்))
    Arrays
      Structure
        சதுர கோடுகள் உருவாக்கம்
        பூச்சூழல் அடிப்படையிலான அடையாளம்
        மாற்றக்கூடிய அளவு
      Operations
        push/pop
        shift/unshift
        indexOf/includes
      Types
        எண்கள் வரிசை
        எழுத்து வரிசை
        கலவை வகைகள்
    Loops
      For Loops
        கணக்கீட்டு மறுஅம்சங்கள்
        வரிசை செயலாக்கம்
        கணிக்கக்கூடிய ஓட்டம்
      While Loops
        நிபந்தனை அடிப்படை
        தெரியாத மறுஅம்சங்கள்
        பயனர் உள்ளீடு
      Modern Syntax
        for...of
        forEach
        செயல்பாட்டு முறைகள்
    Applications
      Data Analysis
        புள்ளிவிவரங்கள்
        வடிகட்டல்
        மாற்றங்கள்
      User Interfaces
        பட்டியல்கள்
        மெனுக்கள்
        கலக்கும் இடங்கள்
Loading

வரிசைகள்

வரிசைகளை ஒரு டிஜிட்டல் கோப்பு அலமாரி போல எண்ணுங்கள் - ஒவ்வொரு திடலில் ஒரு கோப்பை சேமிப்பதற்கு பதிலாக, ஒரே கட்டமைக்கப்பட்ட தொட்டியில் பல தொடர்புடைய பொருட்களை அமைக்கலாம். நிரலாக்க விதிகள் மூலம், வரிசைகள் பல தகவல் துண்டுகளை ஒரே ஒருங்கிணைந்த தொகுப்பில் சேமிக்க உதவுகின்றன.

நீங்கள் படம் காட்சித்தொகுப்பை உருவாக்கினாலும், செய்யவேண்டிய பணிப் பட்டியலை நிர்வகிக்கிறீர்களோ அல்லது ஒரு கேம் மேல் மதிப்புகளை கண்காணிக்கிறீர்கள் என்றாலும், வரிசைகள் தரவு ஒழுங்குமுறையின் அடித்தளமாக இருக்கின்றது. இப்போது அவற்றின் செயல்பாட்டைப் பார்க்கலாம்.

✅ வரிசைகள் எங்கும் உள்ளன! ஒரு உண்மையான வாழ்க்கை உதாரணமாக சோலார் பனல் வரிசையை நினைத்து பார்க்க முடியுமா?

வரிசைகள் உருவாக்கல்

வரிசைகளை உருவாக்குவது மிகவும் எளிது - வெறும் சதுரக் கோடுகள் பயன்படுத்துங்கள்!

// காலியான வரிசை - பொருட்களை காத்திருக்கும் காலியான ஷாப்பிங் கார்ட் போல
const myArray = [];

இங்கு என்ன நடக்கிறது? நீங்கள் வெறும் சதுரக் கோடுகள் [] பயன்படுத்தி காலியான தொட்டியை உருவாக்கியுள்ளீர்கள். இதை ஒரு காலியான நூலகத் தட்டில் போல நினைக்கலாம் - நீங்கள் அதை எந்த புத்தகங்களைக் கொண்டிருக்க விரும்பினாலும் கையாள்வதற்கு தயாரானது.

நீங்கள் உங்கள் வரிசையை ஆரம்பத்திலிருந்தே முதன்முதல் மதிப்புகளால் நிரப்பலாம்:

// உங்கள் ஐஸ்கிரீம் கடையின் சுவை பட்டியல்
const iceCreamFlavors = ["Chocolate", "Strawberry", "Vanilla", "Pistachio", "Rocky Road"];

// ஒரு பயனரின் சுயவிவர தகவல்கள் (வேறு வகை தரவுகளை கலந்து)
const userData = ["John", 25, true, "developer"];

// உங்கள் பிடித்த வகுப்புக்கான தேர்வு மதிப்பெண்கள்
const scores = [95, 87, 92, 78, 85];

கவர்ச்சியான விஷயங்கள்:

  • ஒரே வரிசையில் எழுத்துகள், எண்கள் அல்லது true/false மதிப்புகள் சேமிக்கலாம்
  • ஒவ்வொரு பொருளையும் கிளியை கொண்டு பிரிக்க வேண்டும் - எளிது!
  • வரிசைகள் தொடர்புடைய தகவலை ஒன்றாகவே நிர்வகிக்க சிறந்தது
flowchart LR
    A["📦 வரிசைகளை"] --> B["உருவாக்கு [ ]"]
    A --> C["பலவற்றை சேமி"]
    A --> D["அட்டவணை அடிப்படையில் செல்லு"]
    
    B --> B1["const arr = []"]
    B --> B2["const arr = [1,2,3]"]
    
    C --> C1["எண்கள்"]
    C --> C2["எழுத்துகள்"]
    C --> C3["பூலியன் மதிப்புகள்"]
    C --> C4["கலவுகள்"]
    
    D --> D1["arr[0] = முதல்"]
    D --> D2["arr[1] = இரண்டாவது"]
    D --> D3["arr[2] = மூன்றாவது"]
    
    E["📊 வரிசை அட்டவணை"] --> E1["அட்டவணை 0: முதல்"]
    E --> E2["அட்டவணை 1: இரண்டாவது"]
    E --> E3["அட்டவணை 2: மூன்றாவது"]
    E --> E4["அட்டவணை n-1: கடைசி"]
    
    style A fill:#e3f2fd
    style B fill:#e8f5e8
    style C fill:#fff3e0
    style D fill:#f3e5f5
    style E fill:#e0f2f1
Loading

வரிசை குறியீட்டல்

இது முதலில் வித்தியாசமாக தோன்றலாம்: வரிசைகள் தங்கள் பொருட்களை 0-இன் எண்ணிக்கையிலிருந்து தொடங்கி எண்கள் அடிக்கின்றன, 1-இல்ல. இந்த பூஜ்ய அடிப்படைக் குறியீட்டு அமைப்பு கணினி நினைவகப் பண்புகளிலிருந்தே வருகிறது - இது C போன்ற கணினி மொழிகளின் ஆரம்ப நாளிலிருந்து பயன்படுத்தப்படுகிறது. ஒவ்வொரு இடமும் ஒரு index எனப்படும் முகவரி எண்ணை பெறுகிறது.

குறியீடு மதிப்பு விளக்கம்
0 "Chocolate" முதல் உறுப்பினன்
1 "Strawberry" இரண்டாம் உறுப்பினன்
2 "Vanilla" மூன்றாம் உறுப்பினன்
3 "Pistachio" நான்காம் உறுப்பினன்
4 "Rocky Road" ஐந்தாம் உறுப்பினன்

✅ நீங்கள் வரிசைகள் பூஜ்ய குறியீட்டிலிருந்து தொடங்குவதை மகிழ்ச்சியுடன் ஏற்றுகிறீர்களா? சில நிரலாக்க மொழிகளில் குறியீடுகள் 1-இன் எண்ணிக்கையிலிருந்து தொடங்குகின்றன. இதன் பின்னணியில் ஒரு சுவாரஸ்யமான வரலாறு உள்ளது, அதைப் விக்கிப்பீடியாவில் படிக்கலாம்.

வரிசை உறுப்பினர்களைப் பெறுதல்:

const iceCreamFlavors = ["Chocolate", "Strawberry", "Vanilla", "Pistachio", "Rocky Road"];

// கோப்பை குறிக்கோள் நோட்டேஷன் பயன்படுத்தி தனிப்பட்ட உருப்படிகளை அணுகவும்
console.log(iceCreamFlavors[0]); // "Chocolate" - முதல் உருப்படி
console.log(iceCreamFlavors[2]); // "Vanilla" - மூன்றாவது உருப்படி
console.log(iceCreamFlavors[4]); // "Rocky Road" - கடைசி உருப்படி

இங்கு என்ன நடக்கிறது:

  • குறியீட்டை அடையாளப்படுத்த சதுரக் கோடுகள் அழைப்பாகக் கொண்டுள்ளது
  • ஒரு குறிப்பிட்ட இடத்தில் இருக்கும் மதிப்பை ফেরுத்து தருகின்றது
  • 0-இன் எண்ணிக்கையிலிருந்து உருப்படிகளை எண்ணுகிறது, அதனால் முதல் உறுப்பினன் குறியீடு 0 ஆகும்

வரிசை உறுப்பினர்களை மாற்றுதல்:

// ஒரு உள்ளிருக்கும் மதிப்பை மாற்றவும்
iceCreamFlavors[4] = "Butter Pecan";
console.log(iceCreamFlavors[4]); // "வெண்ணெய் பீக்கன்"

// முடிவில் ஒரு புதிய உருப்படியை சேர்க்கவும்
iceCreamFlavors[5] = "Cookie Dough";
console.log(iceCreamFlavors[5]); // "குக்கி கோ"

மேலே நாம்:

  • குறைந்த 4 குறியீட்டின் "Rocky Road" என்பதை "Butter Pecan" ஆக மாற்றி விட்டோம்
  • குறைந்த 5 இடத்தில் புதிய "Cookie Dough" உறுப்பினரை சேர்த்தோம்
  • வரிசை நீளம் தானாக அதிகரிக்கிறது, கட்டுப்பாட்டுக்கு வெளியே சேர்க்கையில்

வரிசை நீளம் மற்றும் பொதுவான முறைகள்

வரிசைகள் பல முக்கிய பணிகளை எளிதாக்க builtin பண்புகள் மற்றும் முறைகள் கொண்டுள்ளன.

வரிசை நீளம் கண்டறிதல்:

const iceCreamFlavors = ["Chocolate", "Strawberry", "Vanilla", "Pistachio", "Rocky Road"];
console.log(iceCreamFlavors.length); // 5

// விரிசல் மாற்றப்படுவதுடன் நீளம் தானாக புதுப்பிக்கப்படும்
iceCreamFlavors.push("Mint Chip");
console.log(iceCreamFlavors.length); // 6

முக்கியக் குறிப்புகள்:

  • சொடுக்குகளை மொத்த எண்ணிக்கையைத் தருகிறது
  • உறுப்பினர்கள் சேர்க்கப்பட்டாலும் அல்லது நீக்கப்பட்டாலும் தானாக புதுப்பிக்கிறது
  • லூப்புகள் மற்றும் சரிபார்ப்புகளுக்கான இயல்பான எண்ணிக்கை தருகிறது

அவசியமான வரிசை முறைகள்:

const fruits = ["apple", "banana", "orange"];

// கூறுகள் சேர்க்கவும்
fruits.push("grape");           // அடிப்பகுதியில் சேர்க்கிறது: ["ஆப்பிள்", "வாழைப்பழம்", "ஆரஞ்சு", "திராட்சை"]
fruits.unshift("strawberry");   // துவக்கத்தில் சேர்க்கிறது: ["ஸ்ட்ராபெர்ரி", "ஆப்பிள்", "வாழைப்பழம்", "ஆரஞ்சு", "திராட்சை"]

// கூறுகளை அகற்று
const lastFruit = fruits.pop();        // "திராட்சை" ஐ அகற்றி மீட்டெடுக்கின்றது
const firstFruit = fruits.shift();     // "ஸ்ட்ராபெர்ரி" ஐ அகற்றி மீட்டெடுக்கின்றது

// கூறுகளை கண்டுபிடி
const index = fruits.indexOf("banana"); // 1 ஐ 반환 செய்கிறது ("வாழைப்பழம்" இடம்)
const hasApple = fruits.includes("apple"); // உண்மை 반환 செய்கிறது

இந்த முறைகளை புரிந்துகொள்வது:

  • push() (இறுதியில்) மற்றும் unshift() (ஆரம்பத்தில்) உருப்படிகளை சேர்க்கும்
  • pop() (இறுதியில்) மற்றும் shift() (ஆரம்பத்தில்) உருப்படிகளை நீக்கும்
  • indexOf() மூலம் உருப்படிகளை கண்டறிந்து, includes() மூலம் இருப்பதை உறுதிப்படுத்தும்
  • நீக்கப்பட்ட உருப்படிகள் மற்றும் இடங்களைத் திருப்பி தரும்

✅ உங்களின் உலாவி console இல் உங்கள் சொந்த வரிசையை உருவாக்கி சோதிக்கவும்.

🧠 வரிசை அடிப்படைகள் சரிபார்ப்பு: உங்கள் தரவை ஒழுங்குபடுத்துதல்

உங்கள் வரிசை புரிதலைச் சோதிக்க:

  • ஏன் வரிசைகள் 0-இல் இருந்து எண்ண தொடங்குகின்றன என்று நினைக்கிறீர்கள்?
  • ஒரு கிடைக்கும் இடம் இல்லாமல் பார்க்க முயற்சித்தால் (உதா: 5-உறுப்படிகள் கொண்ட வரிசையில் arr[100]) என்ன நடக்கும்?
  • வரிசைகள் பயன்படும் மூன்று நிஜ உலகக் காட்சிகளை நினைத்துக் கொள்ளுங்கள்?
stateDiagram-v2
    [*] --> EmptyArray: const arr = []
    EmptyArray --> WithItems: உருப்படிகளைச் சேர்க்கவும்
    WithItems --> Accessing: குறியீடுகளைப் பயன்படுத்தவும்
    Accessing --> Modifying: மதிப்புகளை மாற்றவும்
    Modifying --> Processing: முறைகள் பயன்படுத்தவும்
    
    WithItems --> WithItems: push(), unshift()
    Processing --> Processing: pop(), shift()
    
    note right of Accessing
        பூஜ்ய அடிப்படையிலான குறியீடு
        arr[0] = முதல் உருப்படி
    end note
    
    note right of Processing
        உள்ளமைவு முறைகள்
        இயக்கங்கள் மாற்றமடைந்தவை
    end note
Loading

நிஜ உலகத்தில் புரிதல்: நிரலாக்கத்தில் வரிசைகள் எங்கும் உள்ளன! சமூக ஊடக ஃபீட்கள், ஷாப்பிங் கார்ட்கள், படக் காட்சிப்படுத்தல்கள், பாடல் பட்டியல்கள் - இவை எல்லாம் பின்னணியில் வரிசைகளாக உள்ளன!

லூப்புகள்

சார்லஸ் டிக்கன்ஸின் நாவல்களில் மாணவர்கள் பலமுறை ஒரு கோரிக்கையை எழுத கட்டாயம் செய்ததற்கான புகழ்பெற்ற தண்டனை உதாரணத்தை நினைத்துக்கொள்ளுங்கள். நீங்கள் ஒருவருக்கு "இந்த வசனத்தை 100 முறை எழுது" என்று சொன்னால் தானாகவே அது செய்யப்படும் என்றால்? அதுவே லூப்புகள் உங்கள் குறியீட்டுக்கு செய்கின்றன.

லூப்புகள் தவறுகள் இல்லாமல் பணிகளை மீண்டும் மீண்டும் செய்யும் ஒரு மாற்றமில்லாத உதவியாளராக இருக்கின்றன. நீங்கள் ஒரு ஷாப்பிங் கார்டின் ஒவ்வொரு பொருளையும் பரிசோதிக்க வேண்டும் என்றாலும், அல்லது ஒரு ஆல்பத்தில் உள்ள அனைத்து படங்களையும் காட்ட வேண்டும் என்பாலும், லூப்புகள் அந்தப் பணிகளை திறமையாக கையாள்கின்றன.

ஜாவாஸ்கிரிப்ட் பல வகையான லூப்புகளை வழங்குகிறது. ஒவ்வொன்றையும் பகுப்பாய்வு செய்து எப்போது பயன்படுத்துவது என்பதைப் புரிந்து கொள்வோம்.

flowchart TD
    A["🔄 குறுக்கெழுத்து வகைகள்"] --> B["For குறுக்கெழுத்து"]
    A --> C["While குறுக்கெழுத்து"]
    A --> D["For...of குறுக்கெழுத்து"]
    A --> E["forEach முறை"]
    
    B --> B1["அறிவிக்கப்பட்ட சுற்றுகள்"]
    B --> B2["எண்ணி அடிப்படையிலான"]
    B --> B3["for(init; condition; increment)"]
    
    C --> C1["தெரியாத சுற்றுகள்"]
    C --> C2["நிலைய அடிப்படையிலான"]
    C --> C3["while(condition)"]
    
    D --> D1["நவீன ES6+"]
    D --> D2["அணி சுற்றும்"]
    D --> D3["for(item of array)"]
    
    E --> E1[" செயல்பாட்டு நடைமை"]
    E --> E2["அணி முறை"]
    E --> E3["array.forEach(callback)"]
    
    F["⏰ பயன்படுத்த எப்போது"] --> F1["For: எண்ணிக்கை, குறியீடுகள்"]
    F --> F2["While: பயனர் உள்ளீடு, தேடல்"]
    F --> F3["For...of: எளிய சுற்று"]
    F --> F4["forEach: செயல்பாட்டு நிரலாசிரியல்"]
    
    style A fill:#e3f2fd
    style B fill:#e8f5e8
    style C fill:#fff3e0
    style D fill:#f3e5f5
    style E fill:#e0f2f1
    style F fill:#fce4ec
Loading

for லூப்

for லூப் ஒரு டைமர் அமைப்பதைப் போல - நீங்கள் எத்தனை முறை நடப்பதாக வேண்டுமென்று தெரிந்து காணலாம். இது மிகவும் ஒழுங்கமைக்கப்பட்ட மற்றும் கணிப்பிடக்கூடியது, அதனால் வரிசைகளுடன் வேலை செய்யும்போது அல்லது எண்ணிக்கைகளை கணக்கிடும் போது இது சிறந்தது.

for லூப் அமைப்பு:

கூறு நோக்கம் உதாரணம்
தொடக்கீடு தொடக்க புள்ளி அமைக்கும் let i = 0
நிபந்தனை எப்போது தொடர வேண்டும் i < 10
மேல் செல்லல் எப்படி புதுப்பிக்க i++
// 0 முதல் 9 வரை எண்ணுவது
for (let i = 0; i < 10; i++) {
  console.log(`Count: ${i}`);
}

// மேலும் நடைமுறை உதாரணம்: மதிப்பெண்களை செயலாக்குவது
const testScores = [85, 92, 78, 96, 88];
for (let i = 0; i < testScores.length; i++) {
  console.log(`Student ${i + 1}: ${testScores[i]}%`);
}

எடுத்துக்காட்டாக, என்ன நடக்கிறது:

  • கணக்கிடுவதை i என்ற மாறியை தொடக்கத்தில் 0 ஆக ஆரம்பிக்கிறது
  • ஒவ்வொரு முறை இயக்கத்திற்கு முன் i < 10 என்ற நிபந்தனையை பரிசோதிக்கிறது
  • நிபந்தனை உண்மையானபோது குறியீட்டு தொகுதியை இயக்குகிறது
  • ஒவ்வொரு முறை பிறகு i-ஐ 1-ஆக அதிகரிக்கிறது i++ மூலம்
  • நிபந்தனை துெறிவானபோது (i 10 ஆகும் போது) நிறுத்துகிறது

✅ உலாவி console இல் இந்த குறியீட்டைக் இயக்குங்கள். கணக்கிடும் மாறி, நிபந்தனை அல்லது மறுநிரலாக்க தொடர்ச்சியில் சிறிய மாற்றங்கள் செய்தால் என்ன நடக்கும்? நீங்கள் அதை பின்னோக்கி இயங்கச் செய்யவா, தொலைவுக் கணக்கெடுப்பாக மாற்ற முடியுமா?

🗓️ for லூப் தேர்வு: கட்டுப்படுத்தப்பட்ட மீண்டும் செயல்

உங்கள் for லூப் புரிதலை மதிப்பாய்வு செய்ய:

  • ஒரு for லூப்பின் மூன்று பகுதிகள் என்ன மற்றும் ஒவ்வொன்றும் என்ன செய்கின்றன?
  • வரிசையை பின்னோக்கி எப்படி சுற்றிப்பார்ப்பது?
  • நீங்கள் மேல் செல்லல் பகுதியை (i++) மறந்துவிட்டால் என்ன நிகழும்?
flowchart TD
    A["🚀 For Loop துவக்கம்"] --> B["ஆரம்பி: let i = 0"]
    B --> C{"நிபந்தனை: i < array.length?"}
    C -->|true| D["குறியீடு தொகுதி செயல்படுத்தவும்"]
    D --> E["உயர்த்துக: i++"]
    E --> C
    C -->|false| F["✅ Loop இல் இருந்து வெளியேறு"]
    
    G["📋 பொதுவான மாதிரிகள்"] --> G1["for(let i=0; i<n; i++)"]
    G --> G2["for(let i=n-1; i>=0; i--)"]
    G --> G3["for(let i=0; i<arr.length; i+=2)"]
    
    style A fill:#e3f2fd
    style F fill:#e8f5e8
    style G fill:#fff3e0
Loading

லூப் ஞானம்: நீங்கள் எத்தனை முறை நடக்கும் என்று தெரிந்திருக்கும் போது for லூப்புகள் சிறந்தவை. வரிசை செயலாக்கத்திற்கான மிகவும் பொதுவான தேர்வு!

while லூப்

while லூப் என்பது "இதுவரை செய்ய..." என்பதுபோல் - அதுவெவ்வளவு முறை நடக்கும் என்று தெரியாது, ஆனால் எப்போது நிறுத்துவது என்பது தெரியும். அது பயனரிடமிருந்து தேவையான உள்ளீட்டை பெறும் வரை கேட்க அல்லது தரவுகளில் தேடும்போது சிறந்தது.

while லூப்பின் பண்புகள்:

  • நிபந்தனை உண்மையானது வரைக்கும் தொடர்ச்சியாக இயங்கும்
  • எந்தவொரு கணக்கிடும் மாறியையும் உங்கள் கைமுறையாளர் நிர்வகிக்க வேண்டும்
  • ஒவ்வொரு முறை இயக்கத்திற்கு முன் நிபந்தனையை பரிசோதிக்கிறது
  • நிபந்தனை மெய்மையாக மாறாதிருக்கின் நோக்கி நீளக் கால லூப்புகள் உண்டாகும் அபாயம் உள்ளது
// அடிப்படை எண்ணிக்கை உதாரணம்
let i = 0;
while (i < 10) {
  console.log(`While count: ${i}`);
  i++; // அதிகரிப்பதை மறக்காதீர்கள்!
}

// அதிக நடைமுறை உதாரணம்: பயனர் உள்ளீட்டை செயலாக்குதல்
let userInput = "";
let attempts = 0;
const maxAttempts = 3;

while (userInput !== "quit" && attempts < maxAttempts) {
  userInput = prompt(`Enter 'quit' to exit (attempt ${attempts + 1}):`);
  attempts++;
}

if (attempts >= maxAttempts) {
  console.log("Maximum attempts reached!");
}

இந்த எடுத்துக்காட்டுகளை புரிந்துகொள்ள:

  • லூப் உட்கருத்தில் கணக்கிடும் மாறி i கைமுறை நிர்வகிக்கப்படுகிறது
  • அளவிற்குள் இருக்கக் காக்க கணக்கிடும் மாறி அதிகரிக்கப்படுகிறது
  • பயனர் உள்ளீட்டு மற்றும் முயற்சி வரம்புகளுடன் நடைமுறை பயன்பாட்டைக் காட்டுகிறது
  • முடிவில்லாத செயல்பாடுகளைத் தவிர்க்க பாதுகாப்பு முறைகள் உள்ளது

♾️ while லூப் ஞானம்: நிபந்தனை அடிப்படையிலான மீண்டும் செயல்

தனது while லூப் புரிதலை சோதிக்க:

  • while லூப்புகளில் முக்கிய ஆபத்து என்ன?
  • எப்போது for லூப்புக்கு பதிலாக while லூப்பை நீங்கள் தேர்ந்தெடுப்பீர்கள்?
  • முடிவில்லாத லூப்புகளைத் தவிர்ப்பது எப்படி?
flowchart LR
    A["🔄 While vs For"] --> B["While Loop"]
    A --> C["For Loop"]
    
    B --> B1["அறியப்படாத சுற்றங்கள்"]
    B --> B2["நிலை சார்ந்தது"]
    B --> B3["பயனர் உள்ளீடு, தேடல்"]
    B --> B4["⚠️ அபாயம்: முடிவில்லா சுற்றங்கள்"]
    
    C --> C1["அறிந்த சுற்றங்கள்"]
    C --> C2["எண்ணிக்கையை மீறி இயக்கப்படுகிறது"]
    C --> C3["அணிச் செயலாக்கம்"]
    C --> C4["✅ பாதுகாப்பானது: கணிக்கக்கூடிய முடிவு"]
    
    D["🛡️ பாதுகாப்பு குறிப்புகள்"] --> D1["எப்பொழுதும் நிலை மாறி மாற்றவும்"]
    D --> D2["தப்பிச் செல்லும் நிலைகள் சேர்க்கவும்"]
    D --> D3["அதிகபட்ச சுற்ற அளவுகளை அமைக்கவும்"]
    
    style A fill:#e3f2fd
    style B fill:#fff3e0
    style C fill:#e8f5e8
    style D fill:#ffebee
Loading

பாதுகாப்பு முதலில்: while லூப்புகள் சக்திவாய்ந்தவை ஆனால் நிபந்தனைப் பராமரிப்பு மிக முக்கியம். உங்கள் லூப் நிபந்தனை இறுதியில் தவறாக மாறும் என்பதை உறுதி செய்யவும்!

நவீன லூப் மாற்றி வழிகள்

ஜாவாஸ்கிரிப்ட் உங்கள் குறியீட்டை மேலும் வாசிக்கக்கூடியதும் குறைவான தவறுகளுடையதுமானதாக செய்ய நவீன லூப் சொற்றொடர்களை வழங்குகிறது.

For...of லூப் (ES6+):

const colors = ["red", "green", "blue", "yellow"];

// நவீன அணுகுமுறை - சுத்தமான மற்றும் பாதுகாப்பானது
for (const color of colors) {
  console.log(`Color: ${color}`);
}

// பாரம்பரிய for வளைவில் இணைத்து பார்க்கவும்
for (let i = 0; i < colors.length; i++) {
  console.log(`Color: ${colors[i]}`);
}

for...of இன் முக்கிய நன்மைகள்:

  • குறியீட்டை நிர்வகிக்க வேண்டிய தேவையைக் குறைத்தல் மற்றும் off-by-one பிழைகளை தவிர்ப்பு
  • வரிசை உறுப்பினர்களுக்கு நேரடியாக அணுகல் வழங்கல்
  • குறியீடு வாசிப்புக்கு எளிதாக்கம் மற்றும் சொற்றொடர் சிக்கல்களை குறைத்தல்

forEach முறை:

const prices = [9.99, 15.50, 22.75, 8.25];

// செயல்பாட்டு நிரலாக்க ಶೈಲிக்காக forEach ಉಪಯೋಗಿಸಿ
prices.forEach((price, index) => {
  console.log(`Item ${index + 1}: $${price.toFixed(2)}`);
});

// ಸರಳ ಕಾರ್ಯಗಳಿಗೆ ತூரಿಕಾರ ರಚನೆಗಳೊಂದಿಗೆ forEach
prices.forEach(price => console.log(`Price: $${price}`));

forEach பற்றி நீங்கள் அறிவது:

  • ஒவ்வொரு வரிசை உறுப்பிற்கும் ஒரு செயல்பாட்டை இயக்குகிறது
  • உறுப்பினர் மதிப்பையும் குறியீட்டையும் அளவுருக்களாக வழங்குகிறது
  • பூர்வ ரசிக லூப்புகளால் நிறுத்த முடியாது
  • undefined ஐ திருப்பி தருகிறது (புதிய வரிசை உருவாக்காது)

✅ நீங்கள் ஏன் for லூப்பிற்கு பதிலாக while லூப்பை தேர்ந்தெடுப்பீர்கள்? StackOverflow இல் 17 ஆயிரம் பார்வையாளர்கள் இதைப் பற்றி கேள்வி எழுப்பியுள்ளனர், சில கருத்துக்கள் உங்களுக்குப் பயனாக இருக்கலாம்.

🎨 நவீன லூப் சொற்றொடர் தேர்வு: ES6+ஐ அங்கீகரித்தல்

உங்கள் நவீன ஜாவாஸ்கிரிப்ட் புரிதலை மதிப்பாய்வு செய்ய:

  • பாரம்பரிய for லூப்புகளுக்கு மாற்றாக for...of இன் நன்மைகள் என்ன?
  • எப்போது நீங்கள் பாரம்பரிய for லூப்பை விரும்பலாம்?
  • forEach மற்றும் map இன் வேறுபாடு என்ன?
quadrantChart
    title சுழற்சி தேர்வு வழிகாட்டு
    x-axis பாரம்பரிய --> நவீன
    y-axis எளிய --> சிக்கலான
    quadrant-1 நவீன சிக்கலான
    quadrant-2 பாரம்பரிய சிக்கலான
    quadrant-3 பாரம்பரிய எளிய
    quadrant-4 நவீன எளிய
    
    பாரம்பரிய For: [0.2, 0.7]
    While Loop: [0.3, 0.6]
    For...of: [0.8, 0.3]
    forEach: [0.9, 0.4]
    அணி முறைகள்: [0.8, 0.8]
Loading

நவீன செயல்: ES6+ சொற்றொடர்கள் போன்ற for...of மற்றும் forEach வரிசை சுழற்சிக்கான முன்னுரிமை வாய்ந்த அணுகுமுறையாக மாறியுள்ளன, ஏனெனில் அவை நியாயபூர்வமானதும் குறைந்த பிழைகளுடனும் இருக்கின்றன!

லூப்புகளும் வரிசைகளும்

வரிசைகளுடன் லூப்புகளை இணைத்தல் வலுவான தரவு செயலாக்க திறன்களை ஏற்படுத்துகிறது. பட்டியல்கள் காட்டுதல் முதல் புள்ளிவிவர கணக்கீடு வரை பல நிரலாக்க பணிகளுக்கான அடிப்படையாக இணைப்பு உள்ளது.

பாரம்பரிய வரிசை செயலாக்கம்:

const iceCreamFlavors = ["Chocolate", "Strawberry", "Vanilla", "Pistachio", "Rocky Road"];

// பாரம்பரிய for லூப் அணுகுமுறை
for (let i = 0; i < iceCreamFlavors.length; i++) {
  console.log(`Flavor ${i + 1}: ${iceCreamFlavors[i]}`);
}

// நவீன for...of அணுகுமுறை
for (const flavor of iceCreamFlavors) {
  console.log(`Available flavor: ${flavor}`);
}

ஒவ்வொரு முறையிலும் பார்க்கலாம்:

  • லூப் எல்லையைத் தீர்மானிக்க வரிசை நீளம் பண்பை பயன்படுத்துகிறது
  • பாரம்பரிய for லூப்பில் குறியீட்டை கொண்டு உறுப்பினரை அணுகுகிறது
  • for...of லூப்பில் நேரடியாக உறுப்பினரை அணுகுகிறது
  • ஒவ்வொரு உறுப்பினரையும் ஒருமுறை முறையாக செயலாக்குகிறது

உயிரியல் தரவு செயலாக்க உதாரணம்:

const studentGrades = [85, 92, 78, 96, 88, 73, 89];
let total = 0;
let highestGrade = studentGrades[0];
let lowestGrade = studentGrades[0];

// ஒரு ஒற்றை சுற்று கொண்டு அனைத்து மதிப்பெண்களையும் செயலாக்கவும்
for (let i = 0; i < studentGrades.length; i++) {
  const grade = studentGrades[i];
  total += grade;
  
  if (grade > highestGrade) {
    highestGrade = grade;
  }
  
  if (grade < lowestGrade) {
    lowestGrade = grade;
  }
}

const average = total / studentGrades.length;
console.log(`Average: ${average.toFixed(1)}`);
console.log(`Highest: ${highestGrade}`);
console.log(`Lowest: ${lowestGrade}`);

இந்த குறியீடு எப்படி செயல்படுகிறது:

  • மொத்தம் மற்றும் உயர்ந்த/குறைந்த மதிப்புகள் கண்காணிப்பதை தொடங்கி நிலைத்துவைக்கிறது
  • ஒவ்வொரு மதிப்பையும் ஒன்றுதான் ஓர் திறமையான லூப்பில் செயலாக்குகிறது
  • சராசரி கணக்கீட்டுக்கு மொத்தத்தை சேர்க்கிறது
  • சுழற்சியின் போது மிக உயர்ந்த மற்றும் மிகக் குறைந்த மதிப்புகளைக் கண்காணிக்கிறது
  • லூப்புக்குப் பிறகு இறுதி புள்ளிவிவரங்களை கணக்கிடுகிறது

✅ உங்களது உலாவி console இல் தானாக உருவாக்கிய வரிசையை பயன்படுத்தி லூப்புக்களுடன் முயற்சி செய்யவும்.

flowchart TD
    A["📦 வரிசை தரவு"] --> B["🔄 சுழற்சி செயலாக்கம்"]
    B --> C["📈 முடிவுகள்"]
    
    A1["[85, 92, 78, 96, 88]"] --> A
    
    B --> B1["மொத்தம் கணக்கிடுக"]
    B --> B2["குறைவான/அதிகபட்சம் கண்டுபிடிக்க"]
    B --> B3["நிலைகளைக் கணக்கிடுக"]
    B --> B4["தரவுகளை மாற்றுக"]
    
    C --> C1["சராசரி: 87.8"]
    C --> C2["அதிகபட்சம்: 96"]
    C --> C3["தேர்வில் உத்தேசம்: 5/5"]
    C --> C4["அட்சர மதிப்பெண்கள்"]
    
    D["⚡ செயலாக்க முறைமைகள்"] --> D1["சங்கலனம் (மொத்தம்)"]
    D --> D2["தோற்றுமாறுதல் (குறைவான/அதிகபட்ச)"]
    D --> D3["வடிகட்டு (நிலைகள்)"]
    D --> D4["வருடிவோட்டம் (மாற்றம்)"]
    
    style A fill:#e3f2fd
    style B fill:#fff3e0
    style C fill:#e8f5e8
    style D fill:#f3e5f5
Loading

GitHub Copilot முகவர் சவால் 🚀

Agent முறையைப் பயன்படுத்தி கீழ்க்கண்ட சவாலை முடிக்கவும்:

விளக்கம்: ஒரு தரவுத்தொகுப்பை பகுப்பாய்வு செய்து பொருத்தமான விளக்கங்களை உருவாக்கும் வரிசைகள் மற்றும் லூப்புகளை இணைத்த ஒரு சிக்கலான தரவு செயலாக்க முறை/function உருவாக்குக.

கட்டளை: analyzeGrades என்ற ஒரு function உருவாக்கவும், இது மாணவர் மதிப்பெண் பொருள் கொண்ட ஒரு வரிசையை (ஒவ்வொன்றும் பெயர் மற்றும் மதிப்பெண் பண்புகளை கொண்டது) எடுத்துக்கொண்டு, அதிகபட்ச மதிப்பெண், குறைந்தபட்ச மதிப்பெண், சராசரி மதிப்பெண், தேர்ச்சி பெற்ற மாணவர்களின் எண்ணிக்கை (மதிப்பெண் >= 70), மற்றும் சராசரிக்கு மேல் மதிப்பெண் பெற்ற மாணவர்களின் பெயர் வரிசையை உட்பொதிகிறது. உங்கள் தீர்வில் குறைந்தது இரண்டு விதமான லூப்புகளை பயன்படுத்தவும்.

மேலும் அறிய agent mode இல்.

🚀 சவால்

JavaScript பல நவீன வரிசை முறைகளை வழங்குகிறது, அவை குறிப்பிட்ட பணிகளுக்காக பாரம்பரிய 반복ங்களை மாற்ற முடியும். forEach, for-of, map, filter, மற்றும் reduce ஆகியவற்றை ஆராயுங்கள்.

உங்கள் சவால்: மாணவர் மதிப்பெண் எடுத்துக்காட்டை குறைந்தது மூன்று விதமான வரிசை முறைகளைக் கொண்டு மறுசீரமைக்கவும். நவீன JavaScript نحو பயன்படுத்தி குறியீடு எவ்வளவு சுத்தமாகவும் தெளிவாகவும் மாறுகிறதோ கவனியுங்கள்.

பாடத்துக்குப் பின் வினாடி வினா

பாடத்துக்குப் பின் வினாடி வினா

பரிசீலனை & தனிப்பட்ட ஆய்வு

JavaScript இல் வரிசைகளுக்கு அண்மையில் பல முறைகள் சேர்க்கப்பட்டுள்ளன, அவை தரவு கையாள்வதற்கு மிகவும் பயனுள்ளதாக இருக்கின்றன. இந்த முறைகள் பற்றி படியுங்கள் மற்றும் உங்கள் உருவாக்கிய வரிசையில் சிலவற்றை (push, pop, slice மற்றும் splice போன்றவை) முயற்சிக்கவும்.

பணிகள்

ஒரு வரிசையை சுழற்றுக


📊 உங்கள் வரிசைகள் மற்றும் 반복 கருவி தொகுப்பின் சுருக்கம்

graph TD
    A["🎯 வரிசைகள் & தொடர்கள் தேர்ச்சி"] --> B["📦 வரிசை அடிப்படைகள்"]
    A --> C["🔄 தொடர் வகைகள்"]
    A --> D["🔗 தரவு செயலாக்கம்"]
    A --> E["🎨 நவீன தொழில்நுட்பங்கள்"]
    
    B --> B1["செயல்: [ ]"]
    B --> B2["இண்டெக்ஸ் செட்: arr[0]"]
    B --> B3["முறைகள்: push, pop"]
    B --> B4["முன்னெச்சரிக்கை: length"]
    
    C --> C1["For: தெரிந்த முறை"]
    C --> C2["While: நிபந்தனை அடிப்படையில்"]
    C --> C3["For...of: நேரடி அணுகல்"]
    C --> C4["forEach: செயல்பாட்டு"]
    
    D --> D1["புள்ளிவிவர கணக்கீடு"]
    D --> D2["தரவு மாற்றம்"]
    D --> D3["வடிகட்டல் & தேடல்"]
    D --> D4["اسல் நேர செயலாக்கம்"]
    
    E --> E1["அரோ ஃபங்ஷன்கள்"]
    E --> E2["முறை சங்கிலி"]
    E --> E3["பிளவி"]
    E --> E4["டெம்ப்ளேட் எழுத்துக்கள்"]
    
    F["💡 முக்கிய நன்மைகள்"] --> F1["தரவு பராமரிப்பு திறன்"]
    F --> F2["குறியீடு மீண்டும் எழுதல் குறைவு"]
    F --> F3["விருத்திக்கக்கூடிய தீர்வுகள்"]
    F --> F4["தூய syntax"]
    
    style A fill:#e3f2fd
    style B fill:#e8f5e8
    style C fill:#fff3e0
    style D fill:#f3e5f5
    style E fill:#e0f2f1
    style F fill:#fce4ec
Loading

🚀 உங்கள் வரிசைகள் மற்றும் 반복 திறமை நேர வரிசை

அடுத்து 5 நிமிடங்களில் செய்யக்கூடியவை

  • உங்கள் விருப்பமான திரைப்படங்களின் ஒரு வரிசையை உருவாக்கி குறிப்பிட்ட உருப்படிகளை அணுகவும்
  • 1 இருந்து 10 வரை எண்ணும் ஒரு for 반복ம் எழுதவும்
  • பாடத்தில் உள்ள நவீன வரிசை முறைகளுக்கான சவாலை முயற்சிக்கவும்
  • உலாவியில் வரிசை குறியீட்டைப் பயிற்சி செய்யவும்

🎯 இந்த மணிநேரத்தில் சாதிக்க முடியவுள்ளவை

  • பாடத்துக்குப் பின் வினாடி வினாவை முடித்து சிக்கலான கருத்துக்களை மதிப்பாய்வு செய்யவும்
  • GitHub Copilot சவாலிலிருந்து முழுமையான மதிப்பெண் பகுப்பாய்வையாளர் உருவாக்கவும்
  • பொருட்களை சேர்க்கும் மற்றும் அகற்றும் எளிய ஷாப்பிங் கார்ட் உருவாக்கவும்
  • விதிவிலக்கான 반복 வகைகளை மாற்றும் பயிற்சிகள் செய்யவும்
  • push, pop, slice, மற்றும் splice போன்ற வரிசை முறைகளைப் பயன்படுத்தி முயற்சி செய்யவும்

📅 உங்கள் வாராந்திர தரவு செயலாக்க பயணம்

  • "ஒரு வரிசையை சுழற்றுக" பணியை படைப்பாற்றலுடன் முடிக்கவும்
  • வரிசைகள் மற்றும் 반복ங்களைக் கொண்டு ஒரு பணியாளர்கள் பட்டியல் செயலி உருவாக்கவும்
  • எண்களின் எளிய புள்ளியியல் கணக்கிடியை உருவாக்கவும்
  • MDN வரிசை முறைகளை பயிற்சி செய்யவும்
  • புகைப்படக் காட்சியகம் அல்லது இசை பட்டியல் இடைமுகம் உருவாக்கவும்
  • map, filter, மற்றும் reduce போன்ற செயல்பாடுகள் அடிப்படையிலான நிரலாக்கத்தை ஆராயவும்

🌟 உங்கள் மாதநிலை மாற்றம்

  • முன்னோடிய வரிசை செயல்பாடுகள் மற்றும் செயல்திறன் மேம்பாட்டை ஆற்றலாம்
  • முழுமையான தரவு காட்சி அட்டவணையை உருவாக்கவும்
  • தரவு செயலாக்கத்துடன் தொடர்புடைய திறந்த மூல திட்டங்களில் பங்களிக்கவும்
  • பிறருக்கு வரிசைகள் மற்றும் 반복ங்களை நடைமுறை எடுத்துக்காட்டுகளுடன் கற்பிக்கவும்
  • மறு பயன்பாட்டுக்குரிய தனிப்பட்ட தரவு செயலாக்க செயல்பாடுகள் நூலகத்தை உருவாக்கவும்
  • வரிசைகளை அடிப்படையாகக் கொண்டு கட்டமைக்கப்பட்ட தகவல் அலகுகள் மற்றும் கூடுக்களை ஆராயவும்

🏆 இறுதி தரவு செயலாக்க சாம்பியன் சரிபார்ப்பு

உங்கள் வரிசைகள் மற்றும் 반복 திறமையை கொண்டாடுங்கள்:

  • நிஜ பயன்பாடுகளுக்கு நீங்கள் கற்றுக்கொண்ட மிகவும் பயனுள்ள வரிசை செயல்பாடு என்ன?
  • எந்த 반복 வகை உங்கள் கைகளுக்கு இயல்பானது மற்றும் ஏன்?
  • வரிசைகள் மற்றும் 반복ங்களைப் புரிந்துகொண்டதில் உங்கள் தரவு ஒழுங்குபடுத்தும் முறையில் எப்படி மாற்றம் ஏற்பட்டது?
  • இன்னும் எதைச் செய்ய விரும்புகிறீர்கள் கருத்து சிக்கலான தரவு செயலாக்க பணியொன்றை?
journey
    title உங்கள் தரவு செயலாக்க முன்னேற்றம்
    section இன்று
      Array Confusion: 3: You
      Loop Basics: 4: You
      Index Understanding: 5: You
    section இந்த வாரம்
      Method Mastery: 4: You
      Efficient Processing: 5: You
      Modern Syntax: 5: You
    section அடுத்த மாதம்
      Complex Algorithms: 5: You
      Performance Optimization: 5: You
      Teaching Others: 5: You
Loading

📦 நீங்கள் தரவுச் சீரமைப்பு மற்றும் செயலாக்க சக்தியைக் கைவிட்டீர்கள்! வரிசைகள் மற்றும் 반복ங்கள் நீங்கள் உருவாக்கும் பெரும்பாலான பயன்பாடுகளின் அடித்தளம் ஆகும். எளிய பட்டியலிலிருந்த தொடங்கி சிக்கலான தரவு பகுப்பாய்விலிருந்து, தகவலை திறமையாகவும் அழகாகவும் கையாள நீங்கள் இப்போது கருவிகளை பெற்றுள்ளீர்கள். ஒவ்வொரு இயக்கமான இணையதளம், மொபைல் செயலி மற்றும் தரவு சார்ந்த செயலி இவை அடிப்படையில் சார்ந்துள்ளன. பரவலாக வளர்க்கக்கூடிய தரவு செயலாக்க உலகிற்கு வரவேற்கிறோம்! 🎉


அறிகுறி: இந்த ஆவணம் கூ-ஒப் மொழிபெயர்ப்பாளர் என்ற செயற்கை நுண்ணறிவு மொழிபெயர்ப்பு சேவையை பயன்படுத்தி மொழிபெயர்க்கப்பட்டுள்ளது. துல்லியமாக இருப்பதற்காக நாம் முயலினாலும், தானாகவே செய்யப்பட்ட மொழிபெயர்ப்புகளில் தவறுகள் அல்லது நுட்பக் குறைவுகள் இருக்க வாய்ப்பு உள்ளது. தாய்மொழியில் உள்ள அசல் ஆவணம் அதிகாரப்பூர்வ மூலம் என கருதப்பட வேண்டும். மிகவும் முக்கியமான தகவல்களுக்கு, திறமையான மனித பிற மொழிபெயர்ப்பை பரிந்துரைக்கிறோம். இந்த மொழிபெயர்ப்பின் பயன்பாட்டினால் ஏற்பட்ட எந்த தவறான புரிதல்கள் அல்லது தவறான விளக்கங்களுக்கும் நாங்கள் பொறுப்பல்ல.