മലയാളം

ടൈപ്പ്സ്ക്രിപ്റ്റ് ലിറ്ററൽ ടൈപ്പുകളെക്കുറിച്ച് അറിയൂ. കർശനമായ മൂല്യ നിയന്ത്രണങ്ങൾ നടപ്പിലാക്കാനും കോഡിന്റെ വ്യക്തത മെച്ചപ്പെടുത്താനും പിഴവുകൾ തടയാനും സഹായിക്കുന്ന ശക്തമായ ഒരു ഫീച്ചറാണിത്. പ്രായോഗിക ഉദാഹരണങ്ങളിലൂടെയും നൂതന സാങ്കേതിക വിദ്യകളിലൂടെയും പഠിക്കൂ.

ടൈപ്പ്സ്ക്രിപ്റ്റ് ലിറ്ററൽ ടൈപ്പുകൾ: കൃത്യമായ മൂല്യ നിയന്ത്രണങ്ങളിൽ വൈദഗ്ദ്ധ്യം നേടാം

ജാവാസ്ക്രിപ്റ്റിന്റെ ഒരു സൂപ്പർസെറ്റായ ടൈപ്പ്സ്ക്രിപ്റ്റ്, വെബ് ഡെവലപ്‌മെന്റിന്റെ ചലനാത്മക ലോകത്തേക്ക് സ്റ്റാറ്റിക് ടൈപ്പിംഗ് കൊണ്ടുവരുന്നു. ഇതിന്റെ ഏറ്റവും ശക്തമായ ഫീച്ചറുകളിലൊന്നാണ് ലിറ്ററൽ ടൈപ്പുകൾ എന്ന ആശയം. ഒരു വേരിയബിളിനോ പ്രോപ്പർട്ടിക്കോ കൈവശം വയ്ക്കാൻ കഴിയുന്ന കൃത്യമായ മൂല്യം വ്യക്തമാക്കാൻ ലിറ്ററൽ ടൈപ്പുകൾ നിങ്ങളെ അനുവദിക്കുന്നു, ഇത് മെച്ചപ്പെട്ട ടൈപ്പ് സുരക്ഷ നൽകുകയും അപ്രതീക്ഷിത പിശകുകൾ തടയുകയും ചെയ്യുന്നു. ഈ ലേഖനം ലിറ്ററൽ ടൈപ്പുകളെക്കുറിച്ച് ആഴത്തിൽ ചർച്ചചെയ്യും, അവയുടെ സിന്റാക്സ്, ഉപയോഗം, പ്രായോഗിക ഉദാഹരണങ്ങളോടുകൂടിയ പ്രയോജനങ്ങൾ എന്നിവ ഇതിൽ ഉൾപ്പെടുന്നു.

എന്താണ് ലിറ്ററൽ ടൈപ്പുകൾ?

string, number, അല്ലെങ്കിൽ boolean പോലുള്ള പരമ്പരാഗത ടൈപ്പുകളിൽ നിന്ന് വ്യത്യസ്തമായി, ലിറ്ററൽ ടൈപ്പുകൾ മൂല്യങ്ങളുടെ ഒരു വലിയ വിഭാഗത്തെ പ്രതിനിധീകരിക്കുന്നില്ല. പകരം, അവ നിർദ്ദിഷ്ടവും സ്ഥിരവുമായ മൂല്യങ്ങളെ പ്രതിനിധീകരിക്കുന്നു. ടൈപ്പ്സ്ക്രിപ്റ്റ് മൂന്ന് തരം ലിറ്ററൽ ടൈപ്പുകളെ പിന്തുണയ്ക്കുന്നു:

ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കുന്നതിലൂടെ, നിങ്ങളുടെ ഡാറ്റയുടെ യഥാർത്ഥ നിയന്ത്രണങ്ങളെ പ്രതിഫലിപ്പിക്കുന്ന കൂടുതൽ കൃത്യമായ ടൈപ്പ് ഡെഫനിഷനുകൾ നിങ്ങൾക്ക് സൃഷ്ടിക്കാൻ കഴിയും, ഇത് കൂടുതൽ ശക്തവും പരിപാലിക്കാൻ എളുപ്പമുള്ളതുമായ കോഡിലേക്ക് നയിക്കുന്നു.

സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾ

സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകളാണ് ഏറ്റവും സാധാരണയായി ഉപയോഗിക്കുന്ന ലിറ്ററൽ ടൈപ്പ്. ഒരു വേരിയബിളിനോ പ്രോപ്പർട്ടിക്കോ മുൻകൂട്ടി നിശ്ചയിച്ച ഒരു കൂട്ടം സ്ട്രിംഗ് മൂല്യങ്ങളിൽ ഒന്ന് മാത്രമേ കൈവശം വയ്ക്കാൻ കഴിയൂ എന്ന് വ്യക്തമാക്കാൻ അവ നിങ്ങളെ അനുവദിക്കുന്നു.

അടിസ്ഥാന സിന്റാക്സ്

ഒരു സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പ് നിർവചിക്കുന്നതിനുള്ള സിന്റാക്സ് ലളിതമാണ്:


type AllowedValues = "value1" | "value2" | "value3";

ഇത് AllowedValues എന്ന പേരിൽ ഒരു ടൈപ്പ് നിർവചിക്കുന്നു, അതിന് "value1", "value2", അല്ലെങ്കിൽ "value3" എന്നീ സ്ട്രിംഗുകൾ മാത്രമേ ഉൾക്കൊള്ളാൻ കഴിയൂ.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. ഒരു കളർ പാലറ്റ് നിർവചിക്കുന്നു:

നിങ്ങൾ ഒരു UI ലൈബ്രറി നിർമ്മിക്കുകയാണെന്നും ഉപയോക്താക്കൾക്ക് മുൻകൂട്ടി നിശ്ചയിച്ച പാലറ്റിൽ നിന്ന് മാത്രമേ നിറങ്ങൾ വ്യക്തമാക്കാൻ കഴിയൂ എന്ന് ഉറപ്പാക്കണമെന്നും കരുതുക:


type Color = "red" | "green" | "blue" | "yellow";

function paintElement(element: HTMLElement, color: Color) {
  element.style.backgroundColor = color;
}

paintElement(document.getElementById("myElement")!, "red"); // സാധുവാണ്
paintElement(document.getElementById("myElement")!, "purple"); // പിശക്: 'Color' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"purple"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

അംഗീകൃത മൂല്യങ്ങളുടെ ഒരു കർശനമായ ഗണം നടപ്പിലാക്കാൻ സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾക്ക് എങ്ങനെ കഴിയുമെന്ന് ഈ ഉദാഹരണം കാണിക്കുന്നു, അതുവഴി ഡെവലപ്പർമാർ അസാധുവായ നിറങ്ങൾ ആകസ്മികമായി ഉപയോഗിക്കുന്നത് തടയുന്നു.

2. API എൻഡ്‌പോയിന്റുകൾ നിർവചിക്കുന്നു:

API-കളുമായി പ്രവർത്തിക്കുമ്പോൾ, അനുവദനീയമായ എൻഡ്‌പോയിന്റുകൾ വ്യക്തമാക്കേണ്ടത് പലപ്പോഴും ആവശ്യമാണ്. ഇത് നടപ്പിലാക്കാൻ സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾക്ക് സഹായിക്കാനാകും:


type APIEndpoint = "/users" | "/posts" | "/comments";

function fetchData(endpoint: APIEndpoint) {
  // ... നിർദ്ദിഷ്ട എൻഡ്‌പോയിന്റിൽ നിന്ന് ഡാറ്റ ലഭ്യമാക്കുന്നതിനുള്ള കോഡ്
  console.log(`Fetching data from ${endpoint}`);
}

fetchData("/users"); // സാധുവാണ്
fetchData("/products"); // പിശക്: 'APIEndpoint' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"/products"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

fetchData ഫംഗ്‌ഷൻ സാധുവായ API എൻഡ്‌പോയിന്റുകൾ ഉപയോഗിച്ച് മാത്രമേ വിളിക്കാൻ കഴിയൂ എന്ന് ഈ ഉദാഹരണം ഉറപ്പാക്കുന്നു, ടൈപ്പിംഗ് പിശകുകൾ അല്ലെങ്കിൽ തെറ്റായ എൻഡ്‌പോയിന്റ് പേരുകൾ മൂലമുണ്ടാകുന്ന പിഴവുകളുടെ സാധ്യത കുറയ്ക്കുന്നു.

3. വിവിധ ഭാഷകൾ കൈകാര്യം ചെയ്യൽ (അന്താരാഷ്ട്രവൽക്കരണം - i18n):

