বাংলা

টাইপস্ক্রিপ্ট অ্যাসারশন ফাংশনের একটি বিস্তারিত নির্দেশিকা। কম্পাইল-টাইম ও রানটাইমের মধ্যে ব্যবধান পূরণ, ডেটা যাচাই এবং ব্যবহারিক উদাহরণ সহ নিরাপদ ও শক্তিশালী কোড লিখতে শিখুন।

টাইপস্ক্রিপ্ট অ্যাসারশন ফাংশন: রানটাইম টাইপ সেফটির সম্পূর্ণ নির্দেশিকা

ওয়েব ডেভেলপমেন্টের জগতে, আপনার কোডের প্রত্যাশা এবং প্রাপ্ত ডেটার বাস্তবতার মধ্যেকার চুক্তি প্রায়শই ভঙ্গুর হয়। টাইপস্ক্রিপ্ট জাভাস্ক্রিপ্ট লেখার পদ্ধতিতে বিপ্লব এনেছে, কারণ এটি একটি শক্তিশালী স্ট্যাটিক টাইপ সিস্টেম সরবরাহ করে, যা প্রোডাকশনে পৌঁছানোর আগেই অগণিত বাগ ধরে ফেলে। তবে, এই সুরক্ষা ব্যবস্থা মূলত কম্পাইল-টাইমে সীমাবদ্ধ থাকে। কী হবে যখন আপনার সুন্দরভাবে টাইপ করা অ্যাপ্লিকেশনটি রানটাইমে বাইরের জগত থেকে অগোছালো, অপ্রত্যাশিত ডেটা গ্রহণ করে? এখানেই টাইপস্ক্রিপ্টের অ্যাসারশন ফাংশনগুলো সত্যিকারের শক্তিশালী অ্যাপ্লিকেশন তৈরির জন্য একটি অপরিহার্য হাতিয়ার হয়ে ওঠে।

এই বিস্তারিত নির্দেশিকা আপনাকে অ্যাসারশন ফাংশনের গভীরে নিয়ে যাবে। আমরা অন্বেষণ করব কেন সেগুলি প্রয়োজনীয়, কীভাবে স্ক্র্যাচ থেকে তৈরি করতে হয় এবং সাধারণ বাস্তব-জগতের পরিস্থিতিতে কীভাবে প্রয়োগ করতে হয়। এই নির্দেশিকার শেষে, আপনি এমন কোড লিখতে সক্ষম হবেন যা কেবল কম্পাইল-টাইমে টাইপ-সেফ নয়, বরং রানটাইমেও স্থিতিস্থাপক এবং অনুমানযোগ্য।

কম্পাইল-টাইম বনাম রানটাইম: একটি বড় বিভাজন

অ্যাসারশন ফাংশনের গুরুত্ব পুরোপুরি বোঝার জন্য, আমাদের প্রথমে তাদের সমাধান করা মৌলিক চ্যালেঞ্জটি বুঝতে হবে: টাইপস্ক্রিপ্টের কম্পাইল-টাইম জগৎ এবং জাভাস্ক্রিপ্টের রানটাইম জগতের মধ্যেকার ব্যবধান।

টাইপস্ক্রিপ্টের কম্পাইল-টাইম প্যারাডাইস

যখন আপনি টাইপস্ক্রিপ্ট কোড লেখেন, আপনি একজন ডেভেলপারের স্বর্গে কাজ করেন। টাইপস্ক্রিপ্ট কম্পাইলার (tsc) একজন সতর্ক সহকারীর মতো কাজ করে, আপনার কোডকে আপনার সংজ্ঞায়িত টাইপগুলোর বিরুদ্ধে বিশ্লেষণ করে। এটি যা যা পরীক্ষা করে:

এই প্রক্রিয়াটি আপনার কোড এক্সিকিউট হওয়ার আগে ঘটে। চূড়ান্ত আউটপুট হলো প্লেইন জাভাস্ক্রিপ্ট, যেখানে সব ধরনের টাইপ অ্যানোটেশন মুছে ফেলা হয়। টাইপস্ক্রিপ্টকে একটি বিল্ডিংয়ের বিস্তারিত স্থাপত্য নীলনকশার মতো ভাবুন। এটি নিশ্চিত করে যে সমস্ত পরিকল্পনা সঠিক, পরিমাপ সঠিক এবং কাঠামোগত অখণ্ডতা কাগজে-কলমে নিশ্চিত।

