«عملگرها» (Operators) جزئی جداناپذیر از زبانهای برنامه نویسی هستند و میتوانند عملیاتی را روی مقدار یا «عملوند» (Operand) خاصی انجام دهند. عملگرها در جاوا اسکریپت و در سایر زبانهای برنامه نویسی برای انجام محاسبات ریاضی و منطقی خاص بر روی عملوندها استفاده میشوند. در جاوا اسکریپت، عملگرها برای مقایسه مقادیر، انجام عملیات حسابی و غیره به کار میروند. در این مطلب آموزشی از مجله ریسمونک قرار است در رابطه با انواع عملگرها در جاوا اسکریپت توضیحاتی همراه با مثالهای مختلف برای درک آسان انواع عملگرهای رایج ارائه شود.
عملگر چیست؟
در برنامه نویسی کامپیوتری، عملگرها اجزایی هستند که در زبانهای برنامه نویسی تعریف شدهاند. این اجزا به طور کلی مانند توابع در برنامه نویسی عمل میکنند، اما از نظر نحوی یا معنایی متفاوت هستند. در هر زبان برنامه نویسی معمولاً مجموعهای از عملگرهای داخلی تعریف شدهاند و در برخی موارد، این زبانها به کاربران اجازه میدهند تا معانی جدیدی به عملگرهای موجود اضافه کنند یا حتی عملگرهای کاملاً جدیدی را تعریف کنند.
به بیانی سادهتر، عملگر نمادی است که برای انجام عملیات روی عملوندها استفاده میشود. عملیات میتوانند ریاضی یا منطقی باشند. در جاوا اسکریپت انواع مختلفی از عملگرها برای انجام عملیات مختلف وجود دارد که در ادامه این بخش همه آنها مورد بررسی قرار گرفتهاند.
انواع عملگرها در جاوا اسکریپت
عملگرها در جاوا اسکریپت در دستههای مختلفی قرار میگیرند که مهمترین آنها شامل موارد زیر هستند:
- «عملگرهای حسابی» (Arithmetic Operators)
- «عملگرهای مقایسه» (Arithmetic Operators)
- «عملگرهای منطقی» (Logical Operators)
- «عملگرهای انتسابی» (Assignment Operators)
- «عملگرهای سهتایی» (Ternary Operators)
- «عملگر حذف» (Delete Operators)
- و سایر موارد
عملگرهای حسابی در جاوا اسکریپت
یکی از شناختهشدهترین عملگرها در جاوا اسکریپت، عملگرهای حسابی هستند. عملگرهای حسابی جاوا اسکریپت، عملگرهایی هستند که روی مقادیر عددی عملیات انجام میدهند و یک مقدار عددی را بازمیگردانند. عملگرهای حسابی زیادی در جاوا اسکریپت وجود دارند. در زیر انواع عملگر حسابی جاوا اسکریپت توضیح داده شده است.
۱٫ عملگر جمع (+) در جاوا اسکریپت: این عملگر در جاوا اسکریپت دو عملوند عددی را میگیرد و مجموع عددی آنها را بازمیگرداند. همچنین دو رشته یا عدد را به هم متصل میکند. «سینتکس» (Syntax) آن به صورت زیر است:
۲٫ عملگر تفریق (-) در جاوا اسکریپت: عملگر تفریق، اختلاف دو عملوند را به صورت مقدار عددی بهعنوان خروجی بازمیگرداند. سینتکس آن به صورت زیر است:
۳٫ عملگر ضرب (*) در جاوا اسکریپت: ضرب (*) دو عملوند را در همدیگر ضرب میکند و حاصل را به عنوان خروجی بازمیگرداند. سینتکس آن به صورت زیر است:
۴٫ عملگر تقسیم (/) در جاوا اسکریپت: این عملگر در جاوا اسکریپت دو عملوند را گرفته و عمل تقسیم را برای آنها انجام میدهد. برای این عملگر، عملوند سمت راست «مقسومعلیه» (Divisor) و عملوند سمت چپ «مقسوم» (Dividend) است.
۵٫ عملگر باقیمانده (%) در جاوا اسکریپت: عملگر باقیمانده، مقدار باقیمانده حاصل از تقسیم دو عدد را بازمیگرداند. قطعه کد زیر مربوط به این عملگر در جاوا اسکریپت است.
۶٫ عملگر توان (**) در جاوا اسکریپت: عملگر توان، عملوندی را به توان عملوندی دیگر میرساند. قطعه کد زیر مربوط به عملگر توان در جاوا اسکریپت است که در آن عملوند سمت راست بهعنوان توان استفاده میشود.
مثالی از عملگرهای حسابی جاوا اسکریپت:
خروجی عملیات فوق در ادامه آمده است:
۱۵ ۵ ۵۰ ۲ ۰ ۱۰۰۰۰۰
عملگرهای افزایش و کاهش در جاوا اسکریپت
عملگرهای افزایش و کاهش در جاوا اسکریپت نوعی دیگر از عملگرهای حسابی هستند که شرح و مثال مربوط به آنها به صورت زیر است:
عملگر افزایش (++) در جاوا اسکریپت
این عملگر در جاوا اسکریپت، عملوند خود را افزایش میدهد (یکی به آن اضافه میکند) و مقداری را بازمیگرداند.
- اگر از عملگر به صورت پسوندی استفاده شود (مثلاً ++x)، این عملگر ابتدا متغیر x را برمیگرداند و بعد یک واحد به آن اضافه میکند.
- اگر عملگر به صورت پیشوندی استفاده شود (مثلاً x++)، ابتدا به متغیر x یک واحد اضافه میکند و بعد آن را برمیگرداند.
سینتکس عملگر افزایش در جاوا اسکریپت به صورت زیر است:
عملگر کاهش (–) در جاوا اسکریپت
این عملگر از میان عملگرها در جاوا اسکریپت عملوند خود را کاهش میدهد (یکی از آن کم میکند) و مقداری را برمیگرداند.
- اگر از این علامت به صورت پسوندی استفاده شود، (مثلاً –x)، این عملگر ابتدا متغیر x را برمیگرداند و بعد یک واحد از آن کم میکند.
- اگر عملگر به صورت پیشوندی استفاده شود، (مثلاً x–)، ابتدا از متغیر x یک واحد کم میکند و بعد آن را برمیگرداند.
سینتکس عملگر کاهش در جاوا اسکریپت به صورت زیر است:
مثالی از عملگرهای کاهش و افزایش در جاوا اسکریپت در زیر آورده شده است.
خروجی به شکل زیر خواهد بود:
x = 5; x++=5 x=6 ++x=7 x--=7 x=6 --x=5
عملگرهای یکانی در جاوا اسکریپت
عملگرهای جاوا اسکریپت از نوع یکانی(یکین | Unary) ، یکی دیگر از عملگرهای مهمی هستند که کاربرد مختص به خودشان را دارند. انواع عملگرهای Unary عبارتاند از:
- Unary (-)
- Unary (+)
Unary (-): این عملگر در جاوا اسکریپت، بر روی عملوندی واحد عمل میکند و نفی عملوند را به عنوان خروجی بازمیگرداند. یعنی مقادیر مثبت را به منفی و مقادیر منفی را به مثبت تبدیل خواهد کرد. برای مثال اگر در عبارت Unary (x) مقدار متغیر برابر ۳ باشد، یعنی x=3 باشد، x- برابر با ۳- میشود و برعکس. سینتکس این عملگر در جاوا اسکریپت به صورت زیر است:
مثالی از عملگر Unary (-):
Unary (+): این عملگر در جاوا اسکریپت برای تبدیل یک مقدار غیر عددی به مقدار عددی به کار گرفته میشود. این عملگر سریع ترین و بهترین روش برای تبدیل مقادیر غیر عددی به عدد است، زیرا هیچ عملیات اضافی را روی عدد انجام نمیدهد. سینتکس آن به صورت زیر است:
مثالی از عملگر Unary (+):
عملگر انتسابی در جاوا اسکریپت
نوعی دیگر از انواع عملگرها در جاوا اسکریپت، «عملگر انتسابی» (Assignment operators) است. علامت عملگر انتسابی (=) است و مقدار عملوند سمت راست را به عملوند سمت چپ خود اختصاص میدهد. یعنی اگر a = b باشد، مقدار b را به a اختصاص دهد.
عملگر انتسابی ساده برای تخصیص مقداری به یک متغیر استفاده میشود. عملیات انتساب به مقدار اختصاص داده شده ارزیابی میشود. اعمال کردن عملگر انتساب بهمنظور اختصاص یک مقدار واحد به چندین متغیر یا مکان، امکانپذیر است و سینتکس آن در جاوا اسکریپت به صورت زیر خواهد بود:
مثالی ساده از عملگر انتسابی در جاوا اسکریپت:
تعداد زیادی از عملگرهای انتسابی دیگر در جاوا اسکریپت وجود دارند که معرفی و شرح هرکدام در جدول و توضیحات زیر آمده است:
نام عملگر | نشانی اختصاری | نشانی اصلی و مفهوم عملگر |
عملگر انتسابی جمع | a+=b | a=a+b |
عملگر انتسابی تفریق | a-=b | a=a-b |
عملگر انتسابی ضرب | a*=b | a=a*b |
عملگر انتسابی تقسیم | a/=b | a=a/b |
عملگر انتسابی باقی مانده | a%=b | a=a%b |
عملگر انتسابی توان | a**=b | a=a**b |
عملگر انتسابی شیفت به چپ | a<<=b | a=a<<b |
عملگر انتسابی شیفت به راست | a>>=b | a=a>>b |
عملگر انتسابی AND | a&=b | a=a&b |
عملگر انتسابی OR | a|=b | a=a | b |
عملگر انتسابی XOR | a^=b | a=a^b |
۱٫ عملگر انتسابی جمع
این عملگر مقدار عملوند سمت راست را به متغیر اضافه میکند و نتیجه را به متغیر اختصاص میدهد. نوع دو عملوند رفتار عملگر انتسابی جمع را تعیین میکند. اضافه کردن یا الحاق کردن با این عملگر در جاوا اسکریپت، امکان پذیر است. در این عملیات، از رشته هم میتوان به عنوان عملوند استفاده کرد. مثال زیر در رابطه با عملگر انتسابی در جاوا اسکریپت است:
خروجی به صورت زیر خواهد بود:
۵۳ ۵۳
۲٫ عملگر انتسابی تفریق در جاوا اسکریپت
این عملگر مقدار عملوند سمت راست را از یک متغیر کم کرده و نتیجه را به همان متغیر اختصاص میدهد. مثال زیر این مفهوم را بیان میکند.
خروجی به صورت زیر خواهد بود:
۴۵ ۴۵
۳٫ عملگر انتسابی ضرب در جاوا اسکریپت
این عملگر یک متغیر را در مقدار عملوند سمت راست ضرب میکند و نتیجه را به متغیر اختصاص میدهد. مثال زیر مربوط به این عملگر است:
خروجی به صورت زیر خواهد بود:
۱۰۰ ۱۰۰
۴٫ عملگر انتسابی تقسیم در جاوا اسکریپت
این عملگر در جاوا اسکریپت، یک متغیر را بر مقدار عملوند سمت راست تقسیم میکند و نتیجه را به متغیر اختصاص میدهد. مثال زیر مربوط به این عملگر است:
خروجی:
۲۵ ۲۵
۵٫ عملگر انتسابی باقیمانده
این عملگر یک متغیر را بر مقدار عملوند سمت راست تقسیم میکند و باقیمانده را به عنوان خروجی بازمیگرداند. مثال زیر مربوط به این عملگر است:
خروجی:
۰
۶٫ عملگر انتسابی توان در جاوا اسکریپت
این عملگر مقدار یک متغیر را به توان عملوند سمت میرساند. مثال زیر مربوط به این عملگر است:
خروجی:
۴
۷٫ عملگر انتسابی شیفت به چپ در جاوا اسکریپت
این عملگر بیتهای دودویی مقدار متغیر مربوطه را به تعداد تعیین شده به سمت چپ منتقل میکند و نتیجه را به متغیر اختصاص میدهد. مثال:
خروجی:
۲۰
۸٫ عملگر انتسابی شیفت به راست در جاوا اسکریپت
این عملگر در جاوا اسکریپت، بیتهای دودویی مقدار متغیر را به تعداد واحد تعیین شده به سمت راست منتقل میکند و نتیجه را به همان متغیر اختصاص میدهد. مثال:
۱
۹٫ عملگر انتسابی AND در جاوا اکسریپت
این عملگر در جاوا اسکریپت از نمایش باینری هر دو عملوند استفاده میکند، یک عملیات AND بیتی روی آنها انجام میدهد و نتیجه را به متغیر اختصاص میدهد. مثال:
خروجی:
۰
۱۰٫ عملگر انتسابی OR در جاوا اسکریپت
این عملگر از نمایش باینری هر دو عملوند استفاده میکند، عملیات OR را به صورت بیتی روی آنها انجام میدهد و نتیجه را به متغیر اختصاص میدهد. مثال:
خروجی:
۷
۱۱٫ عملگر انتسابی Xor در جاوا اسکریپت
این عملگر نیز از نمایش دودویی هر دو عملوند استفاده میکند، یک عملیات XOR بیتی روی آنها انجام میدهد و نتیجه را به متغیر اختصاص میدهد. مثال:
خروجی:
۷
عملگرهای مقایسه ای در جاوا اسکریپت
این بخش از مقاله، مربوط به «عملگرهای مقایسهای» (Comparison Operators) و پیادهسازی آنها در جاوا اسکریپت است. عملگرهای مقایسهای در میان انواع عملگرها در جاوا اسکریپت، عمدتاً برای انجام عملیات منطقی که برابری یا عدم برابری بین مقادیر را تعیین میکنند، استفاده میشوند.
این عملگرها برای انجام محاسبات ریاضی و منطقی خاص روی عملوندها استفاده میشوند. جاوا اسکریپت مانند C ،C++ ،Java ،Python و زبانهای مختلف دیگر از عملیات مقایسه پشتیبانی میکند. عملگرهای مقایسه در عبارات منطقی برای تعیین برابری یا تفاوت آنها در متغیرها یا مقادیر استفاده میشود. در زیر مثالی از عملگرهای مقایسهای آورده شده است.
خروجی به صورت زیر خواهد بود:
true true
عملگرهای مقایسهای مختلفی وجود دارند که در جاوا اسکریپت پشتیبانی میشوند که در دو دسته زیر قرار میگیرند:
- عملگرهای برابری
- عملگرهای رابطهای
هر دو عملگر در بخش بعد از طریق مثالها مورد بحث واقع خواهند شد.
عملگرهای برابری در جاوا اسکریپت
در این بخش به شرح هر یک از انواع عملگرهای برابری در جاوا اسکریپت پرداخته شده است.
۱٫ عملگر برابری در جاوا اسکریپت
این عملگر در جاوا اسکریپت، برای مقایسه برابری دو عملوند استفاده میشود. اگر برابر باشد، شرط درست است در غیر این صورت نادرست است. سینتکس آن به صورت زیر است:
مثال ۱: مثال زیر عملگر برابری را در جاوا اسکریپت نشان میدهد.
خروجی به صورت زیر خواهد بود:
> true > true > true > true > false
۲٫ عملگر نابرابری در جاوا اسکریپت
عملگر نابرابری در جاوا اسکریپت برای مقایسه نابرابری دو عملوند استفاده میشود. اگر برابر باشد، شرط نادرست و در غیر این صورت درست است. سینتکس و مثال آن به صورت زیر خواهد بود:
مثال:
خروجی:
> true > false > false > false > true
۳٫ عملگر برابری دقیق در جاوا اسکریپت
این عملگر در جاوا اسکریپت، برای مقایسه برابری دو عملوند هم از لحاظ مقدار و هم از لحاظ نوع استفاده میشود. . اگر مقدار و نوع هر دو عملوند برابر باشند، شرط درست و در غیر این صورت نادرست است. سینتکس عملگر برابری دقیق در جاوا اسکریپت به صورت زیر خواهد بود:
مثال:
خروجی:
> false > true > true > false > false
۴٫ عملگر نابرابری شدید در جاوا اسکریپت
این عملگر برای مقایسه نابرابری دو عملوند با نوع استفاده میشود. اگر مقدار و نوع نابرابر باشند، شرط درست و در غیر این صورت نادرست است. سینتکس آن به صورت زیر خواهد بود:
// Illustration of (!==) operator
let val1 = ۵;
let val2 = '۵';
// Checking of operands
console.log(val1 !== ۶);
console.log(val2 !== '۵');
console.log(val1 !== val1);
// Check against null and boolean value
console.log(۰ !== false);
console.log(۰ !== null);
خروجی آن به صورت زیر است:
> true > false > false > true > true
تابع های جاوا اسکریپت — راهنمای جامع
عملگرهای مقایسهای رابطهای در جاوا اسکریپت
نوعی دیگر از عملگرها در جاوا اسکریپت، عملگرهای رابطهای هستند که در ادامه هرکدام همراه با سینتکس و مثال شرح داده شده است.
۱٫ عملگر مقایسه بزرگتری (<)
این عملگر برای بررسی اینکه آیا مقدار سمت چپ بزرگتر از مقدار سمت راست است یا خیر استفاده میشود. اگر مقدار بیشتر باشد، شرط درست و در غیر این صورت نادرست است. سینتکس آن به صورت زیر خواهد بود:
مثال:
خروجی آن به صورت زیر است:
> true > true > false > true
۲٫ عملگر بزرگتر مساوی در جاو اسکریپت (=<)
این عملگر برای بررسی اینکه آیا عملوند سمت چپ بزرگتر یا مساوی با عملوند سمت راست است یا خیر استفاده میشود. اگر مقدار بزرگتر یا مساوی باشد، شرط درست و در غیر این صورت نادرست است. سینتکس عملگر بزرگتر مساوی در جاوا اسکریپت به صورت زیر خواهد بود:
مثال:
خروجی:
> true > true > true > false
۳٫ عملگر کوچکتر یا کمتر (>) در جاوا اسکریپت:
این عملگر در جاوا اسکریپت، برای بررسی اینکه آیا مقدار سمت چپ کمتر از مقدار سمت راست است یا خیر استفاده میشود. اگر اینطور باشد، شرط درست و در غیر این صورت نادرست است. سینتکس این عملگر به صورت زیر خواهد بود:
مثال:
خروجی:
> true > false > false > true
۴٫ عملگر کمتر یا مساوی (=>) در جاوا اسکریپت:
این عملگر برای بررسی اینکه آیا مقدار عملوند سمت چپ کمتر یا مساوی با مقدار عملوند سمت راست است یا خیر استفاده میشود. اگر اینطور باشد، شرط درست و در غیر این صورت نادرست است. سینتکس این عملگر به صورت زیر خواهد بود:
مثال:
خروجی:
> true > false > false > true
عملگرهای بیتی جاوا اسکریپت
جاوا اسکریپت مانند زبان C ،C++، جاوا، پایتون و زبانهای مختلف دیگر از عملیات بیتی پشتیبانی میکند. در جاوا اسکریپت، یک عدد به عنوان یک عدد ممیز شناور ۶۴ بیتی ذخیره میشود، اما عملیات بیتی بر روی اعدد باینری ۳۲ بیتی قابل انجام است، یعنی برای انجام عملیات بیتی، جاوا اسکریپت عدد را به عددی ۳۲ بیتی تبدیل میکند و عملیات را انجام میدهد و نتیجه را به عنوان عددی ۶۴ بیتی بازمیگرداند. در زیر انواع عملگرهای جاوا اسکریپت از نوع بیتی توضیح و برای هر یک مثالی آورده شده است.
۱٫ عملگر بیتی AND ( & ) در جاوا اسکریپت
این عملگر باینری در جاوا اسکریپت دو عملوند را میپذیرد. در عملگر AND اگر هر دو بیت درست باشند (یعنی ۱)، نتیجه همیشه درست (۱) و در هر حالت دیگری این عملگر ۰ را برمیگرداند. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | B | خروجی |
۰ | ۰ | ۰ |
۰ | ۱ | ۰ |
۱ | ۰ | ۰ |
۱ | ۱ | ۱ |
۲٫ عملگر بیتی OR (|) در جاوا اسکریپت
این عملگر باینری نیز دو عملوند را میپذیرد. اگر هر یک از عملوندها غلط باشند (یعنی ۰) نتیجه ۰ است و در هر حالت دیگری ۱ را برمیگرداند. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | B | خروجی |
۰ | ۰ | ۰ |
۱ | ۰ | ۱ |
۰ | ۱ | ۱ |
۱ | ۱ | ۱ |
۳٫ عملگر بیتی XOR (^) در جاوا اسکریپت
این هم عملگری باینری است یعنی دو عملوند را میپذیرد. اگر هر دو عملوند متفاوت باشند، نتیجه ۱ و در هر حالت دیگری ۰ را برمیگرداند. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | B | خروجی |
۰ | ۰ | ۰ |
۰ | ۱ | ۱ |
۱ | ۰ | ۱ |
۱ | ۱ | ۰ |
۴٫ عملگر بیتی NOT (~) در جاوا اسکریپت
NOT عملگری یکنواخت به حساب میآید، یعنی عملوندهای منفرد را میپذیرد. با این عملگر، ۰ تبدیل به ۱ و ۱ تبدیل به ۰ میشود. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | A~ |
۱ | ۰ |
۰ | ۱ |
۵٫ عملگر باینری شیف به چپ (>>)
این عملگر نیز باینری است و دو عملوند را میپذیرد. عمولند اول مقدار عدد اول در نمایش بیتی و عملوند دوم تعداد بیتهایی را مشخص میکند که باید تغییر کنند. هر بیت به سمت چپ منتقل میشود و ۰ بیت از سمت راست اضافه میشود. همچنین بیتهای اضافی از سمت چپ دور ریخته خواهند شد. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | ۶ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱۰ ) |
B | ۱ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱ ) |
خروجی A << B | ۱۲ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱۰۰ ) |
۶٫ عملگر باینری شیفت به راست (<<)
این عملگر نیز باینری است. عملوند اول مقدار عدد اول در نمایش بیتی و عملوند دوم تعداد بیتهایی را مشخص میکند که باید تغییر کنند. با این عملگر هر بیت به سمت راست منتقل میشود و بیتهای سرریز دور انداخته خواهند شد. جدول زیر حالتهای مختلف این عملگر را نشان میدهد.
A | ۶ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱۰ ) |
B | ۱ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱ ) |
خروجی A >> B | ۳ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱ ) |
۷٫ عملگر Right Shift ( <<< )
در این عملگر باینری، عملوند اول نمایش بیتی عدد و عملوند دوم تعداد بیتهایی را که باید تغییر کنند را مشخص میکنند. هر بیت به سمت راست منتقل میشود و بیتهای سرریز دور انداخته خواهند شد. ۰ بیت از سمت چپ اضافه میشود تا صفرها در سمت راست پر شود. جدول زیر حالتهای مختلف این عملگر را نشان میدهد:
A | ۶ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱۰ ) |
B | ۱ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱ ) |
خروجی A >>> B | ۳ ( ۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۰۱۱ ) |
مثال برای عملگرها در جاوا اسکریپت از نوع باینری:
خروجی:
A & B = 0 A | B = 7 ~A = -7 A >> B = 3 A >>> B = 3 A
حلقه for در جاوا اسکریپت — از صفر تا صد + مثال و کد
عملگر حذف در جاوا اسکریپت چیست؟
عملگر حذف بهطور خاص برای حذف ویژگیهای شی جاوا اسکریپت استفاده میشود و این عملگر نسبتاً عملگری کمتر شناخته شده در جاوا اسکریپت است. این بخش از آموزش از مطلب عملگرها در جاوا اسکریپت مربوط به تشریح این عملگر خواهد بود.
اگرچه متدهای Pop ،Shift و Slice در جاوا اسکریپت برای حذف یک عنصر از آرایه در دسترس هستند، اما به دلیل وجود جفت کلید-مقدار در یک شی، عمل حذف پیچیدهتر میشود و بهترین راهکار استفاده از عملگر حذف است. باید به این نکته توجه داشت که عملگر حذف فقط روی اشیا عملیات انجام میدهد. این عملگر روی متغیرها یا توابع کار نمیکند. سینتکس عملگر حذف در جاوا اسکریپت به صورت زیر است:
عملگر حذف اگر یک «خاصیت» (Property) را حذف کند، مقدار True را برمیگرداند، اما روی شی تأثیری نخواهد داشت. همچنین این عملگر در جاوا اسکریپت هنگام تلاش برای حذف یک متغیر یا تابع، مقدار False را بازمیگرداند.
مثال: این مثال با فرض اینکه یک شی به نام Person دارای سه جفت کلید-مقدار (یعنی FirstName ،LastName و Phone) است، ارائه خواهد شد. اکنون با استفاده از عملگر delete برای حذف ویژگی Phone از میان این سه ویژگی، تلاش خواهد شد تا مشاهده شود این عملگر چه چیزی را به عنوان خروجی بازمیگرداند.
خروجی:
true (۲) {firstName: "kamel", lastName: "bahr...} firstName : "kamel" lastName : "bahrami"
همانطور که خروجی بالا نشان میدهد، delete person.phone مقدار True بازمیگرداند. حال در بخش زیر از عملگر حذف در جاوا اسکریپت برای حذف یک متغیر و یک تابع استفاده شده است. مثال:
خروجی:
false false
از آنجایی که عملگر حذف، برای متغیرها یا تابع کار نمیکند، False را برمیگرداند و متغیرها و توابع واقعی دست نخورده باقی میمانند. نکته دیگری که باید در نظر داشت این است که این عملگر ارزش ویژگی را حذف نمیکند بلکه خود ویژگی را حذف میکند.
استثنا: متغیرهای سراسری را می توان با استفاده از عملگر حذف در جاوا اسکریپت حذف کرد. مثال:
بدون استفاده از var ، کلمه کلیدی let یا const متغیر را بهعنوان یک متغیر سراسری تنظیم میکند و بهعنوان یک ویژگی شی کار میکند. خروجی به صورت زیر است:
true Uncaught ReferenceError: toDelete is not defined
در این مثال، delete toDelete مقدار True را برمیگرداند و تلاش برای دسترسی به متغیر پس از حذف، با خطا مواجه میشود زیرا متغیر دیگر تعریف نشده است.
حذف مقادیر آرایه با استفاده از delete در جاوا اسکریپت
آرایههای جاوا اسکریپت همه اشیاء هستند. بنابراین، میتوان از عملگر حذف برای حذف آنها استفاده کرد. با این وجود، این کار مشکل ایجاد میکند، زیرا پس از حذف عنصر از آرایه، این عملگر موقعیت یا مکان عنصر حذف شده را خالی نشان میدهد و طول آرایه را بهروز نمیکند.
خروجی:
true (۳) [۲, ۳]
در خروجی بالا، طول آرایه که هم اکنون ۲ است به روز نشده است و همان ۳ را نشان میدهد. این نوعی مشکل بهحساب میآید؛ بنابراین، استفاده از متدهای Pop ، Shift و Splice بهوضوح روش بهتری برای حذف عناصر آرایه هستند. استفاده از ویژگی delete در حلقهها سرعت برنامه را به میزان قابلتوجهی کاهش میدهد. بنابراین، این روش تنها زمانی باید استفاده شود که حذف ویژگی شی کاملاً ضروری باشد.
عملگر کاما در جاوا اسکریپت
عملگر کاما (,) در جاوا اسکریپت، به همان روشی مورد استفاده قرار میگیرد که در بسیاری از زبانهای برنامه نویسی مانند C ،C++ و غیره استفاده میشود. این عملگر عمدتاً عملوندهای خود را از چپ به راست به ترتیب ارزیابی میکند و مقدار عملوند سمت راست را برمیگرداند. عملگر کاما بهعنوان جداکننده برای عبارات متعدد در محلی استفاده میشود که به یک عبارت واحد نیاز دارد. هنگامی که عملگر کاما در یک عبارت قرار میگیرد، هر عبارت را اجرا میکند و سمت راستترین عبارت را برمیگرداند.
سینتکس:
در دستور بالا، چند عبارت با استفاده از یک عملگر کاما از هم جدا میشوند. در حین اجرا، هر عبارت از چپ به راست اجرا میشود و سمت راستترین عبارت بازگردانده میشود. مثال زیر این موضوع را نشان میدهد.
خروجی به صورت زیر است:
Welcome to Faradars Faradars
در خروجی ابتدا تابع x() سپس y() و در آخر z() اجرا میشوند. درنهایت، عملگر کاما سمت راستترین عبارت را برمیگرداند. مفیدترین کاربرد عملگر کاما در حلقهها است. در حلقهها، برای بهروزرسانی چندین متغیر در عبارتی از این عملگر استفاده میشود. مثال:
خروجی به صورت زیر است:
۰ ۵ ۱ ۴ ۲ ۳ ۳ ۲ ۴ ۱ ۵ ۰
عملگرهای اتصال کوتاه جاوا اسکریپت
یکی دیگر از انواع عملگرها در جاوا اسکریپت، عملگرهای اتصال کوتاه هستند. در عملگرهای اتصال کوتاه جاوا اسکریپت، عبارتی از سمت چپ به راست ارزیابی میشود و تا زمانی که تأیید شود که نتیجه شرایط باقیمانده روی نتیجه ارزیابی شده از قبل تأثیری نخواهد داشت، مقدار True بازگردانده خواهد شد. اگر حتی قبل از ارزیابی کامل عبارت، نتیجه واضح باشد، اتصال کوتاه اتفاق میافتد و نتیجه بازگردانده میشود. ارزیابی اتصال کوتاه از کار غیرضروری جلوگیری میکند و منجر به پردازش کارآمد و سریع خواهد شد.
۱٫ عملگر اتصال کوتاه AND در جاوا اسکریپت
در مورد عملگر اتصال کوتاه AND، عبارت تا زمانی ارزیابی میشود که یک نتیجه نادرست به دست آید. اگر عبارتی با AND وجود داشته باشد و خود عملوند اول نادرست باشد، اتصال کوتاه رخ میدهد و در این صورت عبارت بعدی ارزیابی نمیشود و False بازگردانده میشود. مثال زیر این موضوع را بیان میکند.
خروجی:
false true
۲٫ عملگر اتصال کوتاه OR در جاوا اسکریپت
در مورد عملگر اتصال کوتاه OR، عبارت تا زمانی ارزیابی میشود که یک نتیجه درست به دست آید. اگر عبارتی با OR منطقی وجود داشته باشد و خود عملوند اول درست باشد، اتصال کوتاه رخ میدهد، در این صورت ارزیابی متوقف میشود و True بازگردانده میشود. مثال زیر این موضوع را بیان میکند.
خروجی به صورت زیر است:
true true
عملگر سه تایی جاوا اسکریپت
علامت سؤال (?) یا عملگر شرطی (&) در بین شرط و عبارت، در جاوا اسکریپت نشانگر عملگر سهتایی هستند که سه عملوند را میتوانند بپذیرند. این سه عملوند شامل موارد زیر هستند:
- شرط
- اگر عبارت درست باشد
- اگر عبارت نادرست باشد
ارزیابی شرط باید به مقدار True یا False یا مقدار بولی منجر شود. این عملگر در صورتی که عبارت قبل از “:” ، True باشد اجرا میشود و مقدار True را در خروجی برمیگرداند. بهطور مشابه، مقدار False بعد از “:” قرار دارد و اگر عبارت دوم درست باشد، False را برمیگرداند. سینتکس این عملگر در جاوا اسکریپت به صورت زیر است:
مثال ۱:
مثال ۲:
Senior Citizen
مثال ۳: چند عملگر شرطی باهم:
خروجی:
Excellent
عملگر نوع جاوا اسکریپت
در زبان برنامه نویسی جاوا اسکریپت، «عملگر نوع» (Typeof)، نوع داده عملوند خود را در قالب رشته بازمیگرداند. عملوند میتواند هر شی، تابع یا متغیری باشد. سینتکس این عملگر در جاوا اسکریپت به دو صورت زیر است:
انواع داده احتمالی که این عملگر در جاوا اسکریپت بازمیگرداند، شامل موارد زیر هستند:
- «تعریف نشده» (Undefined)
- «شی» (Object)
- «دودویی» (بولی | Boolean)
- «عدد» (Number)
- «رشته» (String)
- «نماد» (Symbol)
- و سایر موارد
مثال از عملگر نوع در جاوا اسکریپت:
خروجی:
string number undefined
عملگر Instanceof در جاوا اسکریپت
آخرین مورد از عملگرها در جاوا اسکریپت، عملگر Instanceof است. این عملگر در جاوا اسکریپت برای بررسی نوع شی در زمان اجرا استفاده میشود. اگر شرط آن درست باشد مقدار بولی بازمیگرداند و نشان میدهد که شی نمونهای از یک کلاس خاص است و اگر شرط غلط باشد، خاتمه پیدا میکند. سینتکس آن به صورت زیر است:
مثال:
خروجی:
Faradars true true false false
سخن پایانی
در این مطلب آموزشی از مجله ریسمونک انواع عملگرها در جاوا اسکریپت همراه با سینتکس و مثالهای متعددی مورد بررسی قرار گرفتند. عملگرها بخشی جداناپذیر از هر زبان برنامه نویسی هستند. برای شروع کار با جاوا اسکریپت، یادگیری عملگرها از اصول پایهای هستند که هر متقاضی این زبان باید با آنها آشنا باشد. بیشتر عملگرهایی که در جاوا اسکریپت مورد استفاده قرار میگیرند، در این مطلب آموزش داده شدند. امید است که این مطلب آموزشی مورد رضایت شما واقع شده باشد.