ആഗോള ആപ്ലിക്കേഷനുകളിൽ, നിങ്ങൾക്ക് വിവിധ ഭാഷകൾ കൈകാര്യം ചെയ്യേണ്ടി വന്നേക്കാം. നിങ്ങളുടെ ആപ്ലിക്കേഷൻ നിർദ്ദിഷ്ട ഭാഷകളെ മാത്രമേ പിന്തുണയ്ക്കുന്നുള്ളൂ എന്ന് ഉറപ്പാക്കാൻ നിങ്ങൾക്ക് സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കാം:


type Language = "en" | "es" | "fr" | "de" | "zh";

function translate(text: string, language: Language): string {
  // ... നൽകിയിട്ടുള്ള ടെക്സ്റ്റ് നിർദ്ദിഷ്ട ഭാഷയിലേക്ക് വിവർത്തനം ചെയ്യാനുള്ള കോഡ്
  console.log(`Translating '${text}' to ${language}`);
  return "Translated text"; // പ്ലെയ്സ്ഹോൾഡർ
}

translate("Hello", "en"); // സാധുവാണ്
translate("Hello", "ja"); // പിശക്: 'Language' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"ja"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

നിങ്ങളുടെ ആപ്ലിക്കേഷനിൽ പിന്തുണയ്ക്കുന്ന ഭാഷകൾ മാത്രമേ ഉപയോഗിക്കുന്നുള്ളൂ എന്ന് എങ്ങനെ ഉറപ്പാക്കാമെന്ന് ഈ ഉദാഹരണം കാണിക്കുന്നു.

നമ്പർ ലിറ്ററൽ ടൈപ്പുകൾ

ഒരു വേരിയബിളിനോ പ്രോപ്പർട്ടിക്കോ ഒരു പ്രത്യേക സംഖ്യാ മൂല്യം മാത്രമേ കൈവശം വയ്ക്കാൻ കഴിയൂ എന്ന് വ്യക്തമാക്കാൻ നമ്പർ ലിറ്ററൽ ടൈപ്പുകൾ നിങ്ങളെ അനുവദിക്കുന്നു.

അടിസ്ഥാന സിന്റാക്സ്

ഒരു നമ്പർ ലിറ്ററൽ ടൈപ്പ് നിർവചിക്കുന്നതിനുള്ള സിന്റാക്സ് സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾക്ക് സമാനമാണ്:


type StatusCode = 200 | 404 | 500;

ഇത് StatusCode എന്ന പേരിൽ ഒരു ടൈപ്പ് നിർവചിക്കുന്നു, അതിന് 200, 404, അല്ലെങ്കിൽ 500 എന്നീ സംഖ്യകൾ മാത്രമേ ഉൾക്കൊള്ളാൻ കഴിയൂ.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. HTTP സ്റ്റാറ്റസ് കോഡുകൾ നിർവചിക്കുന്നു:

HTTP സ്റ്റാറ്റസ് കോഡുകളെ പ്രതിനിധീകരിക്കാൻ നിങ്ങൾക്ക് നമ്പർ ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കാം, നിങ്ങളുടെ ആപ്ലിക്കേഷനിൽ സാധുവായ കോഡുകൾ മാത്രമേ ഉപയോഗിക്കുന്നുള്ളൂ എന്ന് ഉറപ്പാക്കുന്നു:


type HTTPStatus = 200 | 400 | 401 | 403 | 404 | 500;

function handleResponse(status: HTTPStatus) {
  switch (status) {
    case 200:
      console.log("Success!");
      break;
    case 400:
      console.log("Bad Request");
      break;
    // ... മറ്റ് കേസുകൾ
    default:
      console.log("Unknown Status");
  }
}

handleResponse(200); // സാധുവാണ്
handleResponse(600); // പിശക്: 'HTTPStatus' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '600' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

ഈ ഉദാഹരണം സാധുവായ HTTP സ്റ്റാറ്റസ് കോഡുകളുടെ ഉപയോഗം നിർബന്ധമാക്കുന്നു, തെറ്റായതോ നിലവാരമില്ലാത്തതോ ആയ കോഡുകൾ ഉപയോഗിക്കുന്നതിലൂടെ ഉണ്ടാകുന്ന പിശകുകൾ തടയുന്നു.

2. നിശ്ചിത ഓപ്ഷനുകളെ പ്രതിനിധീകരിക്കുന്നു:

ഒരു കോൺഫിഗറേഷൻ ഒബ്ജക്റ്റിൽ നിശ്ചിത ഓപ്ഷനുകളെ പ്രതിനിധീകരിക്കാൻ നിങ്ങൾക്ക് നമ്പർ ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കാം:


type RetryAttempts = 1 | 3 | 5;

interface Config {
  retryAttempts: RetryAttempts;
}

const config1: Config = { retryAttempts: 3 }; // സാധുവാണ്
const config2: Config = { retryAttempts: 7 }; // പിശക്: ടൈപ്പ് '{ retryAttempts: 7; }' 'Config' എന്ന ടൈപ്പിലേക്ക് നൽകാനാവില്ല.

ഈ ഉദാഹരണം retryAttempts-ന് സാധ്യമായ മൂല്യങ്ങളെ ഒരു പ്രത്യേക ഗണത്തിലേക്ക് പരിമിതപ്പെടുത്തുന്നു, ഇത് നിങ്ങളുടെ കോൺഫിഗറേഷന്റെ വ്യക്തതയും വിശ്വാസ്യതയും മെച്ചപ്പെടുത്തുന്നു.

ബൂളിയൻ ലിറ്ററൽ ടൈപ്പുകൾ

ബൂളിയൻ ലിറ്ററൽ ടൈപ്പുകൾ true അല്ലെങ്കിൽ false എന്നീ നിർദ്ദിഷ്ട മൂല്യങ്ങളെ പ്രതിനിധീകരിക്കുന്നു. സ്ട്രിംഗ് അല്ലെങ്കിൽ നമ്പർ ലിറ്ററൽ ടൈപ്പുകളെ അപേക്ഷിച്ച് ഇവയ്ക്ക് വൈവിധ്യം കുറവാണെന്ന് തോന്നാമെങ്കിലും, പ്രത്യേക സാഹചര്യങ്ങളിൽ അവ ഉപയോഗപ്രദമാകും.

അടിസ്ഥാന സിന്റാക്സ്

ഒരു ബൂളിയൻ ലിറ്ററൽ ടൈപ്പ് നിർവചിക്കുന്നതിനുള്ള സിന്റാക്സ് ഇതാണ്:


type IsEnabled = true | false;

എന്നിരുന്നാലും, നേരിട്ട് true | false ഉപയോഗിക്കുന്നത് അനാവശ്യമാണ്, കാരണം ഇത് boolean ടൈപ്പിന് തുല്യമാണ്. മറ്റ് ടൈപ്പുകളുമായോ അല്ലെങ്കിൽ കണ്ടീഷണൽ ടൈപ്പുകളിലോ സംയോജിപ്പിക്കുമ്പോൾ ബൂളിയൻ ലിറ്ററൽ ടൈപ്പുകൾ കൂടുതൽ ഉപയോഗപ്രദമാണ്.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. കോൺഫിഗറേഷൻ ഉപയോഗിച്ചുള്ള കണ്ടീഷണൽ ലോജിക്:

ഒരു കോൺഫിഗറേഷൻ ഫ്ലാഗ് അടിസ്ഥാനമാക്കി ഒരു ഫംഗ്‌ഷന്റെ പ്രവർത്തനം നിയന്ത്രിക്കാൻ നിങ്ങൾക്ക് ബൂളിയൻ ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കാം:


interface FeatureFlags {
  darkMode: boolean;
  newUserFlow: boolean;
}

function initializeApp(flags: FeatureFlags) {
  if (flags.darkMode) {
    // ഡാർക്ക് മോഡ് പ്രവർത്തനക്ഷമമാക്കുക
    console.log("Enabling dark mode...");
  } else {
    // ലൈറ്റ് മോഡ് ഉപയോഗിക്കുക
    console.log("Using light mode...");
  }

  if (flags.newUserFlow) {
    // പുതിയ യൂസർ ഫ്ലോ പ്രവർത്തനക്ഷമമാക്കുക
    console.log("Enabling new user flow...");
  } else {
    // പഴയ യൂസർ ഫ്ലോ ഉപയോഗിക്കുക
    console.log("Using old user flow...");
  }
}

initializeApp({ darkMode: true, newUserFlow: false });

ഈ ഉദാഹരണം സ്റ്റാൻഡേർഡ് boolean ടൈപ്പ് ഉപയോഗിക്കുന്നുണ്ടെങ്കിലും, കൂടുതൽ സങ്കീർണ്ണമായ പെരുമാറ്റം സൃഷ്ടിക്കുന്നതിന് നിങ്ങൾക്ക് ഇത് കണ്ടീഷണൽ ടൈപ്പുകളുമായി (പിന്നീട് വിശദീകരിക്കും) സംയോജിപ്പിക്കാം.