জাভাস্ক্রিপ্টের রানটাইম বাস্তবতা

একবার আপনার টাইপস্ক্রিপ্ট জাভাস্ক্রিপ্টে কম্পাইল হয়ে ব্রাউজার বা নোড.জেএস পরিবেশে চলে গেলে, স্ট্যাটিক টাইপগুলো আর থাকে না। আপনার কোড এখন রানটাইমের গতিশীল, অপ্রত্যাশিত জগতে কাজ করছে। একে এমন উৎস থেকে ডেটা মোকাবেলা করতে হয় যা এটি নিয়ন্ত্রণ করতে পারে না, যেমন:

আমাদের উপমা ব্যবহার করতে গেলে, রানটাইম হলো নির্মাণ সাইট। নীলনকশা নিখুঁত ছিল, কিন্তু সরবরাহ করা উপকরণ (ডেটা) ভুল আকারের, ভুল ধরনের বা কেবল অনুপস্থিত হতে পারে। আপনি যদি এই ত্রুটিপূর্ণ উপকরণ দিয়ে নির্মাণ করার চেষ্টা করেন, আপনার কাঠামো ভেঙে পড়বে। এখানেই রানটাইম ত্রুটি ঘটে, যা প্রায়শই ক্র্যাশ এবং "Cannot read properties of undefined"-এর মতো বাগের কারণ হয়।

অ্যাসারশন ফাংশনের আগমন: ব্যবধান পূরণ

তাহলে, আমরা কীভাবে রানটাইমের অপ্রত্যাশিত উপকরণগুলোর উপর আমাদের টাইপস্ক্রিপ্ট নীলনকশা প্রয়োগ করব? আমাদের এমন একটি প্রক্রিয়া দরকার যা ডেটা *আসার সাথে সাথে* পরীক্ষা করতে পারে এবং নিশ্চিত করতে পারে যে এটি আমাদের প্রত্যাশার সাথে মেলে। অ্যাসারশন ফাংশনগুলো ঠিক এটাই করে।

অ্যাসারশন ফাংশন কী?

অ্যাসারশন ফাংশন টাইপস্ক্রিপ্টে এক বিশেষ ধরনের ফাংশন যা দুটি গুরুত্বপূর্ণ উদ্দেশ্য পূরণ করে:

  1. রানটাইম চেক: এটি একটি ভ্যালু বা শর্তের উপর একটি ভ্যালিডেশন সম্পাদন করে। যদি ভ্যালিডেশন ব্যর্থ হয়, তবে এটি একটি ত্রুটি থ্রো করে, যা সেই কোড পাথের এক্সিকিউশন অবিলম্বে বন্ধ করে দেয়। এটি অবৈধ ডেটাকে আপনার অ্যাপ্লিকেশনে আরও ছড়িয়ে পড়া থেকে বিরত রাখে।
  2. কম্পাইল-টাইম টাইপ ন্যারোয়িং: যদি ভ্যালিডেশন সফল হয় (অর্থাৎ, কোনো ত্রুটি থ্রো না হয়), এটি টাইপস্ক্রিপ্ট কম্পাইলারকে সংকেত দেয় যে ভ্যালুটির টাইপ এখন আরও সুনির্দিষ্ট। কম্পাইলার এই অ্যাসারশনকে বিশ্বাস করে এবং আপনাকে তার স্কোপের বাকি অংশের জন্য ভ্যালুটি অ্যাসার্টেড টাইপ হিসাবে ব্যবহার করার অনুমতি দেয়।

এর জাদুটি ফাংশনের সিগনেচারে রয়েছে, যা asserts কীওয়ার্ড ব্যবহার করে। এর দুটি প্রধান রূপ রয়েছে:

