IF در جاوا اسکریپت و نحوه استفاده از آن + مثال و کد

۱۴۳۲ بازدید
آخرین به‌روزرسانی: ۱۴ مرداد ۱۴۰۲
زمان مطالعه: ۱۰ دقیقه
IF در جاوا اسکریپت و نحوه استفاده از آن + مثال و کد

در امور برنامه نویسی، موقعیت‌هایی وجود دارد که باید شرایط مختلفی را در کد مدیریت کرد. یکی از راه‌های رسیدن به این هدف، استفاده از عبارت if...elseاست که به کاربر اجازه می‌دهد تا بلوک‌های مختلف کد را بر اساس شرایطی خاص اجرا کند. برای نمونه اگر کاربری رباتی توسعه دهد و بخواهد نسبت به دستوراتی یا سؤال‌هایی که از ربات پرسیده می‌شود، پاسخ‌هایی دریافت کند، باید از دستورات شرطی بهره ببرد. زبان برنامه نویسی جاوا اسکریپت هم مانند سایر زبان‌های برنامه نویسی دیگر حاوی دستورات شرطی مختص به خود بوده که یکی از مهم‌ترین آن‌ها دستور IF است. در این مطلب آموزشی از «مجله فرادرس» به آموزش دستور IF در جاوا اسکریپت در قالب نمونه کدهای ساده و روان پرداخته خواهد شد. در پایان این مطلب کاربران درک نسبتاً خوبی از دستورات شرطی و به خصوص دستورif...elseاز جاوا اسکریپت خواهند داشت.

997696

دستور IF...Else در جاوا اسکریپت چیست؟

دستور «IF...Else» نوعی گزاره شرطی در جاوا اسکریپت است که به کاربر امکان می‌دهد بلوک‌های مختلف کد را بر اساس «درست» (True) یا «نادرست» (False) بودن شرطی معین اجرا کند. وقتی شرط داخل دستور IF به درستی ارزیابی شود، کد داخل بلوک IF مربوطه اجرا می‌شود. اگر شرط نادرست ارزیابی شود، کد داخل بلوک «Else» (در صورت وجود) اجرا می‌شود.

در جاوا اسکریپت، مقادیر درست یا نادرست در نظر گرفته می‌شوند و این مقادیر در رویکردهای بولی، مانند دستور IF مورد استفاده قرار می‌گیرند. مقادیر زیر همگی نادرست یا Falseدر نظر گرفته می‌شوند:

  • «False»
  • 0(صفر)
  • - 0(منفی صفر)
  • 0n (BigInt صفر)
  • "", '', `` رشته خالی
  • «Null»
  • «تعریف نشده» (Undefine)
  • «NaN»

هر مقدار دیگری که در فهرست بالا ذکر نشده باشد، درست یا Trueتلقی می‌شود.

مثال دستور IF...Else در جاوا اسکریپت

عبارت if...elseدر جاوا اسکریپت به کاربر این امکان را می‌دهد که در کد خود بر اساس شرایطی خاص تصمیم‌گیری کند. ساختار دستور if...elseبه صورت زیر است:

1if (condition) {
2  // code to be executed if the condition is true (truthy)
3} else {
4  // code to be executed if the condition is false (falsy)
5}

در مثال اول فرض می‌شود که متغیری به نام ageبه معنی سن موجود بوده که روی 18تنظیم شده است. شرط داخل دستور ifبررسی می‌کند که آیا ageبزرگ‌تر یا مساوی با18 است یا خیر. از آنجایی که عدد 18شرط بزرگتر و مساوی با 18را ارضا خواهد کرد در نتیجه شرط درست ارزیابی شده و کد داخل بلوک ifاجرا خواهد شد. در این حالت کنسول ALI is an adultرا نمایش می‌دهد.

1const age = 18;
2
3if (age >= 18) {
4  console.log("ALI is an adult.");
5} else {
6  console.log("ALI is a child.");
7}