2. ഡിസ്ക്രിമിനേറ്റഡ് യൂണിയനുകൾ:

യൂണിയൻ ടൈപ്പുകളിൽ ഡിസ്ക്രിമിനേറ്ററുകളായി ബൂളിയൻ ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കാം. താഴെ പറയുന്ന ഉദാഹരണം പരിഗണിക്കുക:


interface SuccessResult {
  success: true;
  data: any;
}

interface ErrorResult {
  success: false;
  error: string;
}

type Result = SuccessResult | ErrorResult;

function processResult(result: Result) {
  if (result.success) {
    console.log("Success:", result.data);
  } else {
    console.error("Error:", result.error);
  }
}

processResult({ success: true, data: { name: "John" } });
processResult({ success: false, error: "Failed to fetch data" });

ഇവിടെ, ബൂളിയൻ ലിറ്ററൽ ടൈപ്പായ success പ്രോപ്പർട്ടി ഒരു ഡിസ്ക്രിമിനേറ്ററായി പ്രവർത്തിക്കുന്നു, if സ്റ്റേറ്റ്മെന്റിനുള്ളിൽ result-ന്റെ ടൈപ്പ് ചുരുക്കാൻ ടൈപ്പ്സ്ക്രിപ്റ്റിനെ അനുവദിക്കുന്നു.

ലിറ്ററൽ ടൈപ്പുകളെ യൂണിയൻ ടൈപ്പുകളുമായി സംയോജിപ്പിക്കുന്നു

യൂണിയൻ ടൈപ്പുകളുമായി (| ഓപ്പറേറ്റർ ഉപയോഗിച്ച്) സംയോജിപ്പിക്കുമ്പോൾ ലിറ്ററൽ ടൈപ്പുകൾ ഏറ്റവും ശക്തമാകും. നിരവധി നിർദ്ദിഷ്ട മൂല്യങ്ങളിൽ ഒന്ന് കൈവശം വയ്ക്കാൻ കഴിയുന്ന ഒരു ടൈപ്പ് നിർവചിക്കാൻ ഇത് നിങ്ങളെ അനുവദിക്കുന്നു.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. ഒരു സ്റ്റാറ്റസ് ടൈപ്പ് നിർവചിക്കുന്നു:


type Status = "pending" | "in progress" | "completed" | "failed";

interface Task {
  id: number;
  description: string;
  status: Status;
}

const task1: Task = { id: 1, description: "Implement login", status: "in progress" }; // സാധുവാണ്
const task2: Task = { id: 2, description: "Implement logout", status: "done" };       // പിശക്: ടൈപ്പ് '{ id: number; description: string; status: string; }' 'Task' എന്ന ടൈപ്പിലേക്ക് നൽകാനാവില്ല.

ഒരു Task ഒബ്ജക്റ്റിനായി അനുവദനീയമായ സ്റ്റാറ്റസ് മൂല്യങ്ങളുടെ ഒരു പ്രത്യേക ഗണം എങ്ങനെ നടപ്പിലാക്കാമെന്ന് ഈ ഉദാഹരണം കാണിക്കുന്നു.

2. ഒരു ഡിവൈസ് ടൈപ്പ് നിർവചിക്കുന്നു:

ഒരു മൊബൈൽ ആപ്ലിക്കേഷനിൽ, നിങ്ങൾക്ക് വിവിധ ഡിവൈസ് ടൈപ്പുകൾ കൈകാര്യം ചെയ്യേണ്ടി വന്നേക്കാം. ഇവയെ പ്രതിനിധീകരിക്കാൻ നിങ്ങൾക്ക് സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകളുടെ ഒരു യൂണിയൻ ഉപയോഗിക്കാം:


type DeviceType = "mobile" | "tablet" | "desktop";

function logDeviceType(device: DeviceType) {
  console.log(`Device type: ${device}`);
}

logDeviceType("mobile"); // സാധുവാണ്
logDeviceType("smartwatch"); // പിശക്: 'DeviceType' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"smartwatch"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

logDeviceType ഫംഗ്‌ഷൻ സാധുവായ ഡിവൈസ് ടൈപ്പുകൾ ഉപയോഗിച്ച് മാത്രമേ വിളിക്കപ്പെടുന്നുള്ളൂ എന്ന് ഈ ഉദാഹരണം ഉറപ്പാക്കുന്നു.

