Reduce در جاوا اسکریپت چیست و چگونه استفاده می‌ شود؟ + نمونه کد

۱۳۴۲ بازدید
آخرین به‌روزرسانی: ۷ خرداد ۱۴۰۲
زمان مطالعه: ۱۲ دقیقه
دانلود PDF مقاله
Reduce در جاوا اسکریپت چیست و چگونه استفاده می‌ شود؟ + نمونه کدReduce در جاوا اسکریپت چیست و چگونه استفاده می‌ شود؟ + نمونه کد

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

997696

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

مُتد Reduce در جاوا اسکریپت جنبه‌ای اساسی از «برنامه نویسی تابعی» (Functional Programming) به حساب می‌آید. این متد، عناصر موجود در آرایه را از چپ به راست پردازش و مقدار حاصل را در یک «Accumulator» (انباشتگر| انباره) ذخیره می‌کند.

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

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

«سینتکس» (Syntax) متد Reduce در Javascript به صورت قطعه کد زیر است:

1array.reduce(callbackfn(total, curValue, curIndex, array), initialValue)

در ادامه هر یک از اجرای سینتکس Reduce در قالب فهرست شرح داده شده‌اند.

  • callbackfn نوعی پارامتر اجباری به حساب می‌آید که نشان دهنده تابعی است که باید روی هر عنصر آرایه اجرا شود. این پارامتر، خود ۴ آرگومان زیر را نیاز دارد:
    • total : این پارامتری اجباری است که در ابتدا مقدار initialValue را نگه می‌دارد و سپس آخرین مقدار بازگشتی را از تابع ذخیره می‌کند.
    • CurValue : این پارامتر هم اجباری است و مقدار عنصر فعلی در حال پردازش را نگه می‌دارد.
    • curIndex : این مورد، پارامتری اختیاری به حساب می‌آید که اندیس مقدار فعلی در حال پردازش را نگه می‌دارد.
    • array : این هم پارامتری اختیاری محسوب می‌شود و نشان دهنده شی کامل آرایه‌ای است که عملیات روی آن انجام می‌شود.
  • initialValueنیز نوعی پارامتر اختیاری است که مقدار اولیه ارسال شده به تابع را نگه می‌دارد.

با درک و استفاده از متد Reduce با مقادیر دستوری و پارامتری مناسب آن، می‌توان عملیات قدرتمندی را روی آرایه‌ها در جاوا اسکریپت انجام داد.

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

مفهوم Reducer و Accumulator

عبارات «کاهنده» (Reducer) و «انباشت کننده» (Accumulator) مفاهیم کلیدی هنگام کار با متد Reducer در جاوا اسکریپت هستند.

  • Reducer: به معنی کاهش دهنده یا کاهنده است و به عملیات یا عملی اطلاق می‌شود که بر روی هر عنصر آرایه در طول فرآیند Reduce اعمال می‌شود. در واقع Reducer مسئول کاهش کل آرایه به مقداری واحد با اجرای تابعی خاص بر روی هر عنصر است.
  • Accumulator: این عبارت هم به معنی انباشته کننده و جزء مهمی در متد Reduce است. آکومولاتور در واقع متغیر یا ظرفی را نشان می‌دهد که نتایج میانی و نهایی را با اعمال تابع کاهنده به هر عنصر آرایه در خود نگه می‌دارد. در ابتدا، آکومولاتور ممکن است مقدار اولیه اختیاری داشته باشد و سپس آخرین مقدار بازگشتی را از تابع کاهنده ذخیره می‌کند.

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

ویژگی های Reduce در جاوا اسکریپت

متد Reduce در جاوا اسکریپت ویژگی‌های زیر را دارد:

  • ارائه مقدار اولیه: اگر مقدار اولیه مشخص شود، انباشت کننده روی آن مقدار تنظیم خواهد شد و curValue معادل اولین مقدار آرایه خواهد بود.
  • عدم ارائه مقدار اولیه: اگر مقدار initialValue  یا همان مقدار اولیه حذف شود، انباشت کننده روی عنصر اول آرایه تنظیم شده و initialValueمعادل مقدار عنصر دوم خواهد بود.
  • مدیریت آرایه‌های خالی: اگر Reduce() روی آرایه خالی بدون ارائه مقدار اولیه اعمال شود، TypeError ایجاد خواهد شد.
  • عدم اجرای callbackfn برای آرایه‌های خالی یا تک عنصری: اگر آرایه خالی و FillValue ارائه شده باشد، یا اگر آرایه شامل تنها یک عنصر به همراه initialValueباشد، متد Reduce()به سادگی همان مقدار را بدون اجرای تابع callback برمی‌گرداند.

درک این ویژگی‌ها به برنامه‌ نویس کمک می‌کند تا به طور موثر از متد Reduce()استفاده کند و وی را قادر می‌سازد تا بتواند سناریوهای مختلف را مدیریت کند.

مثال Reduce در جاوا اسکریپت

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

مثال جمع همه مقادیر آرایه با Reduce در Javascript

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

1let num = [5, 9, 12, 24, 67]
2
3let sum = num.reduce(function (accumulator, curValue) {
4
5  return accumulator + curValue
6
7}, 0)
8
9console.log(sum)

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

مثال Reduce در جاوا اسکریپت

کدهای فوق را همچنین می‌توان با «توابع پیکان» (Arrow Functions) به صورت زیر نوشت که خروجی آن با خروجی کد بالا یکسان است.

1let num = [5, 9, 12, 24, 67]
2
3let sum = num.reduce((accumulator, curValue) => accumulator + curValue, 0)
4
5console.log(sum)

مثال جمع کردن مقادیر در آرایه با استفاده از Array Reduce

برای محاسبه مجموع مقادیر از آرایه‌ای از اشیا، لازم است مقدار اولیه برای متد Reduce() ارائه شود. با انجام این کار، تمام عناصر آرایه به وسیله تابع پردازش شده و نتیجه مطلوب حاصل می‌شود. قطعه کد مثال مذکور به صورت زیر است:

1let initialValue = 0
2
3let obj = [{n: 5}, {n: 9}, {n: 13}, {n: 25}, {n: 40}]
4
5let sum = obj.reduce(function (accumulator, curValue) {
6
7    return accumulator + curValue.n
8
9}, initialValue)
10
11console.log(sum)

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

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

مثال مسطح کردن آرایه ای از آرایه ها با متد Reduce در جاوا اسکریپت

سناریویی را در نظر بگیرید که در آن آرایه‌ای از آرایه‌ها وجود دارد و هدف مسطح کردن آن به یک آرایه واحد است. کد زیر نحوه دستیابی به این هدف را با استفاده از متد Reduce در Javascript نشان می‌دهد:

1let mulArray = [[3, 5], [1, 7], [12, 9]]
2
3let newArray = mulArray.reduce(function(accumulator, curValue) {
4
5    return accumulator.concat(curValue)
6
7  },[]
8
9)
10
11console.log(newArray)

با اجرای کد بالا در کنسول جاوا اسکریپت، خروجی آن به صورت زیر خواهد بود:

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

در مثال فوق، متغیر mulArray آرایه‌ای متشکل از چندین آرایه است. در کدهای بالا، متد Reduce() به mulArrayاعمال شده و تابع به عنوان اولین آرگومان ارسال خواهد شد. این تابع callback دو پارامتر accumulator و curValue را می‌پذیرد. در تابع callback، از متد concat() برای الحاق آرایه curValueبا آرایه آکومولاتور استفاده شده است که با این کار آرایه مسطح مورد نظر ساخته خواهد شد.

دومین آرگومان ارسال شده به Reduced() آرایه‌ خالی [] است که به عنوان مقدار اولیه آکومولاتور عمل می‌کند. این آرگومان تضمین خواهد کرد که اولین تکرار با آرایه خالی شروع می‌شود. در نهایت، آرایه مسطح به دست آمده در متغیر newArray ذخیره خواهد شد و در کنسول به ثبت می‌رسد.

مثال شمارش نمونه ها در شی با استفاده از Reduce در Javascript

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

1let myCars = ['Mercedes-Benz', 'Jeep', 'Ferrari', 'Lamborghini', 'Mercedes-Benz', 'BMW', 'Ferrari']
2
3let instances = myCars.reduce(function (allCars, car) {
4
5  if (car in allCars) {
6
7    allCars[car]++
8
9  }
10
11  else {
12
13    allCars[car] = 1
14
15  }
16
17  return allCars
18
19}, {})
20
21console.log(instances)
مشاهده کامل کدها

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

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

در کد فوق، متد Reduce() به myCars اعمال و تابع callback به عنوان اولین آرگومان ارسال شده است. همچنین تابع callbackدو پارامتر allCars و car را می‌گیرد.

در داخل تابع callback، با استفاده از عملگر in بررسی می‌شود که آیا خودرو قبلاً یک ویژگی در شی allCarsبوده است یا خیر و اگر این‌طور باشد، تعداد مربوط به خودروی مد نظر افزایش داده می‌شود. اگر وجود نداشت، به شی allCarsاضافه می‌شود و تعداد را روی 1 قرار خواهد داد.

دومین آرگومان ارسال شده به Reduced() شی خالی {} است که به عنوان مقدار اولیه برای شی allCarsعمل می‌کند. در نهایت، شی به‌ دست‌ آمده با تعداد نام خودرو در متغیر نمونه‌ها ذخیره و در کنسول ثبت می‌شود.

مثال گروه بندی اشیا با Reduce در جاوا اسکریپت

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

1let student = [
2
3  { name: 'David', age: 23, hobby: 'fishing' },
4
5  { name: 'Rachel', age: 25, hobby: 'cooking' },
6
7  { name: 'Rahul', age: 22, hobby: 'fishing' }
8
9];
10
11function myFunc(obj, prop) {
12
13  return obj.reduce(function (acc, item) {
14
15    let key = item[prop]
16
17    if (!acc[key]) {
18
19      acc[key] = []
20
21    }
22
23    acc[key].push(item)
24
25    return acc
26
27  }, {})
28
29}
30
31let groupedStudent = myFunc(student, 'hobby')
32
33console.log(groupedStudent)
مشاهده کامل کدها

خروجی قطعه کد بالا با اجرای آن در کنسول به صورت زیر خواهد بود:

آموزش متد reduce

در کد فوق، تابعی به نام groupObjectsByProperty تعریف شده است که آرایه obj و ویژگی prop را به عنوان پارامتر می‌گیرد. در داخل تابع، متد Reduce() روی آرایه objاعمال شده است. تابع callbackنیز ۲ پارامتر acc (accumulator) و item را می‌گیرد.

در تابع callback، مقدار ویژگی propاز هر شی استخراج و به متغیر key اختصاص داده شده است. اگر keyبه عنوان ویژگی در شی acc وجود نداشته باشد، به صورت آرایه خالی مقداردهی اولیه خواهد شد. سپس آیتم فعلی به آرایه keyمربوطه push داده خواهد شد. در نهایت، شی accبازگردانده می‌شود که اکنون شامل اشیای گروه‌بندی شده با مقدار خاصیت مشخص شده است.

مثال حذف موارد تکراری با متد Reduce

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

1let array = [2, 5, 7, 5, 12, 9, 7, 5, 4, 3, 5, 2, 4, 15]
2
3let newArray = array.reduce(function (accumulator, curValue) {
4
5  if (accumulator.indexOf(curValue) === -1) {
6
7    accumulator.push(curValue)
8
9  }
10
11  return accumulator
12
13}, [])
14
15console.log(newArray)
مشاهده کامل کدها

با اجرای قطعه کد بالا در کنسول جاوا اسکریپت، خروجی به صورت زیر خواهد بود:

حذف موارد تکراری با متد reduce 

در قطعه کد بالا، متد Reduce() به آرایه اعمال و تابع callbackبه عنوان اولین آرگومان ارسال شده است. در داخل تابع callback، با استفاده از متد indexOf()‎ بررسی می‌شود که آیا CurValue در آرایه accumulator وجود دارد یا خیر و اگر وجود نداشته باشد (1- را برمی‌گرداند)، CurValueرا به آرایه آکومولاتور push می‌دهد.

دومین آرگومان ارسال شده به Reduce()آرایه خالی [] است که به عنوان مقدار اولیه برای اکومولاتور عمل می‌کند. این آرایه نیز تضمین خواهد کرد که اولین تکرار با آرایه خالی شروع می‌شود. در نهایت، آرایه به دست آمده بدون مقادیر تکراری در متغیر newArray ذخیره و در کنسول به ثبت خواهد رسید.

Reduce در جاوا اسکریپت ES5

Reduce در جاوا اسکریپت «ES5» به صورت زیر استفاده می‌شود:

1var euros = [29.76, 41.85, 46.5]; 
2
3var sum = euros.reduce( function(total, amount){
4  return total + amount
5});
6
7sum // 118.11

در مثال بالا به جای کلمه کلیدی var از const استفاده شده و بعد از پارامترها، عبارتfunction با "fat arrow" (=>) جایگزین و عبارت return از آن حذف شده است. این شیوه نوشتن متد Reduce در ES5 است و با این حال سینتکس «جاوا اسکریپت ES6» برای این هدف مختصرتر و واجد خطای کمتری خواهد بود.

یافتن میانگین با متد Reduce در جاوا اسکریپت چگونه است؟

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

اولین آرگومان index است که نشان دهنده تعداد دفعاتی خواهد بود که تابع Reducer آرایه را پیمایش می‌کند. مثال زیر این موضوع را نشان می‌دهد.

1const euros = [29.76, 41.85, 46.5];
2
3const average = euros.reduce((total, amount, index, array) => {
4  total += amount;
5  if( index === array.length-1) { 
6    return total/array.length;
7  }else { 
8    return total;
9  }
10});
11
12average // 39.37

Map و Filter به عنوان کاهش در جاوا اسکریپت

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

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

Map و Filter در جاوا اسکریپت

به عنوان نمونه، در ادامه آرایه‌ای از مقادیر به آرایه دیگری کاهش داده خواهد شد که در آن هر مقدار آرایه ۲ برابر می‌شود. برای رسیدن به این هدف، باید مقدار اولیه برای آکومولاتور تعیین شود که در این مورد آرایه‌ای خالی خواهد بود. مقدار اولیه نشان دهنده مقدار شروع پارامتر کل در هنگام شروع کار عملیات کاهش است. می‌توان مقدار اولیه را با اضافه کردن کاما (, ) و سپس مقدار اولیه دلخواه خود در داخل پرانتز بعد از {} تنظیم کرد. درست مانند مثال زیر:

1const average = euros.reduce((total, amount, index, array) => {
2  total += amount
3  return total/array.length
4}, 0);

در مثال‌های قبلی، مقدار اولیه حذف و به جای آن مقداری پیش‌فرض total به آن اختصاص یافته بود. با این حال، زمانی که مقدار اولیه روی آرایه‌ای خالی قرار گیرد، می‌توان هر مقداری را به totalاختصاص داد. اگر هدف این باشد که آرایه‌ای از مقادیر را به آرایه دیگری کاهش دهیم که در آن هر مقدار دو برابر می‌شود، باید مقدار 2* را به آرایه totalاعمال یا به اصطلاح push کرد. مثال زیر این مفهوم را می‌رساند.

1const euros = [29.76, 41.85, 46.5];
2
3const doubled = euros.reduce((total, amount) => {
4  total.push(amount * 2);
5  return total;
6}, []);
7
8doubled // [59.52, 83.7, 93]

در مثال بالا با استفاده از متد Reduce در جاوا اسکریپت، با موفقیت آرایه‌ای جدید ایجاد شد که در آن هر مقدار ۲ برابر می‌شود. با این حال، می‌توان قدمی فراتر رفت و «پالایش» (فیلترینگ| Filtering) را اعمال کرد تا اعداد خاصی از دو برابر شدن مصون بمانند. این کار را می‌توان با ترکیب دستور if در Reducer انجام داد. مثال زیر این موضوع را نشان می‌دهد.

1const euro = [29.76, 41.85, 46.5];
2
3const above30 = euro.reduce((total, amount) => {
4  if (amount > 30) {
5    total.push(amount);
6  }
7  return total;
8}, []);
9
10above30 // [ 41.85, 46.5 ]

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

وقتی عملیات Mapو Filterبا هم ترکیب می‌شوند، اساساً عملیات ۲ بار انجام خواهند شد. ابتدا هر مقدار را Filter می‌کند و سپس عملیات Mapروی آن‌ها انجام می‌گیرد. با این حال، با متد Reduce در Javascript، می‌توان عملیات ذکر شده را هم‌زمان انجام داد. در مثال‌های ساده و پیش پا افتاده به دلیل افزایش پیچیدگی کدها، استفاده از متد Reduce برای انجام عملیات Mapو Filterتوصیه نمی‌شود ولی در سناریوهای پیچیده‌تر و ترکیبی می‌توان از کارایی متد Reduce برای انجام این کار استفاده کرد.

Piping با متد Reduce

یکی از جنبه‌های جذاب متد Reduce در جاوا اسکریپت، توانایی آن در کار نه تنها با اعداد و رشته‌ها، بلکه با توابع در جاوا اسکریپت است. سناریویی را در نظر بگیرید که در آن مجموعه‌ای از توابع پایه ریاضی وجود دارند.

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