خروجی کد بالا در کنسول مرورگر به صورت زیر است:

مثال دستور if...else در جاوا اسکریپت

حال اگر مقدار متغیر ageبه 12تغییر داده شود، شرط موجود در دستورifبه falseارزیابی می‌شود و کد داخل بلوک elseاجرا خواهد شد که در این شرایط کنسول ALI is a childرا نمایش می‌دهد.

1const age = 12;
2
3if (age >= 18) {
4  console.log("ALI is an adult.");
5} else {
6  console.log("ALI is a child.");
7}

این بار خروجی در کنسول مرورگر به صورت زیر خواهد بود:

آموزش دستورات شرطی در جاوا اسکریپت

با دستور if...elseمی‌توان جریان برنامه را بر اساس شرایط مختلف کنترل کرد و این ویژگی آن را به ابزاری قدرتمند برای تصمیم‌گیری در کدنویسی جاوا اسکریپت تبدیل کرده است.

مثال دستورات چند گانه IF...Else در Javascript

در برخی از سناریوها، ممکن است لازم باشد چندین شرط آزمایش شوند تا معلوم شود کدام بلوک کد باید به اجرا درآید. در چنین مواقعی می‌توان از بلوک else ifهمراه با عبارت if...elseاستفاده کرد. ساختار دستور if...else if...elseبه صورت زیر است:

1if (condition1) {
2  // code to be executed if condition1 is true
3} else if (condition2) {
4  // code to be executed if condition2 is true
5} else {
6  // code to be executed if none of the conditions are true
7}

هنگامی که شرط دستور ifنادرست ارزیابی شود، برنامه برای ارزیابی اولین شرط دستورifبه کار خود ادامه می‌دهد. اگر این شرط درست باشد، بلوک کد مربوطه اجرا خواهد شد. در غیر این صورت، برنامه به ارزیابی سایر عبارات در صورت وجود ادامه خواهد داد. اگر هیچ یک از شرایط موجود در بلوک‌های else ifدرست نباشند، کد داخل بلوک elseاجرا می‌شود.

در مثال زیر دوباره همان متغیر ageرا فرض می‌کنیم که روی 18تنظیم شده است. دستور IF در جاوا اسکریپت و در این مورد بررسی می‌کند که اگر ageکمتر از 18باشد و این عبارت به درست ارزیابی شود در نتیجه ، Alice is under 18 years oldرا چاپ کند. اگر شرط اول نادرست باشد، دستور ifدیگری بررسی می‌کند که آیا ageبین 18تا 21سال است یا خیر. اگر این شرایط ارضا شود یا به عبارت دیگر شرط درست باشد، Alice is between the ages of 18 and 21در کنسول مرورگر چاپ می‌شود. اگر هر دو شرط ifو else ifنادرست باشند، به بلوک elseبرمی‌گردد و Alice is over 21 years oldرا چاپ می‌کند.

1const age = 18;
2
3if (age < 18) {
4  console.log("Alice is under 18 years old.");
5} else if (age >= 18 && age <= 21) {
6  console.log("Alice is between the ages of 18 and 21.");
7} else {
8  console.log("Alice is over 21 years old.");
9}

خروجی کد فوق به صورت زیر است:

دستورات چند گانه if...else در Javascript

با استفاده از دستورات چندگانه IF در جاوا اسکریپت، می‌توان به طور موثر چندین شرایط را مدیریت کرد و تصمیمات پیچیده‌تری در کد جاوا اسکریپت خود گرفت.

چه زمانی از دستورهای Switch باید به جای عبارات IF...Else استفاده کرد؟

در جاوا اسکریپت، موقعیت‌هایی وجود دارد که استفاده از دستور «Switch» می‌تواند بهتر از استفاده از دستور «IF...Else» باشد. دستورات Switch می‌توانند «سینتکس» (Syntax) تمیزتری داشته باشند و خوانایی را ارائه دهند، به خصوص زمانی که شرایط متعددی در کد وجود داشته باشد. با این حال، درک زمان استفاده مناسب از هر ساختار ضروری است. بیایید مثال‌های ارائه شده برای نشان دادن استفاده از دستورات switchو IF...Else در جاوا اسکریپت را در نظر بگیریم تا تفاوت آن‌ها را بهتر دریابیم.