ടൈപ്പ് അലിയാസുകളോടുകൂടിയ ലിറ്ററൽ ടൈപ്പുകൾ

ടൈപ്പ് അലിയാസുകൾ (type കീവേഡ് ഉപയോഗിച്ച്) ഒരു ലിറ്ററൽ ടൈപ്പിന് ഒരു പേര് നൽകാൻ സഹായിക്കുന്നു, ഇത് നിങ്ങളുടെ കോഡ് കൂടുതൽ വായിക്കാനും പരിപാലിക്കാനും എളുപ്പമാക്കുന്നു.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. ഒരു കറൻസി കോഡ് ടൈപ്പ് നിർവചിക്കുന്നു:


type CurrencyCode = "USD" | "EUR" | "GBP" | "JPY";

function formatCurrency(amount: number, currency: CurrencyCode): string {
  // ... കറൻസി കോഡ് അടിസ്ഥാനമാക്കി തുക ഫോർമാറ്റ് ചെയ്യാനുള്ള കോഡ്
  console.log(`Formatting ${amount} in ${currency}`);
  return "Formatted amount"; // പ്ലെയ്സ്ഹോൾഡർ
}

formatCurrency(100, "USD"); // സാധുവാണ്
formatCurrency(200, "CAD"); // പിശക്: 'CurrencyCode' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"CAD"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

ഈ ഉദാഹരണം കറൻസി കോഡുകളുടെ ഒരു കൂട്ടത്തിനായി CurrencyCode എന്ന ടൈപ്പ് അലിയാസ് നിർവചിക്കുന്നു, ഇത് formatCurrency ഫംഗ്‌ഷന്റെ വായനാക്ഷമത മെച്ചപ്പെടുത്തുന്നു.

2. ആഴ്ചയിലെ ഒരു ദിവസത്തിന്റെ ടൈപ്പ് നിർവചിക്കുന്നു:


type DayOfWeek = "Monday" | "Tuesday" | "Wednesday" | "Thursday" | "Friday" | "Saturday" | "Sunday";

function isWeekend(day: DayOfWeek): boolean {
  return day === "Saturday" || day === "Sunday";
}

console.log(isWeekend("Monday"));   // false
console.log(isWeekend("Saturday")); // true
console.log(isWeekend("Funday"));   // പിശക്: 'DayOfWeek' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് '"Funday"' എന്ന ആർഗ്യുമെന്റ് നൽകാനാവില്ല.

ലിറ്ററൽ ഇൻഫറൻസ്

നിങ്ങൾ വേരിയബിളുകൾക്ക് നൽകുന്ന മൂല്യങ്ങളെ അടിസ്ഥാനമാക്കി ടൈപ്പ്സ്ക്രിപ്റ്റിന് പലപ്പോഴും ലിറ്ററൽ ടൈപ്പുകൾ സ്വയമേവ അനുമാനിക്കാൻ കഴിയും. const വേരിയബിളുകളുമായി പ്രവർത്തിക്കുമ്പോൾ ഇത് പ്രത്യേകിച്ചും ഉപയോഗപ്രദമാണ്.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പുകൾ അനുമാനിക്കുന്നു:


const apiKey = "your-api-key"; // apiKey-യുടെ ടൈപ്പ് "your-api-key" എന്ന് ടൈപ്പ്സ്ക്രിപ്റ്റ് അനുമാനിക്കുന്നു

function validateApiKey(key: "your-api-key") {
  return key === "your-api-key";
}

console.log(validateApiKey(apiKey)); // true

const anotherKey = "invalid-key";
console.log(validateApiKey(anotherKey)); // പിശക്: 'string' എന്ന ടൈപ്പിലുള്ള ആർഗ്യുമെന്റ് '"your-api-key"' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് നൽകാനാവില്ല.

ഈ ഉദാഹരണത്തിൽ, apiKey-യുടെ ടൈപ്പ് "your-api-key" എന്ന സ്ട്രിംഗ് ലിറ്ററൽ ടൈപ്പായി ടൈപ്പ്സ്ക്രിപ്റ്റ് അനുമാനിക്കുന്നു. എന്നിരുന്നാലും, നിങ്ങൾ ഒരു വേരിയബിളിന് ഒരു സ്ഥിരമല്ലാത്ത മൂല്യം നൽകുമ്പോൾ, ടൈപ്പ്സ്ക്രിപ്റ്റ് സാധാരണയായി വിശാലമായ string ടൈപ്പ് അനുമാനിക്കും.

