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


در امور برنامه نویسی، موقعیتهایی وجود دارد که باید شرایط مختلفی را در کد مدیریت کرد. یکی از راههای رسیدن به این هدف، استفاده از عبارت if...elseاست که به کاربر اجازه میدهد تا بلوکهای مختلف کد را بر اساس شرایطی خاص اجرا کند. برای نمونه اگر کاربری رباتی توسعه دهد و بخواهد نسبت به دستوراتی یا سؤالهایی که از ربات پرسیده میشود، پاسخهایی دریافت کند، باید از دستورات شرطی بهره ببرد. زبان برنامه نویسی جاوا اسکریپت هم مانند سایر زبانهای برنامه نویسی دیگر حاوی دستورات شرطی مختص به خود بوده که یکی از مهمترین آنها دستور IF است. در این مطلب آموزشی از «مجله فرادرس» به آموزش دستور IF در جاوا اسکریپت در قالب نمونه کدهای ساده و روان پرداخته خواهد شد. در پایان این مطلب کاربران درک نسبتاً خوبی از دستورات شرطی و به خصوص دستورif...elseاز جاوا اسکریپت خواهند داشت.
دستور 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به صورت زیر است:
در مثال اول فرض میشود که متغیری به نام ageبه معنی سن موجود بوده که روی 18تنظیم شده است. شرط داخل دستور ifبررسی میکند که آیا ageبزرگتر یا مساوی با18 است یا خیر. از آنجایی که عدد 18شرط بزرگتر و مساوی با 18را ارضا خواهد کرد در نتیجه شرط درست ارزیابی شده و کد داخل بلوک ifاجرا خواهد شد. در این حالت کنسول ALI is an adultرا نمایش میدهد.
خروجی کد بالا در کنسول مرورگر به صورت زیر است:

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

با دستور if...elseمیتوان جریان برنامه را بر اساس شرایط مختلف کنترل کرد و این ویژگی آن را به ابزاری قدرتمند برای تصمیمگیری در کدنویسی جاوا اسکریپت تبدیل کرده است.
مثال دستورات چند گانه IF...Else در Javascript
در برخی از سناریوها، ممکن است لازم باشد چندین شرط آزمایش شوند تا معلوم شود کدام بلوک کد باید به اجرا درآید. در چنین مواقعی میتوان از بلوک else ifهمراه با عبارت if...elseاستفاده کرد. ساختار دستور if...else if...elseبه صورت زیر است:
هنگامی که شرط دستور 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را چاپ میکند.
خروجی کد فوق به صورت زیر است:

با استفاده از دستورات چندگانه IF در جاوا اسکریپت، میتوان به طور موثر چندین شرایط را مدیریت کرد و تصمیمات پیچیدهتری در کد جاوا اسکریپت خود گرفت.
چه زمانی از دستورهای Switch باید به جای عبارات IF...Else استفاده کرد؟
در جاوا اسکریپت، موقعیتهایی وجود دارد که استفاده از دستور «Switch» میتواند بهتر از استفاده از دستور «IF...Else» باشد. دستورات Switch میتوانند «سینتکس» (Syntax) تمیزتری داشته باشند و خوانایی را ارائه دهند، به خصوص زمانی که شرایط متعددی در کد وجود داشته باشد. با این حال، درک زمان استفاده مناسب از هر ساختار ضروری است. بیایید مثالهای ارائه شده برای نشان دادن استفاده از دستورات switchو IF...Else در جاوا اسکریپت را در نظر بگیریم تا تفاوت آنها را بهتر دریابیم.
مثال استفاده از عبارات if...elseبه صورت زیر است:
حال مثال استفاده از عبارات switchبه صورت زیر است:
هر دو ساختار شرطی کدهای بالا به نتیجه واحدی میرسند اما دستور switchاغلب زمانی که شرایط متعددی برای بررسی یک متغیر وجود داشته باشد، کد تمیزتر و مختصرتری ارائه میدهد. بهتر است در حالتهای زیر از دستور switchاستفاده شود:
- هنگام مقایسه متغیری واحد در برابر چندین مقدار.
- زمانی که شرایط بررسی برابری ساده است (مثلاً ===) و شامل عملیات منطقی پیچیده نیست.
- وقتی چندین مورد با مقادیر ثابت موجود است که به بررسی محدوده یا شرایط پیچیدهتر نیاز ندارند.
بهتر است در حالتهای زیر از IF...Else در جاوا اسکریپت استفاده شود:
- هنگام برخورد با شرایط پیچیده یا چندگانه که شامل عملیات منطقی (به عنوان مثال AND ،OR) فراتر از بررسیهای ساده برابری است.
- زمانی که به انعطافپذیری بیشتری در شرایط نیاز است، مانند استفاده از محدودهها یا عملگرهای مقایسهای متفاوت.
مهم است که ساختار مناسب بر اساس الزامات خاص کد مربوطه انتخاب شوند. در حالی که عبارات switchمیتواند منجر به کدهای خواناتر در موقعیتهای خاص شود، دستور if...elseانعطافپذیری بیشتری برای مدیریت شرایط پیچیده ارائه میدهد. هنگام انتخاب بین دو ساختار، همیشه خوانایی و قابلیت نگهداری کد باید در اولویت قرار بگیرد.
عملگر AND منطقی و دستور IF...Else در جاوا اسکریپت
در جاوا اسکریپت، عملگر منطقی «AND (&&)» به کاربر امکان میدهد دو یا چند شرط را در یک دستور ifترکیب کند. اگر تمام شرایط متصل شده به وسیله عملگر &&درست ارزیابی شوند، کد داخل بلوک ifاجرا خواهد شد. اگر هر یک از شرایط نادرست باشند، کد داخل بلوک else(در صورت ارائه) بهجای آن اجرا میشود. مثالهای زیر بیانگر این مفهوم هستند:
مثال ١: قطعه کد مثال اول به صورت زیر است:
خروجی مثال فوق در کنسول مروگر به صورت زیر خواهد بود:

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

