جامع ترین لیست سوالات استخدامی جاوا اسکریپت

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

مقدمه در رابطه با مصاحبه های استخدامی

به صورت کلی میتوان مصاحبه‌های آزمون های استخدامی را به سه دسته تقسیم کرد. دسته اول آزمون یا مصاحبه شفاهی است، بدینصورت که شخص مصاحبه شونده در همان ابتدای کار محک های جدی میخورد که آیا با مفاهیم اصلی زبان جاوا اسکریپت آشنایی دارد یا خیر…

مرحله دوم آزمون عملی است که معمولاً یا پروژه‌ای به شخص مورد نظر داده شده و بایستی در زمان مورد قبول دو طرف آن را پس بدهد و یا در محیط شرکت در طی چند ساعت باید پروژه مورد نظر را به سرانجام برساند.

آزمون سوم معمولاً در شرکت های سطح بالا تست های روانشناسی و روانشناختی از طرف مورد نظر گرفته می شود که ببینند آیا روحیه همکاری و کارگروهی در وی وجود دارد یا خیر.

با توجه به تمام مطالبی که گفته شد در این پست ما قصد داریم شما را آماده ورود به مصاحبه کاری کنیم. تمرکز ما بر روی مصاحبه شفاهی هست یا همان مصاحبه مرحله اول که تقریباً تمامی شرکت آن را دارند.

پس لطفاً با ما همراه باشید تا مهمترین مطالبی که در مصاحبه کاری جاوا اسکریپت از شما پرسیده می شود را بیان کرده و با هم درباره مفاهیم آن بحث کنیم. این مقاله جامع ترین لیست سوالات استخدامی جاوا اسکریپت را حتما برای دوستانتان ارسال کرده و با ارسال نظرات در ویرایش آن یاری کنید.

جامع ترین لیست سوالات استخدامی جاوا اسکریپت
جامع ترین لیست سوالات استخدامی جاوا اسکریپت

مهمترین ویرایش جاوا اسکریپت از چه سالی و کدام نسخه آن بود؟

جاوا اسکریپت در ابتدا به نام لایو اسکریپت نامگذاری شده بود و بعد ها برای شباهت به زبان جاوای معروف، تغییر نام خود را تحت عنوان جاوا اسکریپت داد. اما بعد از زیرمجموعه شدن سازمان اکما توانست در سال‌های ۱۹۹۷ تا ۱۹۹۹ بتواند به ورژن های es1,2,3 را منتشر کند.

مهمترین نسخه جاوا اسکریپت از سال ۲۰۰۹ و با انتشار نسخه اکما اسکریپت ۵ اتفاق افتاد و دومین انقلاب در جاوا اسکریپت سال ۲۰۱۵ تحت نسخه ی اکما اسکریپ ۶ به وقوع پیوست.

از آن سال به بعد به صورت مرتب سالانه آپدیت هایی برای این زبان بیرون می آید و رهبر اصلی جاوااسکریپت ام دی ام یا موزیلا می باشد.

آیا جاوا اسکریپت یک زبان برنامه نویسی است؟

پاسخ منفی است. جاوا اسکریپت همراه html و css تحت زبان‌های اینترپرایز یا تفسیر شده هستند و در کل نیازی به کامپایلر و برنامه خاصی برای اجرا شدن ندارند.

فقط و فقط کد ها را در یک ویرایشگر کد قرار می دهیم و با یک مرورگر وب آن را باز می کنیم.جاوا اسکریپت زبان برنامه نویسی نیست، اما به لطف آپدیت های سال ۲۰۱۵ به بعد بسیار شبیه زبان برنامه نویسی شده و تمام قابلیت های یک زبان برنامه نویسی را به جز پایگاه داده در خود دارد.

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

مدل DOM در جاوا اسکریپت به چه معناست و چه تفاوتی با مدل BOM دارد؟

مخفف سر کلمات document object modle و به معنای دسترسی هوشمند و هدفمند به عناصر html است. با دانستن انواع مدل های دام مانند المنت با آیدی یا کوری سلکتور و غیره می توانیم به عنصر مورد نظر در سند html دسترسی پیدا کرده و یا داخل آن محتوا بریزیم و یا محتوای داخل آن را استخراج نماییم.

دام در اصل یک آبجکت از تمام المنت های موجود در صفحه میباشد که میتواند دسترسی به تک تک آنها را برای ما ایجاد کند.

