تکرار کننده ها

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

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

تکرارکننده‌ها دو متد ارائه می‌دهند: boolean hasNext() و Object next() . اسکریپت‌های گوگل ادز از الگوی تکرارکننده برای دریافت موجودیت‌های گوگل ادز استفاده می‌کنند.

از نظر عملکردی، تکرارکننده‌ها تفاوت چندانی با آرایه‌های معمولی ندارند و می‌توانند کد شما را مختصرتر کنند. کدی را که یک آرایه را پیمایش می‌کند، مقایسه کنید:

for (var i = 0; i < myArray.length; i++) {
  let myObject = myArray[i];
}

با کدی که یک تکرارکننده را پیمایش می‌کند:

while (myIterator.hasNext()) {
  let myObject = myIterator.next();
}

کد زیر نحوه‌ی استفاده از یک iterator را در تمام کمپین‌های جستجو و نمایش در حساب شما نشان می‌دهد:

var campaignIterator = AdsApp.campaigns().get();

while (campaignIterator.hasNext()) {
  let campaign = campaignIterator.next();
  console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +
      `budget=${campaign.getBudget().getAmount()}`);
}

همچنین می‌توانید از تکرار داخلی جاوا اسکریپت استفاده کنید:

for (const campaign of AdsApp.campaigns()) {
  console.log(`${campaign.getName()}; active? ${campaign.isEnabled()}; ` +
      `budget=${campaign.getBudget().getAmount()}`);
}

اعمال تابع withLimit() روی یک انتخابگر، مقدار totalNumEntities() را تغییر نمی‌دهد. x و y در قطعه کد زیر مقدار یکسانی خواهند داشت:

var x = AdsApp.keywords().get().totalNumEntities();
var y = AdsApp.keywords().withLimit(5).get().totalNumEntities();

برای به دست آوردن یک Iterator از موجودیت‌های گوگل ادز، ابتدا باید یک Selector بسازید.