মূল বিষয়টি হলো "ব্যর্থ হলে থ্রো করা"-এর আচরণ। একটি সাধারণ if চেকের মতো নয়, একটি অ্যাসারশন ঘোষণা করে: "প্রোগ্রামটি চালিয়ে যাওয়ার জন্য এই শর্তটি অবশ্যই সত্য হতে হবে। যদি তা না হয়, তবে এটি একটি ব্যতিক্রমী অবস্থা এবং আমাদের অবিলম্বে থামা উচিত।"

আপনার প্রথম অ্যাসারশন ফাংশন তৈরি করা: একটি ব্যবহারিক উদাহরণ

আসুন জাভাস্ক্রিপ্ট এবং টাইপস্ক্রিপ্টের অন্যতম সাধারণ সমস্যা দিয়ে শুরু করি: সম্ভাব্য null বা undefined ভ্যালু নিয়ে কাজ করা।

সমস্যা: অবাঞ্ছিত Nulls

কল্পনা করুন একটি ফাংশন একটি ঐচ্ছিক ইউজার অবজেক্ট নেয় এবং ইউজারের নাম লগ করতে চায়। টাইপস্ক্রিপ্টের কঠোর নাল চেকগুলো আমাদের একটি সম্ভাব্য ত্রুটি সম্পর্কে সঠিকভাবে সতর্ক করবে।


interface User {
  name: string;
  email: string;
}

function logUserName(user: User | undefined) {
  // 🚨 TypeScript ত্রুটি: 'user' সম্ভবত 'undefined'।
  console.log(user.name.toUpperCase()); 
}

এটি ঠিক করার সাধারণ উপায় হলো একটি if চেক:


function logUserName(user: User | undefined) {
  if (user) {
    // এই ব্লকের ভিতরে, TypeScript জানে যে 'user' হলো 'User' টাইপের।
    console.log(user.name.toUpperCase());
  } else {
    console.error('User is not provided.');
  }
}

এটি কাজ করে, কিন্তু যদি `user` এর `undefined` হওয়াটা এই প্রেক্ষাপটে একটি অপূরণীয় ত্রুটি হয়? আমরা চাই না ফাংশনটি নীরবে এগিয়ে যাক। আমরা চাই এটি সশব্দে ব্যর্থ হোক। এটি পুনরাবৃত্তিমূলক গার্ড ক্লজের দিকে নিয়ে যায়।

সমাধান: একটি `assertIsDefined` অ্যাসারশন ফাংশন

আসুন এই প্যাটার্নটি সুন্দরভাবে পরিচালনা করার জন্য একটি পুনঃব্যবহারযোগ্য অ্যাসারশন ফাংশন তৈরি করি।


// আমাদের পুনঃব্যবহারযোগ্য অ্যাসারশন ফাংশন
function assertIsDefined<T>(value: T, message: string = "Value is not defined"): asserts value is NonNullable<T> {
  if (value === undefined || value === null) {
    throw new Error(message);
  }
}

// আসুন এটি ব্যবহার করি!
interface User {
  name: string;
  email: string;
}

function logUserName(user: User | undefined) {
  assertIsDefined(user, "User object must be provided to log name.");

  // কোনো ত্রুটি নেই! TypeScript এখন জানে 'user' হলো 'User' টাইপের।
  // টাইপটি 'User | undefined' থেকে 'User'-এ ন্যারো করা হয়েছে।
  console.log(user.name.toUpperCase());
}

// উদাহরণ ব্যবহার:
const validUser = { name: 'Alice', email: 'alice@example.com' };
logUserName(validUser); // "ALICE" লগ করে

const invalidUser = undefined;
try {
  logUserName(invalidUser); // একটি Error থ্রো করে: "User object must be provided to log name."
} catch (error) {
  console.error(error.message);
}

অ্যাসারশন সিগনেচারটি ভেঙে দেখা

আসুন সিগনেচারটি ভেঙে দেখি: asserts value is NonNullable<T>

অ্যাসারশন ফাংশনের ব্যবহারিক ক্ষেত্র