اما مدل بام سر کلمه بروزر آبجکت مدل و دسترسی هایی در رابطه با تعامل ما با مرورگر به ما اعطا خواهد کرد.

عملیات ریاضی بر روی استرینگ ها و نامبر ها چه تفاوتی دارد؟

در حالت کلی زبان جاوا اسکریپت مشابه زبان php عملیات ریاضی را بر روی استرینگ و نامبر انجام می‌دهد و فرقی برای آن ندارد. به طور مثال نامبر ۲ به علاوه سه می‌شود ۵ و یا نامبر ۴ تقسیم بر ۲ می شود ۲

استرینگ ۴ تقسیم بر استرینگ ۲ میشود ۲ پس تفاوتی تا به اینجای کار بین نامبر و استرینگ وجود ندارد. تنها تفاوت در عملیات جمع می باشد. به دلیل اینکه پلاس یا علامت جمع در جاوا اسکریپت به معنای کانکت و چسباندن میباشد و وقتی شما دوتا استرینگ را با هم جمع می کنید در جاوا اسکریپت به معنای کانکت حساب می شود و آن دو را در کنار هم قرار داده و در خروجی چاپ می کند.

در غیر اینصورت عملیات تفریق تقسیم و ضرب بین نامبر و استرینگ کاملاً یکسان است.

تفاوت بین LET , CONST و VAR در چیست و بهتر است از کدام استفاده شود؟

در ورژن های قدیمی جاوا اسکریپت برای تعریف یک متغیر از کلمه کلیدی وریبل استفاده می شد. اما با آمدن نسخه های جدید به جای var دو کلمه کلیدی let و const تعریف شد.

خوب تا به همین جای کار میتوان گفت که بهتر است از تعاریف داخل ورژن های جدید استفاده کنیم، اما از طرف دیگر می توان گفت برای هر جایگاهی نه!

llet و const هم با هم شباهت دارند هم تضاد. شباهت در اینجاست که هر دو block scope هستند. پس متغیر داخل بلاک با متغیر بیرون بلاک حتی اگر هم نام باشند، مقادیر مختلفی دارند.

اما تضاد این دو در نامشان هم پیداست. let به معنای اجازه دادن است و میتوانید متغیری از نوع let را در طول برنامه به مقادیر مختلف دیگری تغییر دهید. اما const به معنای ثابت است یا همان کانستنت و شما در طول برنامه اجازه تغییر متغیر کانست را نخواهید داشت.

از کانست معمولاً کجاها استفاده میشود؟

بهتر است از متغیر کانست برای ذخیره آرایه و آبجکت استفاده شود. بدین دلیل این که وقتی ما یک آبجکت یا یک آرایه یا حتی یک فانکشن را داخل یک کانستنت قرار می‌دهیم، در اصل آدرس حافظه یا refrence آنرا داخل متغیر ریخته ایم و اگر مقادیر و پراپرتی های آن متغیر را کم، زیاد یا تغییر دهیم، هیچ اتفاقی برای کانستنت نمی افتد.

چون آدرس آن متغیر در حافظه یکسان است و تغییری نمی کند!

تفاوت and و or در چیست؟

موضوع بسیار ساده است .در OR وقتی دو یا N شرط را با هم در کنار هم قرار می دهیم، فقط کافیست یکی از شروط درست باشد. در این صورت کل شرط ما درست خواهد بود و AND دقیقاً معکوس این قضیه است. یعنی اگر دو یا N شرط در کنار هم داشته باشیم، بایستی تمامی شروط درست باشند تا شرط کلی به مقدار TRUE یا صحیح برسد.

پیشنهاد میکنیم از مقاله مفهوم کامل و کاربردی RESTFUL API هم دیدن به عمل آورید.

در مصاحبه های کاری بسیار کاربردی است…

مفهوم آرگومان ورودی و RETURN در FUNCTION را بفرمایید؟

این دو المان در تمامی توابع وجود دارد. آرگومان ورودی که دقیقاً بعد از نام تابع و داخل پرانتز قرار دارد، جایگاه ورود مقدار به داخل تابع می باشد. پس اگر بخواهیم مقداری را از خارج تابع به داخل تابع پاس بدهیم، می توانیم از آرمان های ورودی استفاده نماییم.

یک تابع آزاد است که از آرگومان ورودی استفاده کند یا خیر.

return به معنای مقدار بازگشتی تابع است. شاید بتوان آن را خروجی تابع هم نامید. به طور مثال وقتی یک تابع با آرگومان های ورودی a و b در دل خود ریترن دارد، به این نتیجه می رسیم که این تابع در هنگام فراخوانی بایستی دو مقدار مجهول خود را گرفته و آنها را در هم مثلا ضرب کرده و در خروجی خود نگه دارد.