مثال استفاده از عبارات if...elseبه صورت زیر است:

1const pet = "dog";
2
3if (pet === "lizard") {
4  console.log("I own a lizard");
5} else if (pet === "dog") {
6  console.log("I own a dog");
7} else if (pet === "cat") {
8  console.log("I own a cat");
9} else if (pet === "snake") {
10  console.log("I own a snake");
11} else if (pet === "parrot") {
12  console.log("I own a parrot");
13} else {
14  console.log("I don't own a pet");
15}

حال مثال استفاده از عبارات switchبه صورت زیر است:

1const pet = "dog";
2
3switch (pet) {
4  case "lizard":
5    console.log("I own a lizard");
6    break;
7  case "dog":
8    console.log("I own a dog");
9    break;
10  case "cat":
11    console.log("I own a cat");
12    break;
13  case "snake":
14    console.log("I own a snake");
15    break;
16  case "parrot":
17    console.log("I own a parrot");
18    break;
19  default:
20    console.log("I don't own a pet");
21    break;
22}

هر دو ساختار شرطی کدهای بالا به نتیجه واحدی می‌رسند اما دستور switchاغلب زمانی که شرایط متعددی برای بررسی یک متغیر وجود داشته باشد، کد تمیزتر و مختصرتری ارائه می‌دهد. بهتر است در حالت‌های زیر از دستور switchاستفاده شود:

  • هنگام مقایسه متغیری واحد در برابر چندین مقدار.
  • زمانی که شرایط بررسی برابری ساده است (مثلاً ===) و شامل عملیات منطقی پیچیده نیست.
  • وقتی چندین مورد با مقادیر ثابت موجود است که به بررسی محدوده یا شرایط پیچیده‌تر نیاز ندارند.

بهتر است در حالت‌های زیر از IF...Else در جاوا اسکریپت استفاده شود:

  • هنگام برخورد با شرایط پیچیده یا چندگانه که شامل عملیات منطقی (به عنوان مثال AND ،OR) فراتر از بررسی‌های ساده برابری است.
  • زمانی که به انعطاف‌پذیری بیشتری در شرایط نیاز است، مانند استفاده از محدوده‌ها یا عملگرهای مقایسه‌ای متفاوت.

مهم است که ساختار مناسب بر اساس الزامات خاص کد مربوطه انتخاب شوند. در حالی که عبارات switchمی‌تواند منجر به کدهای خواناتر در موقعیت‌های خاص شود، دستور if...elseانعطاف‌پذیری بیشتری برای مدیریت شرایط پیچیده ارائه می‌دهد. هنگام انتخاب بین دو ساختار، همیشه خوانایی و قابلیت نگهداری کد باید در اولویت قرار بگیرد.

عملگر AND منطقی و دستور IF...Else در جاوا اسکریپت

در جاوا اسکریپت، عملگر منطقی «AND (&&)‎» به کاربر امکان می‌دهد دو یا چند شرط را در یک دستور ifترکیب کند. اگر تمام شرایط متصل شده به وسیله عملگر &&درست ارزیابی شوند، کد داخل بلوک ifاجرا خواهد شد. اگر هر یک از شرایط نادرست باشند، کد داخل بلوک else(در صورت ارائه) به‌جای آن اجرا می‌شود. مثال‌های زیر بیانگر این مفهوم ‌هستند:

مثال ١: قطعه کد مثال اول به صورت زیر است:

1const age = 17;
2const ownsCar = true;
3
4if (age >= 16 && ownsCar) {
5  console.log("Jerry is old enough to drive and has his own car.");
6} else {
7  console.log("Jerry does not drive.");
8}