যেহেতু আমরা মূল বিষয়গুলো বুঝতে পেরেছি, আসুন দেখি কীভাবে সাধারণ, বাস্তব-জগতের সমস্যা সমাধানে অ্যাসারশন ফাংশন প্রয়োগ করা যায়। এগুলি আপনার অ্যাপ্লিকেশনের সীমানায় সবচেয়ে শক্তিশালী, যেখানে বাহ্যিক, আনটাইপড ডেটা আপনার সিস্টেমে প্রবেশ করে।

ব্যবহার ক্ষেত্র ১: এপিআই রেসপন্স ভ্যালিডেট করা

এটি নিঃসন্দেহে সবচেয়ে গুরুত্বপূর্ণ ব্যবহার ক্ষেত্র। একটি fetch অনুরোধ থেকে প্রাপ্ত ডেটা সহজাতভাবেই অবিশ্বস্ত। টাইপস্ক্রিপ্ট সঠিকভাবে `response.json()` এর ফলাফলকে `Promise` বা `Promise` হিসাবে টাইপ করে, যা আপনাকে এটি যাচাই করতে বাধ্য করে।

দৃশ্যপট

আমরা একটি এপিআই থেকে ইউজার ডেটা আনছি। আমরা আশা করি এটি আমাদের `User` ইন্টারফেসের সাথে মিলবে, কিন্তু আমরা নিশ্চিত হতে পারি না।


interface User {
  id: number;
  name: string;
  email: string;
}

// একটি সাধারণ টাইপ গার্ড (বুলিয়ান রিটার্ন করে)
function isUser(data: unknown): data is User {
  return (
    typeof data === 'object' &&
    data !== null &&
    'id' in data && typeof (data as any).id === 'number' &&
    'name' in data && typeof (data as any).name === 'string' &&
    'email' in data && typeof (data as any).email === 'string'
  );
}

// আমাদের নতুন অ্যাসারশন ফাংশন
function assertIsUser(data: unknown): asserts data is User {
  if (!isUser(data)) {
    throw new TypeError('Invalid User data received from API.');
  }
}

async function fetchAndProcessUser(userId: number) {
  const response = await fetch(`https://api.example.com/users/${userId}`);
  const data: unknown = await response.json();

  // সীমানায় ডেটার আকৃতি অ্যাসার্ট করুন
  assertIsUser(data);

  // এই পয়েন্টের পর থেকে, 'data' নিরাপদে 'User' হিসাবে টাইপ করা হয়েছে।
  // আর কোনো 'if' চেক বা টাইপ কাস্টিং এর প্রয়োজন নেই!
  console.log(`Processing user: ${data.name.toUpperCase()} (${data.email})`);
}

fetchAndProcessUser(1);

কেন এটি শক্তিশালী: রেসপন্স পাওয়ার ঠিক পরেই `assertIsUser(data)` কল করার মাধ্যমে, আমরা একটি "সেফটি গেট" তৈরি করি। এর পরের যেকোনো কোড আত্মবিশ্বাসের সাথে `data`-কে `User` হিসাবে ব্যবহার করতে পারে। এটি ভ্যালিডেশন লজিককে বিজনেস লজিক থেকে আলাদা করে, যা অনেক পরিষ্কার এবং পাঠযোগ্য কোডের দিকে নিয়ে যায়।

ব্যবহার ক্ষেত্র ২: এনভায়রনমেন্ট ভেরিয়েবলের অস্তিত্ব নিশ্চিত করা

সার্ভার-সাইড অ্যাপ্লিকেশন (যেমন, নোড.জেএস-এ) কনফিগারেশনের জন্য এনভায়রনমেন্ট ভেরিয়েবলের উপর ব্যাপকভাবে নির্ভর করে। `process.env.MY_VAR` অ্যাক্সেস করলে `string | undefined` টাইপ পাওয়া যায়। এটি আপনাকে যেখানেই এটি ব্যবহার করেন সেখানেই এর অস্তিত্ব পরীক্ষা করতে বাধ্য করে, যা ক্লান্তিকর এবং ত্রুটিপ্রবণ।

দৃশ্যপট