2. നമ്പർ ലിറ്ററൽ ടൈപ്പുകൾ അനുമാനിക്കുന്നു:


const port = 8080; // port-ന്റെ ടൈപ്പ് 8080 എന്ന് ടൈപ്പ്സ്ക്രിപ്റ്റ് അനുമാനിക്കുന്നു

function startServer(portNumber: 8080) {
  console.log(`Starting server on port ${portNumber}`);
}

startServer(port); // സാധുവാണ്

const anotherPort = 3000;
startServer(anotherPort); // പിശക്: 'number' എന്ന ടൈപ്പിലുള്ള ആർഗ്യുമെന്റ് '8080' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് നൽകാനാവില്ല.

കണ്ടീഷണൽ ടൈപ്പുകളോടൊപ്പം ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കുന്നു

കണ്ടീഷണൽ ടൈപ്പുകളുമായി സംയോജിപ്പിക്കുമ്പോൾ ലിറ്ററൽ ടൈപ്പുകൾ കൂടുതൽ ശക്തമാകും. മറ്റ് ടൈപ്പുകളെ ആശ്രയിക്കുന്ന ടൈപ്പുകൾ നിർവചിക്കാൻ കണ്ടീഷണൽ ടൈപ്പുകൾ നിങ്ങളെ അനുവദിക്കുന്നു, ഇത് വളരെ അയവുള്ളതും പ്രകടവുമായ ടൈപ്പ് സിസ്റ്റങ്ങൾ സൃഷ്ടിക്കുന്നു.

അടിസ്ഥാന സിന്റാക്സ്

ഒരു കണ്ടീഷണൽ ടൈപ്പിന്റെ സിന്റാക്സ് ഇതാണ്:


TypeA extends TypeB ? TypeC : TypeD

ഇതിനർത്ഥം: TypeA എന്നത് TypeB-ലേക്ക് നൽകാൻ കഴിയുമെങ്കിൽ, ഫലമായുണ്ടാകുന്ന ടൈപ്പ് TypeC ആയിരിക്കും; അല്ലെങ്കിൽ, ഫലമായുണ്ടാകുന്ന ടൈപ്പ് TypeD ആയിരിക്കും.

പ്രായോഗിക ഉദാഹരണങ്ങൾ

1. സ്റ്റാറ്റസിനെ സന്ദേശത്തിലേക്ക് മാപ്പ് ചെയ്യുന്നു:


type Status = "pending" | "in progress" | "completed" | "failed";

type StatusMessage = T extends "pending"
  ? "Waiting for action"
  : T extends "in progress"
  ? "Currently processing"
  : T extends "completed"
  ? "Task finished successfully"
  : "An error occurred";

function getStatusMessage(status: T): StatusMessage {
  switch (status) {
    case "pending":
      return "Waiting for action" as StatusMessage;
    case "in progress":
      return "Currently processing" as StatusMessage;
    case "completed":
      return "Task finished successfully" as StatusMessage;
    case "failed":
      return "An error occurred" as StatusMessage;
    default:
      throw new Error("Invalid status");
  }
}

console.log(getStatusMessage("pending"));    // Waiting for action
console.log(getStatusMessage("in progress")); // Currently processing
console.log(getStatusMessage("completed"));   // Task finished successfully
console.log(getStatusMessage("failed"));      // An error occurred

ഈ ഉദാഹരണം ഓരോ സാധ്യമായ സ്റ്റാറ്റസിനെയും അതിനനുസരിച്ചുള്ള സന്ദേശത്തിലേക്ക് കണ്ടീഷണൽ ടൈപ്പുകൾ ഉപയോഗിച്ച് മാപ്പ് ചെയ്യുന്ന ഒരു StatusMessage ടൈപ്പ് നിർവചിക്കുന്നു. getStatusMessage ഫംഗ്‌ഷൻ ടൈപ്പ്-സുരക്ഷിത സ്റ്റാറ്റസ് സന്ദേശങ്ങൾ നൽകാൻ ഈ ടൈപ്പ് ഉപയോഗിക്കുന്നു.

2. ഒരു ടൈപ്പ്-സേഫ് ഇവന്റ് ഹാൻഡ്‌ലർ സൃഷ്ടിക്കുന്നു:


type EventType = "click" | "mouseover" | "keydown";

