تفاوت Function Expression، Function Declaration و Arrow Function

تفاوت Function Expression، Function Declaration و Arrow Function

انواع function در جاوااسکریپت
برنامه نویسی طراحی وب

تفاوت Function Expression، Function Declaration و Arrow Function

5/5 امتیاز

انواع function در جاوااسکریپت! یکی از روش‌های تعریف توابع در جاوا اسکریپت، Function Declaration است. در این روش، تابع با استفاده از کلمه کلیدی function تعریف می‌شود و می‌تواند قبل از تعریف آن نیز فراخوانی شود، زیرا جاوا اسکریپت در زمان اجرای اسکریپت، این توابع را بالا می‌برد (Hoisting).

دوره‌های آموزشی آکادمی چابک
با تخفیف‌های ویژه آکادمی چابک، یادگیری را شروع کنید!

مشاهده دوره‌ها

روش دیگر، Function Expression است که در آن تابع به‌عنوان یک عبارت تعریف می‌شود و می‌تواند در متغیری ذخیره شود. برخلاف Function Declaration، توابعی که به این شکل تعریف می‌شوند، قبل از تعریف‌شان قابل فراخوانی نیستند. آخرین روش، Arrow Function است که یک روش جدید و مختصر برای تعریف توابع در ES6 می‌باشد.

لیست توابع جاوا اسکریپت (انواع function در جاوااسکریپت)

JavaScript دارای تعداد زیادی توابع داخلی است که برای انجام وظایف مختلف طراحی شده‌اند. در اینجا لیستی از انواع توابع در جاوا اسکریپت را معرفی کرده‌ایم:

توابع مرتبط با دستکاری آرایه‌ها

  1. Array.prototype.push()
  2. Array.prototype.pop()
  3. Array.prototype.shift()
  4. Array.prototype.unshift()
  5. Array.prototype.slice()
  6. Array.prototype.splice()
  7. Array.prototype.concat()
  8. Array.prototype.join()
  9. Array.prototype.indexOf()
  10. Array.prototype.lastIndexOf()

توابع مرتبط با رشته‌ها

  1. String.prototype.charAt()
  2. String.prototype.charCodeAt()
  3. String.prototype.concat()
  4. String.prototype.includes()
  5. String.prototype.endsWith()
  6. String.prototype.startsWith()
  7. String.prototype.indexOf()
  8. String.prototype.lastIndexOf()
  9. String.prototype.match()
  10. String.prototype.replace()

توابع مرتبط با اعداد

  1. Number.isFinite()
  2. Number.isInteger()
  3. Number.isNaN()
  4. Number.isSafeInteger()
  5. Number.parseFloat()
  6. Number.parseInt()
  7. Number.prototype.toExponential()
  8. Number.prototype.toFixed()
  9. Number.prototype.toLocaleString()
  10. Number.prototype.toPrecision()

انواع توابع در جاوا اسکریپت

توابع مرتبط با شیء‌ها

  1. Object.create()
  2. Object.assign()
  3. Object.keys()
  4. Object.values()
  5. Object.entries()
  6. Object.freeze()
  7. Object.seal()
  8. Object.preventExtensions()
  9. Object.isFrozen()
  10. Object.isSealed()

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

فراخوانی توابع جاوا اسکریپت در html

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

1. اضافه کردن اسکریپت جاوا اسکریپت به فایل HTML

می‌توانید کد جاوا اسکریپت خود را مستقیماً در تگ <script> درون فایل HTML قرار دهید.

مثال:

<!DOCTYPE html>

<html lang=”en”>

<head>

<meta charset=”UTF-8″>

<title>JavaScript Function Call</title>

</head>

<body>

<button onclick=”greet()”>Click me</button>

<script>

function greet() {

alert(“Hello, world!”);

}

</script>

</body>

</html>

در این مثال، هنگامی که کاربر روی دکمه کلیک می‌کند، تابع greet فراخوانی می‌شود و یک پیام هشدار نمایش می‌دهد.

2. استفاده از فایل جاوا اسکریپت خارجی

می‌توانید کد جاوا اسکریپت خود را در یک فایل جداگانه (مثلاً script.js) قرار دهید و آن‌را در فایل HTML خود وارد کنید.

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

مثال:

index.html:

<!DOCTYPE html>

<html lang=”en”>

<head>

<meta charset=”UTF-8″>

<title>JavaScript Function Call</title>

</head>

<body>

<button onclick=”greet()”>Click me</button>

<script src=”script.js”></script>

</body>

</html>

script.js:

function greet() {

alert(“Hello, world!”);

}

در این مثال، فایل script.js شامل تعریف تابع greet است و وقتی کاربر روی دکمه کلیک می‌کند، این تابع فراخوانی می‌شود.

3. فراخوانی توابع از رویدادهای مختلف

می‌توانید توابع جاوا اسکریپت را از رویدادهای مختلف HTML مانند onload, onmouseover, onmouseout, onchange و غیره فراخوانی کنید.

مثال:

<!DOCTYPE html>

<html lang=”en”>

<head>

<meta charset=”UTF-8″>

<title>JavaScript Function Call</title>

<script>

function greet() {

alert(“Hello, world!”);

}

function pageLoaded() {

alert(“Page is fully loaded!”);

}

function changeText(element) {

element.innerHTML = “Mouse over!”;

}

function revertText(element) {

element.innerHTML = “Mouse out!”;

}

</script>

</head>

<body onload=”pageLoaded()”>

<button onclick=”greet()”>Click me</button>

<p onmouseover=”changeText(this)” onmouseout=”revertText(this)”>Hover over this text</p>

</body>

</html>

در این مثال، سه تابع مختلف داریم که از رویدادهای مختلف فراخوانی می‌شوند:

  • pageLoaded: هنگام بارگذاری کامل صفحه فراخوانی می‌شود.
  • greet: با کلیک بر روی دکمه فراخوانی می‌شود.
  • changeText و revertText: با حرکت ماوس بر روی متن و خارج شدن از آن فراخوانی می‌شوند.
chabokacademy
دوره‌های آموزشی آکادمی چابک
با تخفیف‌های ویژه آکادمی چابک، یادگیری را شروع کنید!

مشاهده دوره‌ها

 

4. استفاده از جاوا اسکریپت برای اضافه کردن رویدادها به عناصر HTML

می‌توانید رویدادهای جاوا اسکریپت را به‌صورت برنامه‌نویسی به عناصر HTML اضافه کنید.

مثال:

<!DOCTYPE html>

<html lang=”en”>

<head>

<meta charset=”UTF-8″>

<title>JavaScript Function Call</title>

</head>

<body>

<button id=”myButton”>Click me</button>

<p id=”myText”>Hover over this text</p>

<script>

document.getElementById(“myButton”).onclick = function() {

alert(“Hello, world!”);

};

document.getElementById(“myText”).onmouseover = function() {

this.innerHTML = “Mouse over!”;

};

document.getElementById(“myText”).onmouseout = function() {

this.innerHTML = “Mouse out!”;

};

</script>

</body>

</html>

در این مثال، از جاوا اسکریپت برای اضافه کردن رویدادها به عناصر HTML استفاده شده است:

  • با کلیک بر روی دکمه، یک پیام هشدار نمایش داده می‌شود.
  • با حرکت ماوس بر روی متن و خارج شدن از آن، متن تغییر می‌کند.

تفاوت Function Expression ،Function Declaration و Arrow Function

تفاوت Function Expression ،Function Declaration و Arrow Function

در جاوا اسکریپت، سه روش مختلف برای تعریف توابع وجود دارد: Function Declaration ،Function Expression و Arrow Function. هر یک از این روش‌ها خصوصیات خاص خود را دارد. در اینجا تفاوت‌ها و مثال‌هایی برای هر یک ارائه شده است:

1. Function Declaration

توضیحات:

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

هوستینگ (Hoisting): می‌توان قبل از تعریف تابع، آن‌را فراخوانی کرد.

مثال:

// Function Declaration

function greet() {

console.log(“Hello, world!”);

}

// فراخوانی تابع

greet(); // Output: Hello, world!

ویژگی‌ها:

هوستینگ: تابع greet می‌تواند قبل از تعریف خود فراخوانی شود.

این نوع تعریف تابع معمولاً در بالاترین سطح اسکریپت یا درون بلوک‌های کد استفاده می‌شود.

2. Function Expression

IDE چیست؟
بخوانید

توضیحات:

توابع به یک متغیر تخصیص داده می‌شوند.

تابع تنها پس از تعریف خود قابل استفاده است.

مثال:

// Function Expression

const greet = function() {

console.log(“Hello, world!”);

};

// فراخوانی تابع

greet(); // Output: Hello, world!

ویژگی‌ها:

بدون هوستینگ: تابع greet تنها پس از تعریف خود قابل فراخوانی است.

این روش معمولاً برای تعریف توابع به‌عنوان مقادیر استفاده می‌شود و می‌تواند برای تعریف توابع ناشناس مفید باشد.

3. Arrow Function

توضیحات:

تعریف توابع با استفاده از نماد پیکان (=>).

نحو مختصرتر و تمیزتر.

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

مثال:

// Arrow Function

const greet = () => {

console.log(“Hello, world!”);

};

// فراخوانی تابع

greet(); // Output: Hello, world!

ویژگی‌ها:

  • بدون هوستینگ: مشابه Function Expression، این توابع تنها پس از تعریف خود قابل فراخوانی هستند.
  • مختصر و تمیز: نحو کوتاه‌تر و ساده‌تر.
  • this محدود: Arrow Functions مقدار this را از محدوده والد خود به ارث می‌برند، که آن‌ها را برای استفاده در توابع بازگشتی مناسب می‌سازد.

استفاده از جاوا اسکریپت برای اضافه کردن رویدادها به عناصر HTML

بررسی تفاوت‌ها

1. هوستینگ

Function Declaration: قابل فراخوانی قبل از تعریف.

Function Expression و Arrow Function: تنها پس از تعریف قابل فراخوانی هستند.

2. this

Function Declaration و Function Expression: مقدار this به نحوه فراخوانی تابع بستگی دارد.

Arrow Function: مقدار this از محدوده والد به ارث می‌برد.

3. نحو

  • Function Declaration: function name() { … }
  • Function Expression: const name = function() { … }
  • Arrow Function: const name = () => { … }

سخن پایانی

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

chabokacademy
دوره‌های آموزشی آکادمی چابک
با تخفیف‌های ویژه آکادمی چابک، یادگیری را شروع کنید!

مشاهده دوره‌ها

 

منابع​

w3schools.com

geeksforgeeks.org

دیدگاه خود را اینجا قرار دهید

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