迭代器

疊代器是一種常見的程式設計模式,可在發生以下情況時掃遍物件清單:

  • 無法一開始就知道清單大小。
  • 一次將整個清單載入記憶體可能會耗用過多資源。

迭代器會公開兩個方法:boolean hasNext()Object next()。Google Ads 指令碼會使用迭代器模式擷取 Google Ads 實體。

從功能上來說,迭代器與一般陣列並無太大差異,而且可以讓程式碼更精簡。請比較用來掃遍陣列的程式碼:

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

使用遍歷疊代器的程式碼:

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

以下程式碼示範如何在帳戶中使用迭代器處理所有廣告活動:

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

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

您也可以使用內建的 JavaScript 疊代:

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

withLimit() 套用至選取器不會變更 totalNumEntities() 的值。以下程式碼片段中的 xy 會具有相同的值:

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

若要取得 Google Ads 實體的疊代器,您必須先建立選取器