আমাদের অ্যাপ্লিকেশন শুরু করার জন্য এনভায়রনমেন্ট ভেরিয়েবল থেকে একটি এপিআই কী এবং একটি ডাটাবেস ইউআরএল প্রয়োজন। যদি সেগুলি অনুপস্থিত থাকে, অ্যাপ্লিকেশনটি চলতে পারে না এবং একটি স্পষ্ট ত্রুটি বার্তা সহ অবিলম্বে ক্র্যাশ করা উচিত।


// একটি ইউটিলিটি ফাইলে, যেমন, 'config.ts'

export function getEnvVar(key: string): string {
  const value = process.env[key];

  if (value === undefined) {
    throw new Error(`FATAL: Environment variable ${key} is not set.`);
  }

  return value;
}

// অ্যাসারশন ব্যবহার করে একটি আরও শক্তিশালী সংস্করণ
function assertEnvVar(key: string): asserts key is keyof NodeJS.ProcessEnv {
  if (process.env[key] === undefined) {
    throw new Error(`FATAL: Environment variable ${key} is not set.`);
  }
}

// আপনার অ্যাপ্লিকেশনের এন্ট্রি পয়েন্টে, যেমন, 'index.ts'

function startServer() {
  // স্টার্টআপে সমস্ত চেক সম্পাদন করুন
  assertEnvVar('API_KEY');
  assertEnvVar('DATABASE_URL');

  const apiKey = process.env.API_KEY;
  const dbUrl = process.env.DATABASE_URL;

  // TypeScript এখন জানে apiKey এবং dbUrl স্ট্রিং, 'string | undefined' নয়।
  // আপনার অ্যাপ্লিকেশনে প্রয়োজনীয় কনফিগারেশন থাকার নিশ্চয়তা আছে।
  console.log('API Key length:', apiKey.length);
  console.log('Connecting to DB:', dbUrl.toLowerCase());

  // ... বাকি সার্ভার স্টার্টআপ লজিক
}

startServer();

কেন এটি শক্তিশালী: এই প্যাটার্নটিকে "ফেইল-ফাস্ট" বলা হয়। আপনি আপনার অ্যাপ্লিকেশনের জীবনচক্রের একেবারে শুরুতে সমস্ত গুরুত্বপূর্ণ কনফিগারেশন একবার যাচাই করেন। যদি কোনো সমস্যা থাকে, তবে এটি একটি বর্ণনামূলক ত্রুটি সহ অবিলম্বে ব্যর্থ হয়, যা পরে অনুপস্থিত ভেরিয়েবলটি ব্যবহৃত হলে ঘটে যাওয়া একটি রহস্যময় ক্র্যাশের চেয়ে ডিবাগ করা অনেক সহজ।

ব্যবহার ক্ষেত্র ৩: DOM এর সাথে কাজ করা

যখন আপনি DOM কোয়েরি করেন, যেমন `document.querySelector` দিয়ে, ফলাফলটি হয় `Element | null`। যদি আপনি নিশ্চিত হন যে একটি এলিমেন্ট বিদ্যমান (যেমন, মূল অ্যাপ্লিকেশন রুট `div`), ক্রমাগত `null` এর জন্য পরীক্ষা করা কষ্টকর হতে পারে।

দৃশ্যপট

আমাদের কাছে `

` সহ একটি HTML ফাইল রয়েছে, এবং আমাদের স্ক্রিপ্টকে এতে কন্টেন্ট যুক্ত করতে হবে। আমরা জানি এটি বিদ্যমান।


// আমাদের আগের জেনেরিক অ্যাসারশনটি পুনঃব্যবহার করছি
function assertIsDefined<T>(value: T, message: string = "Value is not defined"): asserts value is NonNullable<T> {
  if (value === undefined || value === null) {
    throw new Error(message);
  }
}

// DOM এলিমেন্টের জন্য একটি আরও নির্দিষ্ট অ্যাসারশন
function assertQuerySelector<T extends Element>(selector: string, constructor?: new () => T): T {
  const element = document.querySelector(selector);
  assertIsDefined(element, `FATAL: Element with selector '${selector}' not found in the DOM.`);

  // ঐচ্ছিক: এটি সঠিক ধরনের এলিমেন্ট কিনা তা পরীক্ষা করুন
  if (constructor && !(element instanceof constructor)) {
    throw new TypeError(`Element '${selector}' is not an instance of ${constructor.name}`);
  }

  return element as T;
}