اما چون در دل خود دستوری برای نگارش مانند ALERT یا PRINT وجود ندارد، بایستی این تابع در دل یک تابع نگارشی فراخوانی شود.

تفاوت فانکشن با arrow function در چیست؟

ما در حالت کلی به دو صورت می توانیم توابع را در زبان جاوا اسکریپت تعریف کنیم. تعریف توابع در اکما اسکریپت ۵ که همراه با کلمه‌ی کلیدی فانکشن می باشند و تعریف توابع در اکما اسکریپت ۶ که نوع مختصر شده و کوتاه شده سینتکس اکما اسکریپت ۵ است.

به شکل زیر نگارش می‌شود و در کل تفاوت خاصی در نوع رفتار این دو وجود ندارد. فقط بدانید که ما در es5 به this دسترسی داریم و در es6 به this دسترسی نداریم.

const myFunct = (a, b) => a*b

Asynchronous Communication چیست؟

ارتباط ناهمزمان یا آسینکرون کامیونیکیشن به چه معناست و کدام خاصیت در جاوا اسکریپت بیشترین استفاده را در این مقوله دارد؟

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

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

حلقه ها در زبان های برنامه نویسی چه کاربردی دارند؟

تمام زبان های برنامه نویسی دارای حلقه های تکرار متنوع هستند و هدف آن انجام یک دستور یکسان به تعداد دلخواه ما می باشد. برای جلوگیری از نوشتن کدهای زیاد از حلقه های تکرار استفاده میکنیم معروف ترین FOR می باشد.

Dev Tool Debugging تولز دیباگینگ چیست؟

همه مرورگرها از بخش تولز دیباگینگ برای کمک به توسعه دهنده های وب در امر اشکال زدایی و پیدا کردن خطا استفاده می کنند. برای دسترسی به این قسمت کافیست در صفحه وب کلیک راست کرده و روی گزینه اینسپکت کلیک کنیم.

قسمت جدیدی که در مرورگر باز می‌شود همان دفتر دیباگینگ ما می باشد که در آن دسترسی به کدهای html css و جاوا اسکریپت داریم.

اسکوپ یا حوزه دسترسی به چه معناست؟

از مفاهیم بنیادی و پایه هر زبان برنامه نویسی حوزه دسترسی یا اسکوپ میباشد. اگر شما فانکشن ای تعریف کرده باشید یا یک آبجکت یا یک کلس خواهید دید که با آکولاد باز و بسته حوزه دسترسی را برای آن دستور خود ایجاد کرده اید.

یعنی هر آنچه که به طور مثال متغیر در درون این اسکوپ تعریف شود در خارج از آن معنا و مفهومی ندارد. پس می توان حوزه دسترسی متغیر ها را به دو عنوان کلی گلوبال و لوکال تعریف کرد.

ما می دانیم که اسکوپ می تواند هم برای یک فانکشن باشد هم برای خود متغیرهای let و const اگر متغیر بیرون اسکوپ تعریف شود دسترسی سوپر گلوبال دارد و اگر متغیر داخل اسکوپ تعریف شود دسترسی لوکال یا محلی خواهد داشت.

Function Calls فانکشن کال یاد فراخوانی توابع به چه معناست؟

همانطور که می دانید توابع اسکوپ هایی از کد می باشند که در داخل آن دستوراتی نوشته شده ولی اجرا نمی شوند. فقط در زمانی که توابع به صورت مستقیم یا غیرمستقیم فراخوانی شوند کدهای نوشته شده در آن بلاک اسکوپ رهاسازی شده و اجرا خواهند شد.

از فراخوانی یک فانکشن یا تابع به معنای اجرای کد های درون آن تابع است حال فراخوانی می تواند به صورت مستقیم یا با صدا زدن اسم تابع باشد و یا به صورت غیرمستقیم بر حسب فراخوانی یک event مانند کلیک رخ دهد.

Conditional statements یا عبارات شرطی به چه مفهوم است؟

اساس و بنیان هر تصمیمی که در عبارات شرطی رخ می‌دهد مانند IF یا SWITCH که مهم ترین عبارات شرطی هستند ، بر اساس همین کاندیشنال استیتمنت ها انجام می شود. عبارات شرطی در صورت کلی دو حالت دارند یا TRUE می باشند و جوابشان مثبت است در غیر این صورت می‌توانند FALSE باشند و جواب منفی.