در مثال فوق، مقدار سن اکنون 13 بوده که کمتر از 16است. حتی اگر ownsCarدرست باشد، شرط اول (age >= 16) به نادرست ارزیابی میشود. در نتیجه، کد داخل بلوک elseاجرا شده و کنسول Jerry does not driveرا نمایش میدهد. عملگر منطقی AND (&&)زمانی مفید است که اطمینان حاصل شود چند شرط برای اجرای بلوک کد مد نظر باید به درستی ارزیابی شوند. اگر هر یک از شرایط نادرست باشند، بلوک elseنوعی گزینه بازگشتی برای اجرای کد جایگزین ارائه میدهد.
عملگر منطقی OR و عبارات IF...Else در جاوا اسکریپت
در جاوا اسکریپت، عملگر منطقی «OR (||)» به کاربر امکان میدهد دو یا چند شرط را در یک دستور ifترکیب کند. اگر حداقل یکی از شرایط مرتبط با ||به درستی ارزیابی شود، کد داخل بلوک ifاجرا خواهد شد. تنها زمانی که همه شرایط نادرست باشند، کد داخل بلوک else(در صورت ارائه) اجرا میشود. مثالهای زیر برای درک ترکیب عملگر منطقی OR (||)و عبارات IF...Else در جاوا اسکریپت مهم هستند.
مثال ١: قطعه کد مثال اول به صورت زیر است:
خروجی کد بالا در کنسول مرورگر به صورت زیر است:

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

در مثال دوم، هر دو boyfriendIsPayingو isSaleنادرست هستند. از آنجا که هیچ یک از شرایط به درستی ارزیابی نمیشوند، کد داخل بلوک elseاجرا میشود و کنسول Jesse will not go shoppingرا نمایش میدهد. عملگر منطقی OR (||)زمانی مفید است که کاربر بخواهد سناریوهای مختلفی را بررسی کند که در این شرایط حداقل یک شرط برای اجرای بلوک ifباید به درستی ارزیابی شود.
عملگر منطقی NOT و عبارات IF...Else در Javascript
در جاوا اسکریپت، عملگر منطقی NOT (!)به کاربر اجازه میدهد نوعی مقدار بولی را نفی کند. این یعنی که این عملگر درست را به نادرست و نادرست را به درست تبدیل میکند. این عملگر مخصوصاً زمانی مفید است که کاربر نیاز به معکوس کردن صحت شرط داشته باشد.
مثال زیر برای درک نقش این عملکرد در ترکیب آن با شرط IF در جاوا اسکریپت مهم است:
خروجی کد بالا در کنسول مرورگی به صورت تصویر زیر است:

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

در مثال فوق شرط age >= 18ارزیابی میشود. از آنجایی که ageبرابر با 32 و شرط بزرگتر بودن از 18 را ارضا میکند در نتیجه شرط برای رأی دادن به درست ارزیابی میشود. بنابراین عبارت Can voteبه متغیر citizenاختصاص داده خواهد شد. سپس عبارت console.log(citizen) "Can vote"در کنسول میشود.
عملگر شرطی سهتایی انتخابی عالی برای زمانی است که عبارت کوتاه و ساده if...elseموجود باشد و در این شرایط این عملگر مذکور روشی مختصر و خوانا برای بیان منطق برنامه فراهم میکند. برای مقایسه کد بالا این بار با استفاده از عبارت معمولی IF...Else در جاوا اسکریپت نوشته شده است:
هر دو دستور عملگر سهتایی و 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 در جاوا اسکریپت و انتخاب ساختاری مناسب بر اساس پیچیدگی شرایط کد، میتوان کدی تمیز، خوانا و کارآمد برای مدیریت سناریوهای مختلف در جاوا اسکریپت نوشت.