1function increment(input) { return input + 1;}
2
3function decrement(input) { return input — 1; }
4
5function double(input) { return input * 2; }
6
7function halve(input) { return input / 2; }

فرض بر این است که کاربر می‌خواهد مقداری را افزایش، دو برابر و سپس کاهش دهد. به جای اینکه هر بار یک تابع جداگانه بنویسد، می‌تواند با استفاده از متد Reduce، نوعی «خط لوله» (Pipeline) قابل استفاده مجدد ایجاد کند. در این زمینه، pipeline دنباله‌ای از توابع است که یک مقدار اولیه را به یک مقدار نهایی تبدیل می‌کند. pipelineدر مثال فرضی این بخش شامل سه تابع افزایش، دو برابر و کاهش با رعایت ترتیب ذکر شده است.

با استفاده از Reduce ، می‌توان pipelineایجاد کرد که مقداری اولیه می‌گیرد و هر تابع را در دنباله اعمال خواهد کرد و مقدار را گام به گام با توجه به عملیات موردنظر تغییر می‌دهد. این رویکرد نیاز به بازنویسی توابع را در هر بار حذف می‌کند و راه‌حل انعطاف‌پذیرتر و قابل استفاده مجدد را ارائه می‌دهد.

1let pipeline = [increment, double, decrement];

به جای استفاده از متد Reduceدر آرایه‌ای از مقادیر، می‌توان متد Reduceرا در pipelineتوابع اعمال کرد. جنبه کلیدی مسئله این است که مقدار اولیه pipelineرا می‌توان به عنوان مقداری که قصد تبدیل آن وجود دارد به صورت زیر تنظیم کرد.

1const result = pipeline.reduce(function(total, func) {
2  return func(total);
3}, 1);
4
5result // 3

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

به عنوان مثال، اگر نیاز کاربر شامل سه بار کاهش، به دنبال آن ۲ برابر کردن، کاهش مجدد آن و در نهایت نصف کردن آن باشد، می‌توان به سادگی pipelineرا با تنظیم مجدد توابع بر اساس آن اصلاح کرد. قطعه کد زیر برای بیان این مفهوم است:

1var pipeline = [
2
3  increment,
4  
5  increment,
6  
7  increment,
8  
9  double,
10  
11  decrement,
12  
13  halve
14  
15];
مشاهده کامل کدها

اشتباهات رایج در استفاده از Reduce در جاوا اسکریپت

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

در حالی که این ممکن است در موارد خاص به خوبی کار کند، اما می‌تواند منجر به نتایج غیرمنتظره شود، به ویژه در هنگام انجام عملیاتی مانند محاسبه تعداد اقلام احتمال رخدداد خطا وجود دارد. بنابراین، مهم است اطمینان حاصل شود که همیشه مقدار اولیه مناسب هنگام استفاده از Reduceارائه شده باشد تا از هرگونه رفتار غیرمنتظره جلوگیری شود.

متد reduce در javascript

اشتباه دیگری که باید مراقب آن بود، فراموش کردن بازگردانی مقدار کل در تابع Reducer است. تابع کاهنده باید همیشه مقداری را برگرداند تا متد Reduce به درستی کار کند. عدم انجام این کار می‌تواند منجر به نتایج نادرست یا غیرمنتظره شود.

Reduce در جاوا اسکریپت به وسیله چه مرورگرهایی پشتیبانی می شود؟

Reduce در جاوا اسکریپت به وسیله مرورگرهای مختلفی مانند؛ «گوگل کروم»، «مایکروسافت اج ۹»، «موزیلا فایرفاکس ۳»، «سافاری ۵» و «اوپرا ۱۰.۵» پشتیبانی خواهد شد. این مرورگرها عملکردهای لازم را برای استفاده از متد Reduce روی آرایه‌ها در جاوا اسکریپت پیاده‌سازی کرده‌اند.

سخن پایانی

متد Reduce در جاوا اسکریپت یکی از کاربردی‌ترین متدهایی است که در سناریوهای مختلفی از آن استفاده می‌شود. در این مطلب از «مجله فرادرس» در رابطه با متد Reduce و ابعاد مختلف این متد توضیحاتی مطلوب ارائه شد و چندین مثال عملی همراه با توضیحات بیان شدند.

همچنین در این مطلب، آموزش استفاده از Pipeline در ترکیب با متد Reduce ارائه شد. در پایان اشتباهات رایجی که در به کارگیری این متد امکان دارد کاربران با آن مواجه شوند نیز ارائه شد.

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

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