ترو و فالس در حالت کلی به چه معناست؟

باید بدانیم که فالس و ترو از عبارات بولین و صفر و یکی میباشند و به معنای صحیح و غلط است. ترو یعنی یک بولین و فالس یعنی صفر بولین.

به صورت دیفالت هر عبارتی می تواند معنای تورو دهد. استرینگ آرسام ، عدد ۶۲ ، عدد منفی ۲۰۰ یا هر چیز دیگری می تواند معنای ترو دهد. یعنی یک موجودیت است!

اما اگر فالس بولین نوشته شود به معنای صفر و غلط خواهد بود. عبارات شرطی هم که جای خود دارد. مثلاً دو بزرگتر از ۴ مشخص است که غلط است یا آرسام برابر است با پارسا غلط است.

Events and Event Handling ایونت و ایونت هندلینگ به چه معنا است؟

ما در اینجا یک مفهوم کلی به نام event داریم که این را همان رویداد می نامیم. مانند کلیک، موس اینتر، موس لیو، اسکرول و غیره اما این به معنای مدیریت رویداد نیست.

پس یک مفهوم رویداد داریم و یک مفهوم مدیریت رویداد که در کد نویسی باید به صورت استاندارد آن را رعایت کرد.

Traversing the DOM یا پیمایش دام به چه مفهوم است؟

اگر شما تمام مفاهیم زبان برنامه نویسی جاوا اسکریپت را بلد باشید اما نتوانید پیمایش درست و منطقی درخت دام و سند html تان داشته باشید، به هیچ عنوان برنامه نویس موفقی نخواهید بود.

پیمایش در دام به این معنا است که شما در هر نقطه از تگ های html بتوانید دسترسی بگیرید و محتویات را استخراج یا وارد نمایید.

پیمایش دقیق دام به شما سطح کنترل ۱۰۰ درصدی در عناصر html می دهد و جز مولفه های بنیادی و اولیه برنامه نویسی می باشد. DOM مخفف Document Object Model و یک آبجکت از تمام المنت‌های موجود در یک صفحه HTML هست.

IIFE (Immediately Invoked Function Expression) چیست؟

همانطور که از نام آن پیداست، IIFE تابعی در جاوا اسکریپت است که بلافاصله به محض تعریف فراخوانی و اجرا می شود. متغیرهای اعلام شده در IIFE توسط دنیای خارج قابل دسترسی نیستند و به این ترتیب می توانید از آلوده شدن دامنه جهانی جلوگیری کنید. بنابراین دلیل اصلی استفاده از IIFE اجرای فوری کد و به دست آوردن حریم خصوصی داده ها است.

Hoisting یا بالابردن به چه معناست؟

بسیاری از توسعه دهندگان زمانی که مفهوم Hoisting در جاوا اسکریپت واضح نمیدانند، نتایج غیرمنتظره ای دریافت می کنند. در جاوا اسکریپت، می‌توانید یک تابع را قبل از تعریف آن فراخوانی کنید و با خطای «Uncaught ReferenceError» مواجه نخواهید شد.

دلیل این امر بالا بردن جایی است که مفسر جاوا اسکریپ همیشه متغیرها و اعلان تابع را قبل از اجرای کد به بالای محدوده فعلی (حوزه تابع یا دامنه جهانی) منتقل می کند. بیایید این را با مثال درک کنیم.

Hoisting یا بالابردن به چه معناست؟

Closures یا بسته شدن به چه معناست؟

بسته شدن به سادگی تابعی در داخل تابع دیگری است که به متغیر تابع خارجی دسترسی دارد. اکنون، این تعریف تقریباً ساده به نظر می رسد، اما جادوی واقعی با دامنه ایجاد می شود.

تابع داخلی می تواند به متغیر تعریف شده در محدوده تابع والد خود و متغیرهای سراسری دسترسی داشته باشد. اکنون در اینجا باید به خاطر داشته باشید که تابع بیرونی نمی تواند به متغیر تابع داخلی دسترسی داشته باشد.

Closures یا بسته شدن به چه معناست؟

Callbacks را تعریف نمایید.