type EventData = T extends "click"
  ? { x: number; y: number; } // ക്ലിക്ക് ഇവന്റ് ഡാറ്റ
  : T extends "mouseover"
  ? { target: HTMLElement; }   // മൗസ്ഓവർ ഇവന്റ് ഡാറ്റ
  : { key: string; }             // കീഡൗൺ ഇവന്റ് ഡാറ്റ

function handleEvent(type: T, data: EventData) {
  console.log(`Handling event type ${type} with data:`, data);
}

handleEvent("click", { x: 10, y: 20 }); // സാധുവാണ്
handleEvent("mouseover", { target: document.getElementById("myElement")! }); // സാധുവാണ്
handleEvent("keydown", { key: "Enter" }); // സാധുവാണ്

handleEvent("click", { key: "Enter" }); // പിശക്: '{ key: string; }' എന്ന ടൈപ്പിലുള്ള ആർഗ്യുമെന്റ് '{ x: number; y: number; }' എന്ന ടൈപ്പിലുള്ള പാരാമീറ്ററിലേക്ക് നൽകാനാവില്ല.

ഈ ഉദാഹരണം ഇവന്റ് ടൈപ്പിനെ അടിസ്ഥാനമാക്കി വ്യത്യസ്ത ഡാറ്റാ ഘടനകളെ നിർവചിക്കുന്ന ഒരു EventData ടൈപ്പ് സൃഷ്ടിക്കുന്നു. ഓരോ ഇവന്റ് ടൈപ്പിനും ശരിയായ ഡാറ്റ handleEvent ഫംഗ്ഷനിലേക്ക് കൈമാറുന്നുവെന്ന് ഉറപ്പാക്കാൻ ഇത് നിങ്ങളെ അനുവദിക്കുന്നു.

ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കുന്നതിനുള്ള മികച്ച രീതികൾ

നിങ്ങളുടെ ടൈപ്പ്സ്ക്രിപ്റ്റ് പ്രോജക്റ്റുകളിൽ ലിറ്ററൽ ടൈപ്പുകൾ ഫലപ്രദമായി ഉപയോഗിക്കുന്നതിന്, ഇനിപ്പറയുന്ന മികച്ച രീതികൾ പരിഗണിക്കുക:

ലിറ്ററൽ ടൈപ്പുകൾ ഉപയോഗിക്കുന്നതിന്റെ പ്രയോജനങ്ങൾ

ഉപസംഹാരം

ടൈപ്പ്സ്ക്രിപ്റ്റ് ലിറ്ററൽ ടൈപ്പുകൾ കർശനമായ മൂല്യ നിയന്ത്രണങ്ങൾ നടപ്പിലാക്കാനും കോഡ് വ്യക്തത മെച്ചപ്പെടുത്താനും പിശകുകൾ തടയാനും നിങ്ങളെ അനുവദിക്കുന്ന ഒരു ശക്തമായ ഫീച്ചറാണ്. അവയുടെ സിന്റാക്സ്, ഉപയോഗം, പ്രയോജനങ്ങൾ എന്നിവ മനസ്സിലാക്കുന്നതിലൂടെ, കൂടുതൽ ശക്തവും പരിപാലിക്കാൻ എളുപ്പമുള്ളതുമായ ടൈപ്പ്സ്ക്രിപ്റ്റ് ആപ്ലിക്കേഷനുകൾ നിർമ്മിക്കാൻ നിങ്ങൾക്ക് ലിറ്ററൽ ടൈപ്പുകൾ പ്രയോജനപ്പെടുത്താം. കളർ പാലറ്റുകളും API എൻഡ്‌പോയിന്റുകളും നിർവചിക്കുന്നത് മുതൽ വിവിധ ഭാഷകൾ കൈകാര്യം ചെയ്യുന്നതും ടൈപ്പ്-സേഫ് ഇവന്റ് ഹാൻഡ്‌ലറുകൾ സൃഷ്ടിക്കുന്നതും വരെ, നിങ്ങളുടെ ഡെവലപ്‌മെന്റ് വർക്ക്ഫ്ലോയെ ഗണ്യമായി മെച്ചപ്പെടുത്താൻ കഴിയുന്ന വൈവിധ്യമാർന്ന പ്രായോഗിക ആപ്ലിക്കേഷനുകൾ ലിറ്ററൽ ടൈപ്പുകൾ വാഗ്ദാനം ചെയ്യുന്നു.