خروجی مثال فوق در کنسول مروگر به صورت زیر خواهد بود:

عملگر AND منطقی و دستور if...else در جاوا اسکریپت

در مثال فوق، دستور IF در جاوا اسکریپت دارای دو شرط است که به وسیله عملگر &&به همدیگر متصل شده‌اند. این دستورات بررسی می‌کنند که آیا سن بیشتر یا مساوی از 16بوده یا خیر و اینکه آیا ownsCarبه درست ارزیابی خواهد شد یا خیر. از آنجا که هر دو شرط درست هستند، کد داخل بلوک ifاجرا می‌شود و کنسول متن مد نظر در تصویر بالا را نمایش می‌دهد.

مثال ٢: قطعه کد مثال دوم به صورت زیر است:

1const age = 13;
2const ownsCar = true;
3
4if (age >= 16 && ownsCar) {
5  console.log("Jerry is old enough to drive and has his own car.");
6} else {
7  console.log("Jerry does not drive.");
8}

خروجی کد فوق در داخل کنسول مرورگر به صورت زیر است:

کاربرد دستور if...else در جاوا اسکریپت

در مثال فوق، مقدار سن اکنون 13 بوده که کمتر از 16است. حتی اگر ownsCarدرست باشد، شرط اول (age >= 16) به نادرست ارزیابی می‌شود. در نتیجه، کد داخل بلوک elseاجرا شده و کنسول Jerry does not driveرا نمایش می‌دهد. عملگر منطقی AND (&&)‎زمانی مفید است که اطمینان حاصل شود چند شرط برای اجرای بلوک کد مد نظر باید به درستی ارزیابی شوند. اگر هر یک از شرایط نادرست باشند، بلوک elseنوعی گزینه بازگشتی برای اجرای کد جایگزین ارائه می‌دهد.

عملگر منطقی OR و عبارات IF...Else در جاوا اسکریپت

در جاوا اسکریپت، عملگر منطقی «OR (||)‎» به کاربر امکان می‌دهد دو یا چند شرط را در یک دستور ifترکیب کند. اگر حداقل یکی از شرایط مرتبط با ||به درستی ارزیابی شود، کد داخل بلوک ifاجرا خواهد شد. تنها زمانی که همه شرایط نادرست باشند، کد داخل بلوک else(در صورت ارائه) اجرا می‌شود. مثال‌های زیر برای درک ترکیب عملگر منطقی OR (||)‎و عبارات IF...Else در جاوا اسکریپت مهم هستند.

مثال ١: قطعه کد مثال اول به صورت زیر است:

1const boyfriendIsPaying = true;
2const isSale = false;
3
4if (boyfriendIsPaying || isSale) {
5  console.log("Jesse will go shopping.");
6} else {
7  console.log("Jesse will not go shopping.");
8}

خروجی کد بالا در کنسول مرورگر به صورت زیر است:

عملگر منطقی OR و عبارات if...else در جاوا اسکریپت

در مثال فوق، دستور IF در جاوا اسکریپت از عملگر ||برای بررسی اینکه آیا boyfriendIsPayingیا isSaleکدام به درستی ارزیابی می‌شوند استفاده خواهد کرد. از آنجایی که boyfriendIsPayingدرست است، شرط درست خواهد بود حتی اگر isSaleنادرست باشد. بنابراین، کد داخل بلوک ifاجرا می‌شود و کنسول Jesse will go shoppingرا نمایش می‌دهد.

مثال ٢: قطعه کد مثال دوم به صورت زیر است:

1const boyfriendIsPaying = false;
2const isSale = false;
3
4if (boyfriendIsPaying || isSale) {
5  console.log("Jesse will go shopping.");
6} else {
7  console.log("Jesse will not go shopping.");
8}

خروجی مثال فوق در کنسول مرورگر به صورت زیر خواهد بود:

سینتکس دستور دستور if در جاوا اسکریپت

در مثال دوم، هر دو boyfriendIsPayingو isSaleنادرست هستند. از آنجا که هیچ یک از شرایط به درستی ارزیابی نمی‌شوند، کد داخل بلوک elseاجرا می‌شود و کنسول Jesse will not go shoppingرا نمایش می‌دهد. عملگر منطقی OR (||)‎زمانی مفید است که کاربر بخواهد سناریوهای مختلفی را بررسی کند که در این شرایط حداقل یک شرط برای اجرای بلوک ifباید به درستی ارزیابی شود.

عملگر منطقی NOT و عبارات IF...Else در Javascript

در جاوا اسکریپت، عملگر منطقی NOT (!)‎به کاربر اجازه می‌دهد نوعی مقدار بولی را نفی کند. این یعنی که این عملگر درست را به نادرست و نادرست را به درست تبدیل می‌کند. این عملگر مخصوصاً زمانی مفید است که کاربر نیاز به معکوس کردن صحت شرط داشته باشد.

مثال زیر برای درک نقش این عملکرد در ترکیب آن با شرط IF در جاوا اسکریپت مهم است:

1const boyfriendIsPaying = true;
2const isSale = false;
3
4if (!boyfriendIsPaying || isSale) {
5  console.log("Jesse will go shopping.");
6} else {
7  console.log("Jesse will not go shopping.");
8}

خروجی کد بالا در کنسول مرورگی به صورت تصویر زیر است:

عملگر منطقی NOT و عبارات if...else در Javascript

در مثال فوق، متغیر boyfriendIsPaying روی trueتنظیم شده است. با این حال در مثال ارائه شده از عملگر منطقی NOT (!)‎قبل از آن در دستور ifاستفاده شده است تا مقدار آن را نفی کند. بنابراین، !boyfriendIsPaying به نادرست ارزیابی می‌شود. شرط دوم isSale، هنوز نادرست است. حال وقتی از عملگر منطقی OR (||)‎برای اتصال شرایط استفاده شود، شرط به نادرست ارزیابی خواهد شد و از آنجا که هیچ یک از شرایط صحیح نیست، کد داخل بلوک elseاجرا می‌شود در نتیجه، کنسول Jesse will not go shoppingرا نمایش می‌دهد.

عملگر منطقی NOT (!)‎زمانی می‌تواند مفید واقع شود که کاربر نیاز به بررسی شرایط مخالف نوعی متغیر یا عبارت را داشته باشد. با نفی مقدار، می‌توان جریان عبارات if...elseرا به طور مؤثرتر تغییر داد.

عملگر شرطی سه تایی در جاوا اسکریپت

عملگر شرطی سه‌تایی در جاوا اسکریپت روشی مختصر برای نوشتن عبارات ساده if...elseارائه می‌دهد. عملگر سه‌تایی نوعی ساختار تک‌خطی است که شرطی را ارزیابی می‌کند و یکی از دو مقدار Trueیا Falseرا بر اساس درست یا نادرست بودن شرط بازمی‌گرداند.

سینتکس اصلی عملگر شرطی سه‌تایی به شرح زیر است:

1condition ? if condition 1 is true : if condition 2 is false

شرط قبل از علامت سوال (؟) قرار می‌گیرد و اگر شرط به درستی ارزیابی شود، عبارت اول اجرا می‌شود. اگر شرط نادرست باشد، عبارت دوم اجرا خواهد شد. مثال زیر برای درک این مفهوم مهم است:

1const age = 32;
2const citizen = age >= 18 ? "Can vote" : "Cannot vote";
3console.log(citizen);

خروجی مثال فوق به صورت زیر است:

عملگر شرطی سه تایی در جاوا اسکریپت

در مثال فوق شرط age >= 18ارزیابی می‌شود. از آنجایی که ageبرابر با 32 و شرط بزرگتر بودن از 18 را ارضا می‌کند در نتیجه شرط برای رأی دادن به درست ارزیابی می‌شود. بنابراین عبارت Can voteبه متغیر citizenاختصاص داده خواهد شد. سپس عبارت console.log(citizen) "Can vote"در کنسول می‌شود.

عملگر شرطی سه‌تایی انتخابی عالی برای زمانی است که عبارت کوتاه و ساده if...elseموجود باشد و در این شرایط این عملگر مذکور روشی مختصر و خوانا برای بیان منطق برنامه فراهم می‌کند. برای مقایسه کد بالا این بار با استفاده از عبارت معمولی IF...Else در جاوا اسکریپت نوشته شده است:

1const age = 32;
2let citizen;
3
4if (age >= 18) {
5  citizen = "Can vote";
6} else {
7  citizen = "Cannot vote";
8}
9
10console.log(citizen);

هر دو دستور عملگر سه‌تایی و if...elseبه نتیجه واحدی رسیده‌اند اما عملگر سه‌تایی می‌تواند برای عبارات شرطی کوتاه‌تر مناسب‌تر باشد و کد را خواناتر و فشرده‌تر می‌کند. با این حال، زمانی که شرایط پیچیده‌تری موجود بوده یا عبارات متعددی برای مدیریت وجود داشته باشد ، عبارت IF...Else در جاوا اسکریپت انعطاف‌پذیری و خوانایی بیشتری را ارائه می‌دهد. همیشه ساختار مناسب باید بر اساس پیچیدگی و الزامات مورد استفاده خاص انتخاب شود.

سخن پایانی

دستورات شرطی ابزار قدرتمندی در جاوا اسکریپت برای تصمیم‌گیری در کد بر اساس شرایط خاص هستند. در زیر خلاصه‌ای از آنچه که در این مطلب آموزش داده شد، آورده شده است:

  • دستورات if...else: زمانی که شرط موجود در عبارت ifبه درست ارزیابی شود، یک بلوک کد را اجرا می‌کنند. اگر شرط نادرست باشد، کد داخل بلوک else(در صورت ارائه) اجرا می‌شود.
  • عبارات if...else if...else: برای آزمایش چند شرط مفید هستند. هنگامی که دستور ifنادرست است، برنامه برای ارزیابی اولین شرط ifدیگری ادامه خواهد یافت. اگر این شرط درست باشد، بلوک کد مربوطه اجرا خواهد شد. در غیر این صورت، برنامه می‌تواند در صورت وجود عبارات دیگری را ارزیابی کند.
  • دستورswitch: اگر عبارت if...elseطولانی و پیچیده شود، دستور switchمی‌تواند جایگزین خواناتری باشد. عبارات switchمی‌تواند به‌ویژه هنگام مقایسه یک متغیر منفرد در برابر چندین مقدار باحالت‌های ثابت مفید باشد.
  • عملگرهای منطقی: می‌توان از عملگرهای منطقی (به عنوان مثال، &&، ||، !) برای آزمایش چند شرط بدون استفاده از دستورات تودرتو if...elseاستفاده کرد. عملگرهای منطقی می‌توانند به کاربر کمک کنند تا کد خود را ساده کرده و آن را مختصرتر کند.
  •  عملگر سه‌تایی: عملگر سه‌تایی روشی مختصر برای نوشتن عبارات ساده if...elseارائه می‌دهد. این عملگر از یک شرط تشکیل شده است که به دنبال آن دو عبارت با علامت سؤال (؟) و دونقطه (:) از هم جدا می‌شوند. اگر شرط درست باشد، عبارت اول اجرا می‌شود. در غیر این صورت، عبارت دوم اجرا خواهد شد.

در مطلب فوق از مجله فرادرس در رابطه با هرکدام از موارد فوق توضیحاتی همراه با مثال ارائه شد. با درک مفهوم IF...Else در جاوا اسکریپت و انتخاب ساختاری مناسب بر اساس پیچیدگی شرایط کد، می‌توان کدی تمیز، خوانا و کارآمد برای مدیریت سناریوهای مختلف در جاوا اسکریپت نوشت.

بر اساس رای ۲ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
FreeCodeCamp
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *