疊代器是一種常見的程式設計模式,可在發生以下情況時掃遍物件清單:
- 無法一開始就知道清單大小。
- 一次將整個清單載入記憶體可能會耗用過多資源。
迭代器會公開兩個方法: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()
的值。以下程式碼片段中的 x
和 y
會具有相同的值:
var x = AdsApp.keywords().get().totalNumEntities();
var y = AdsApp.keywords().withLimit(5).get().totalNumEntities();
若要取得 Google Ads 實體的疊代器,您必須先建立選取器。