// ব্যবহার
const appRoot = document.querySelector('#app-root');
assertIsDefined(appRoot, 'Could not find the main application root element.');

// অ্যাসারশনের পরে, appRoot এর টাইপ 'Element', 'Element | null' নয়।
appRoot.innerHTML = '

Hello, World!

'; // আরও নির্দিষ্ট হেল্পার ব্যবহার করে const submitButton = assertQuerySelector<HTMLButtonElement>('#submit-btn', HTMLButtonElement); // 'submitButton' এখন সঠিকভাবে HTMLButtonElement হিসাবে টাইপ করা হয়েছে submitButton.disabled = true;

কেন এটি শক্তিশালী: এটি আপনাকে আপনার পরিবেশ সম্পর্কে একটি ইনভ্যারিয়েন্ট—একটি শর্ত যা আপনি সত্য বলে জানেন—প্রকাশ করতে দেয়। এটি অপ্রয়োজনীয় নাল-চেকিং কোড সরিয়ে দেয় এবং স্ক্রিপ্টের একটি নির্দিষ্ট DOM কাঠামোর উপর নির্ভরতা পরিষ্কারভাবে নথিভুক্ত করে। যদি কাঠামো পরিবর্তন হয়, আপনি একটি তাৎক্ষণিক, স্পষ্ট ত্রুটি পাবেন।

অ্যাসারশন ফাংশন বনাম বিকল্পগুলি

টাইপ গার্ড বা টাইপ কাস্টিং-এর মতো অন্যান্য টাইপ-ন্যারোয়িং কৌশলগুলোর তুলনায় কখন একটি অ্যাসারশন ফাংশন ব্যবহার করতে হবে তা জানা অত্যন্ত গুরুত্বপূর্ণ।

কৌশল সিনট্যাক্স ব্যর্থ হলে আচরণ সর্বোত্তম ব্যবহার
টাইপ গার্ডস value is Type false রিটার্ন করে কন্ট্রোল ফ্লো (if/else)। যখন 'আনহ্যাপি' কেসের জন্য একটি বৈধ, বিকল্প কোড পাথ থাকে। যেমন, "যদি এটি একটি স্ট্রিং হয়, তবে এটি প্রক্রিয়া করুন; অন্যথায়, একটি ডিফল্ট ভ্যালু ব্যবহার করুন।"
অ্যাসারশন ফাংশন asserts value is Type একটি Error থ্রো করে ইনভ্যারিয়েন্ট প্রয়োগের জন্য। যখন প্রোগ্রামটি সঠিকভাবে চালিয়ে যাওয়ার জন্য একটি শর্ত অবশ্যই সত্য হতে হবে। "আনহ্যাপি" পাথটি একটি অপূরণীয় ত্রুটি। যেমন, "এপিআই রেসপন্স অবশ্যই একটি User অবজেক্ট হতে হবে।"
টাইপ কাস্টিং value as Type কোনো রানটাইম প্রভাব নেই বিরল ক্ষেত্রে যেখানে আপনি, ডেভেলপার, কম্পাইলারের চেয়ে বেশি জানেন এবং ইতিমধ্যে প্রয়োজনীয় পরীক্ষাগুলো সম্পন্ন করেছেন। এটি শূন্য রানটাইম সুরক্ষা প্রদান করে এবং খুব কম ব্যবহার করা উচিত। এর অতিরিক্ত ব্যবহার একটি "কোড স্মেল"।

মূল নির্দেশিকা

নিজেকে জিজ্ঞাসা করুন: "এই চেকটি ব্যর্থ হলে কী হওয়া উচিত?"

উন্নত প্যাটার্ন এবং সেরা অনুশীলন

১. একটি কেন্দ্রীয় অ্যাসারশন লাইব্রেরি তৈরি করুন

আপনার কোডবেস জুড়ে অ্যাসারশন ফাংশন ছড়িয়ে ছিটিয়ে রাখবেন না। সেগুলিকে একটি ডেডিকেটেড ইউটিলিটি ফাইলে কেন্দ্রীভূত করুন, যেমন src/utils/assertions.ts। এটি পুনঃব্যবহারযোগ্যতা, সামঞ্জস্যতা বৃদ্ধি করে এবং আপনার ভ্যালিডেশন লজিক খুঁজে পাওয়া ও পরীক্ষা করা সহজ করে তোলে।


// src/utils/assertions.ts

export function assert(condition: unknown, message: string): asserts condition {
  if (!condition) {
    throw new Error(message);
  }
}

export function assertIsDefined<T>(value: T): asserts value is NonNullable<T> {
  assert(value !== null && value !== undefined, 'This value must be defined.');
}

export function assertIsString(value: unknown): asserts value is string {
  assert(typeof value === 'string', 'This value must be a string.');
}

// ... ইত্যাদি।

২. অর্থপূর্ণ ত্রুটি থ্রো করুন

একটি ব্যর্থ অ্যাসারশন থেকে প্রাপ্ত ত্রুটি বার্তা ডিবাগিংয়ের সময় আপনার প্রথম সূত্র। এটিকে কার্যকর করুন! "Assertion failed"-এর মতো একটি জেনেরিক বার্তা সহায়ক নয়। পরিবর্তে, প্রসঙ্গ সরবরাহ করুন:


function assertIsUser(data: unknown): asserts data is User {
  if (!isUser(data)) {
    // খারাপ: throw new Error('Invalid data');
    // ভালো:
    throw new TypeError(`Expected data to be a User object, but received ${JSON.stringify(data)}`);
  }
}

৩. পারফরম্যান্সের প্রতি মনোযোগী হন

অ্যাসারশন ফাংশনগুলো রানটাইম চেক, যার মানে তারা সিপিইউ সাইকেল ব্যবহার করে। এটি আপনার অ্যাপ্লিকেশনের সীমানায় (এপিআই ইনগ্রেস, কনফিগারেশন লোডিং) পুরোপুরি গ্রহণযোগ্য এবং আকাঙ্ক্ষিত। তবে, পারফরম্যান্স-ক্রিটিক্যাল কোড পাথের ভিতরে জটিল অ্যাসারশন রাখা এড়িয়ে চলুন, যেমন একটি টাইট লুপ যা প্রতি সেকেন্ডে হাজার হাজার বার চলে। সেগুলি এমন জায়গায় ব্যবহার করুন যেখানে চেকের খরচ সম্পাদিত অপারেশনের (যেমন একটি নেটওয়ার্ক অনুরোধ) তুলনায় নগণ্য।

উপসংহার: আত্মবিশ্বাসের সাথে কোড লেখা

টাইপস্ক্রিপ্ট অ্যাসারশন ফাংশনগুলো কেবল একটি বিশেষ ফিচার নয়; এগুলি শক্তিশালী, প্রোডাকশন-গ্রেড অ্যাপ্লিকেশন লেখার জন্য একটি মৌলিক হাতিয়ার। এগুলি আপনাকে কম্পাইল-টাইম তত্ত্ব এবং রানটাইম বাস্তবতার মধ্যেকার গুরুত্বপূর্ণ ব্যবধান পূরণ করতে সক্ষম করে।

অ্যাসারশন ফাংশন গ্রহণ করে, আপনি করতে পারেন:

পরের বার যখন আপনি একটি এপিআই থেকে ডেটা আনবেন, একটি কনফিগারেশন ফাইল পড়বেন, বা ব্যবহারকারীর ইনপুট প্রক্রিয়া করবেন, তখন কেবল টাইপ কাস্ট করে সেরাটার আশা করবেন না। এটি অ্যাসার্ট করুন। আপনার সিস্টেমের প্রান্তে একটি সুরক্ষা গেট তৈরি করুন। আপনার ভবিষ্যতের আপনি—এবং আপনার দল—আপনার লেখা শক্তিশালী, অনুমানযোগ্য এবং স্থিতিস্থাপক কোডের জন্য আপনাকে ধন্যবাদ জানাবে।

টাইপস্ক্রিপ্ট অ্যাসারশন ফাংশন: রানটাইম টাইপ সেফটির সম্পূর্ণ নির্দেশিকা | MLOG