در جاوا اسکریپت، callback به سادگی تابعی است که به عنوان پارامتر به تابع دیگری ارسال می شود و در داخل تابع دیگر فراخوانی یا اجرا می شود. در اینجا یک تابع باید منتظر باشد تا تابع دیگری اجرا شود یا مقدار آن را برگرداند و این باعث می شود که زنجیره عملکردها (زمانی که X تکمیل شود، Y اجرا شود، و ادامه می یابد.). به همین دلیل است که معمولاً از callback در عملیات ناهمزمان جاوا اسکریپت برای ارائه قابلیت همزمان استفاده می شود.

پیشنهاد میکنیم از مقاله آموزش مدل bem در css هم دیدن به عمل آورید.

در مصاحبه های کاری پرسیده میشود…

مفهوم promise را بیان نمایید.

ما مفهوم callback را درک می کنیم، اما اگر کد شما در داخل کال بک ها ، callback داشته باشد و ادامه یابد، چه اتفاقی می افتد؟

خب، این ساختار بازگشتی بازگشت به callback به عنوان “جهنم callback” نامیده می شود و به حل این نوع مشکل کمک می کند. Promises در عملیات جاوا اسکریپت ناهمزمان زمانی مفید هستند که ما نیاز به اجرای دو یا چند عملیات پشت سر هم (یا بازگشت به callback) داریم، جایی که هر تابع بعدی با تکمیل عملکرد قبلی شروع می شود.

یک Promises  شیئی است که ممکن است در آینده یک مقدار واحد تولید کند، یا یک مقدار حل شده یا دلیلی برای حل نشدن (رد) آن.

قبل از اینکه Promise معرفی شود برای انجام چند وظیفه‌ی غیر هم زمان از callback function استفاده‌ی زیادی می‌شد. 

 به گفته developer.mozilla “یک Promises  یک شی است که نشان دهنده تکمیل یا شکست نهایی یک عملیات ناهمزمان است. اساساً، یک Promises  یک شیء برگشتی است که به جای ارسال callback به یک تابع، callback را به آن متصل می‌کند.» Promises  های مسئله «جهنم callback » را حل می‌کند که چیزی جز ساختار بازگشتی از callback نیست

یک promise  ممکن است در سه حالت ممکن باشد…

Fulfilled: زمانی که عملیات با موفقیت به پایان رسید.

Rejected: زمانی که عملیات شکست خورده باشد.

در حال تعلیق: حالت اولیه، نه انجام شده و نه رد شده است.

“همگام سازی و انتظار، نوشتن Promise ها را آسان تر می کند”…

function myDisplayer(some) {
document.getElementById(“demo”).innerHTML = some;
}
let myPromise = new Promise(function(myResolve, myReject) {
let x = 0;
// some code (try to change x to 5)
if (x == 0) {
myResolve(“OK”);
} else {
myReject(“Error”);
}
});

myPromise.then(
function(value) {myDisplayer(value);},
function(error) {myDisplayer(error);}
);

Async & Await چیست؟

async یک تابع را Promise می کند

await باعث می شود یک تابع منتظر یک Promise باشد.

کلمه کلیدی async قبل از یک تابع باعث می شود تابع یک Promise را برگرداند:

async function myFunction() {
  return “Hello”;
}

یا

function myFunction() {
return Promise.resolve(“Hello”);
}

بنابراین در جاوا اسکریپت عملیات ناهمزمان را می توان در نسخه های مختلف …

ES5 -> Callback

ES6 -> Promise

ES7 -> Async/wait

می‌توانید از Async/wait برای انجام درخواست Rest API در جایی که می‌خواهید داده‌ها قبل از فشار دادن به نمای به طور کامل بارگیری شوند، استفاده کنید.

function myDisplayer(some) {

  document.getElementById(“demo”).innerHTML = some;

}

async function myFunction() {return “Hello”;}

myFunction().then(

  function(value) {myDisplayer(value);},

  function(error) {myDisplayer(error);}

);

یا  در مثال دیگر

const showPosts = async () => {

const response = await fetch(‘https://jsonplaceholder.typicode.com/posts’);

const posts = await response.json();

console.log(posts);

}

showPosts();

class ها در جاوا اسکریپت به چه معنا هستند؟

تا قبل از سال ۲۰۱۵ و معرفی es6، یکی از نقیصه های بزرگ زبان جاوا اسکریپت عدم وجود ساختار کلاس در آن بود که بعد از معرفی این ورژن این مشکل برطرف شد و جاوا اسکریپت نیز با داشتن مفهوم کلاس وجه آبجکتیو خود را کامل کرد.

کلاس ها یک بلاک اسکوپ هستند مشابه یک فانکشن که جدا تعریف می‌شوند ولی تابع نیستند. کلاس ها در دل خود توابعی دارند که می تواند از پیش تعریف شده باشد یا خودمان آنها را به‌صورت متدهای دستی تعریف کنیم.

constructor مهمترین و اصلی ترین تابع که است کلس تابع کانستراکتور یا تابع سازنده است. می‌توان آرگومان های ورودی توسط آن به داخل کلاس ارسال کرد. کلاس ها را به صورت مستقیم نمی توان در خروجی استفاده کرد و حتما باید از آن یک اینستنس آبجکت با استفاده از کلمه کلیدی NEW گرفت.

چند نوع حافظه در زبان جاوا اسکریپت داریم؟

به صورت کلی اگر ما بخواهیم داده هایی را در جاوا اسکریپت فایلی ذخیره کنیم تنها راه حل ما ذخیره در مرورگر است. منظور از جاوا اسکریپت خالی عدم استفاده از کتابخانه هایی مانند نود جی اس است.

کوکی در جاوا اسکریپت localStorage و sessionStorage تنها راه‌حل هایی هستند که ما می توانیم مقداری دیتا را در مرورگر کاربر ذخیره کرده و در ارجاعات بعدی از آن استفاده بکنیم این رویه به دیتا ماینینگ ما کمک شایان توجهی خواهد کرد.

مفهوم null , undefined, NAN را بفرمایید.

نال به معنای خالی و اگر ما به صورت مثال یک متغیر به نام ایکس تعریف کنیم و آن را مقدار دهی نکنیم برابر با نال خواهد بود. پس هر آن مقداری که تعریف ولی مقدار نداشته باشد در واقع می‌توان گفت که خودش یک value یا مقدار است به معنای تهی و خالی.

آن دیفاین به معنای متغیرهایی است که مقدار دهی نشده‌اند یا تابعی که فreturn ندارد یا آرایه ای که به طور مثال ۳ عضو آن مقدار دهی شده اما شما عضو دهم را فراخوانی می کنید. آن دیفاین به معنای تعریف نشده یا زمانی که از یک آبجکت مقدار پراپرتی را فراخوانی می کنید که تعریف نشده آن دیفاین برمیگرداند.

مقدار NAN مخفف سر کلمات not a number می باشد یعنی مقداری که type of آن برابر نامبر بوده است اما در حقیقت یک عدد ریاضی نیست.

عبارات falsy و truthy به چه معناست؟

همانطور که می دانید با قرار دادن دو علامت تعجب پشت متغیر می توانیم آنها را به بولین تبدیل کنیم. حال عباراتی که در تبدیل به بولین مقدار ترو برمی‌گردانند به عبارات تروسی و عباراتی که در عملیات تبدیل به بولین فالس می‌شوند فالسی نامیده می‌شود.

(!!null)
(!!undefined)

Unary plus چیست؟

سریعترین راه و روش برای تبدیل یک استرینگ به نام بر قرار دادن پلاس قبل از آن می‌باشد.

console.log(+ "-29")

Event Propagation چیست؟

کلمه Propagation یعنی گسترش و ترویج. پس Event Propagation یعنی یک رویداد (Event) چه جوری توی یک صفحه HTML گسترش پیدا میکنه.

به دو دسته Capturing و Bubbling تقسیم میشود.

چرا زمانی که یک آبجکت یا آرایه را در آبجکت آرایه دیگر میریزیم با هم برابری نمی کنند؟

دلیل بسیار واضح است. فرض کنیم یک آبجکت داریم با مقادیر مشخص در متغیر ایکس و یک آبجکت دیگر با همان مقادیر ولی در متغیر وای.

اگر در یک عبارت شرطی این دو را با هم برابری بدهیم جواب false خواهد شد به این خاطر که آبجکت و آرایه آدرس حافظه آن در متغیر ذخیره می شود نه مقادیر آن. پس چون دو آدرس متفاوت حافظه داریم این دو با هم برابر نمی شوند. در اینجا باید از spread method استفاده کنیم تا بتوانیم آنها را با هم برابر کنیم.

کد زیر را تفسیر کنید:

<div onclick="getElement(event)">
    <p>
        <button></button>
    </p>
</div>
<script>
function getElement(event) {
    alert(event.target.tagName);
}
</script>

event.target دقیقاً خود المان را بر می گرداند. در ادامه کد مقدار tagname را فراخوانی کرده پس روی هرکدام از المان ها که کلیک کنید تگ مربوطه را برمیگرداند. می‌توانستیم به جای tagname از value استفاده کنیم تا مقدار آن را برگرداند.

اما اگر به جای ایونت دات تارگت از currentTarget استفاده می کردیم فقط خود مقدار div را برمی‌گشت چون رویداد بر روی div پیاده سازی شده است.

تفاوت دو مساوی و سه مساوی در چیست؟

زمانی ما از دو مساوی استفاده می‌کنیم هدفمون برابری از نظر مقدار است و وقتی از سه مساوی استفاده می‌کنیم هدفمون برابری از نظر نوع و مقدار می باشد.

یک تابع نام ببرید که تمام محاسبات ریاضی را به صورت رشته ای و در یک خط انجام میدهد؟

تابع EVAL ، محاسبات را در قالب یک رشته و در یک خط انجام می‌دهد. معمولاً در ساخت ماشین حساب از این متد استفاده می شود.

use strict چیست؟

کلمه strict به معنی سخت‌گیرانه هست. وقتی توی جاوا اسکریپت از این دستور استفاده می‌کنیم برنامه‌ی وارد حالت سخت‌گیرانه میشه. به قول معروف Strict Mode. استفاده از این دستور باعث میشه تا کدهایی امن‌تر و با باگ‌های کمتری بنویسیم.

پروتوتایپ به چه معناست؟

به معنای اینستنتس یا نمونه اولیه میباشد. هر مقداری که توی جاوااسکریپت تعریف می‌کنیم، یک سری از ویژگی‌هاش رو از یک نمونه‌ی اولیه به ارث می‌بره. این ویژگی‌ها شامل متدها و پراپرتی‌های مفید هستن که ما فکر می‌کنیم توی مقداری که ساختیم وجود دارن.

در صورتی که موقع ساخته شدن، از یک والد به ارث برده میشن. مثل پراپرتی length توی رشته‌ها و آرایه‌ها…

اما باید بدونیم که توی جاوااسکریپت هر آبجکتی یک پراپرتی مخفی داره به اسم [[Prototype]]. این پراپرتی به عنوان یک لینک یا واسط برای دسترسی به نمونه‌ی والد در نظر گرفته میشه. برای اینکه پروتوتایپ یا نمونه اولیه یا به زبان ساده‌تر، والد آبجکت person رو ببینیم، از کد زیر استفاده می‌کنیم:

Object.getPrototypeOf(person);

// or

person.__proto__;

کاربرد متد bind در جاوا اسکریپت چیست؟

متد bind برای ساختن تابعی استفاده میشه که مقدار this معین و مشخصی داره. همونطور که می‌دونیم در حالت عادی توابع ما تا زمانی که اجرا نشن نمی‌تونیم مقدار this اونها رو تشخیص بدیم. اما شرایطی هست که ما می‌خوایم صراحتاً مشخص کنیم که this چه مقداری داشته باشه. اینجا چنین متدی به کار ما میاد.

متغیرهایی که بدون کلمه کلیدی VAR تعریف شوند از چه نوع اند؟

این متغیرها از نوع متغیر های سراسری حساب میشوند.

عملگر Spread؟

اسپریت در فانکشن می‌تواند آرگومانهای ما را به صورت یکجا پاس دهد. به این صورت که فرض کنید یک فانکشن با ۳ ورودی دارید و می خواهید یک آرایه باسه مقدار را به عنوان آرگومان به آن پاسخ بدهید به شیوه زیر با سه نقطه آن را اسپرید می کنیم.

function sum(x, y, z) {

  return x + y + z;

}

sum(...numbers);

عملگر Rest به چه معناست؟

این عملگر که توی توابع استفاده میشه، به تابع کمک می‌کنه تا بی‌نهایت آرگومان داشته باشه. در واقع یک روش جدیدتر بجای کلمه کلیدی arguments توی توابع هست. تابع sum مثال بالا رو درنظر بگیرید که فقط سه تا آرگومان قبول می‌کرد. با استفاده از پارامتر rest می‌تونیم یک کاری کنیم که بی‌نهایت آرگومان قبول کنه:

function sum(...numbers) {

    return numbers.reduce((total, current) => total + current);

}

sum(1, 2, 3); // 6

sum(1, 2, 3, 11, 12, 13); // 42

تایپ اسکریپت (TypeScript):

تایپ اسکریپت (به انگلیسی: TypeScript) یک زبان برنامه‌نویسی چندسکویی، متن باز و کامپایلری است که توسط شرکت مایکروسافت توسعه داده شده و پشتیبانی می‌شود. تایپ اسکریپت یکی از زیر مجموعه‌های زبان جاوا اسکریپت است که به شما کمک می‌کند تا کدهای خود را به روش ساده‌تری نوشته و سپس با کامپایل‌ کردن آن‌ها خروجی استاندارد کد جاوا اسکریپت را به دست آورید.

سینتکس TypeScript شباهت زیادی با Javascript و EC6 دارد و تمامی کدهای جاوا اسکریپت موجود، در تایپ اسکریپت معتبر شناخته می‌شوند.

چطوری یک آبجکت رو Clone کنیم؟

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

const a = { x: 1 }

const b = JSON.parse(JSON.stringify(a));

b.x = 2;

alert(b.x); // 2

alert(a.x); // 1

کلیدواژه this در arrow function به چه معناست؟

بر خلاف توابع معمولی، توابع arrow چیزی به نام this برای خودشون ندارن. مقدار this در این توابع خارج از lifecycle اون تابعه و مربوط میشه به نزدیکترین تابع non-arrow.

مفهوم وراثت در برنامه نویسی شی‌ءگرا را توضیح دهید.

زبان‌های برنامه نویسی شی‌ءگرا علاوه بر کلاس دارای زیرکلاس نیز هستند. این زیرکلاس‌ها شامل همه خصوصیاتی هستند که کلاس‌های والدشان دارند؛ اما می‌توانند خصوصیات دیگری را نیز بپذیرند.

در مورد مثال بازی شطرنج، مهره‌های پیاده به متدی نیاز دارند که در صورت موفقیت در رسیدن به انتهای صفحه، آن‌ها را به وزیر تبدیل کند. مثلاً این متد را می‌توان ()transformPiece نامید.

همه مهره‌ها به چنین متدی نیاز ندارند. بنابراین لازم نیست که این متد را در کلاس مهره‌ها قرار دهیم. بلکه می‌توانیم یک زیرکلاس از کلاس مهره‌ها به نام «پیاده» ایجاد کنیم. از آنجا که زیرکلاس‌ها همه خصوصیات کلاس «مهره» را ارث می‌برند، این وهله از زیرکلاس «پیاده» نیز شامل رنگ، ارتفاع، شکل و حرکت‌های مجاز خواهد بود.

اما علاوه بر خصوصیات فوق یک متد ()transformPiece نیز در آن تعریف می‌کنیم. در این حالت لازم نیست که نگران استفاده نادرست از این متد بر روی مهره رخ (قلعه) باشیم.

تفاوت بین ()forEach و ()map

متد map یک فانکشن را به عنوان پارامتر دریافت می‌کند، سپس آن را بر روی هر یک از عناصر اعمال می‌کند و آرایه‌ای کاملاً جدید، با حاصلی که از فراخوانی همان فانکشن بوده را، باز می‌گرداند.

مثل map ،‌متد ()forEach هم یک تابع را به عنوان یک آرگومان دریافت می‌کند،‌و یک‌بار آن را برای هر یک از عناصر آرایه اجرا می‌‌‌کند. با این حال، به جای return یک آرایه جدید همانندundefined ،map برمی‌گرداند.

اولین تفاوت بین ()map و ()forEach، مقداری است که return می‌شود. متد ()undefined ، forEach برمی‌گرداند و ()map یک آرایه‌ی جدید را،‌ با عناصری که گرفته باز می‌گرداند.

تفاوت دوم بین این دو متدهای آرایه، این است که ()map قابلیت chain کردن دارد. به عبارت دیگر، شما می‌توانید بعد از اجرای متد  ()map روی یک آرایه، متدهای دیگر مثل ()reduce(), sort(), filter را نیز به آن متصل کنید.

این چیزی است که با متد ()forEach، نمی‌توان انجام داد. بله ،‌چون همان‌طور که حدس می‌زنید، undefined بر‌می‌گرداند.

تمام…امیدواریم از این مقاله جامع ترین لیست سوالات استخدامی جاوا اسکریپت نهایت استفاده را برده باشید.

پیشنهاد میکنیم آن را به دوستانتان ارسال کرده و اگر سوالی در ذهن دارید که در لیست وجود ندارد، در قسمت کامنت ارسال کنید تا بقیه دوستان استفاده کنند. با تشکر♥

لینک های مفید: MDN w3

4 پاسخ

دیدگاه خود را ثبت کنید

تمایل دارید در گفتگوها شرکت کنید؟
در گفتگو ها شرکت کنید.

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد.