Do...Loop: 當(dāng)(或直到)條件為 True 時循環(huán)。 While...Wend: 當(dāng)條件為 True 時循環(huán)。 For...Next: 指定循環(huán)次數(shù),使用計數(shù)器重復(fù)運行語句。 For Each...Next: 對于集合中的每項或數(shù)組中的每個元素,重復(fù)執(zhí)行一組語句。 使用 Do 循環(huán) 可以使用 Do...Loop 語句多次(次數(shù)不定)運行語句塊。當(dāng)條件為 True 時或條件變?yōu)?True 之前,重復(fù)執(zhí)行語句塊。 當(dāng)條件為 True 時重復(fù)執(zhí)行語句 While 關(guān)鍵字用于檢查 Do...Loop 語句中的條件。有兩種方式檢查條件:在進入循環(huán)之前檢查條件(如下面的 ChkFirstWhile 示例);或者在循環(huán)至少運行完一次之后檢查條件(如下面的 ChkLastWhile 示例)。在 ChkFirstWhile 過程中,如果 myNum 的初始值被設(shè)置為 9 而不是 20,則永遠不會執(zhí)行循環(huán)體中的語句。在 ChkLastWhile 過程中,循環(huán)體中的語句只會執(zhí)行一次,因為條件在檢查時已經(jīng)為 False。 Sub ChkFirstWhile() Dim counter, myNum counter = 0 myNum = 20 Do While myNum > 10 myNum = myNum - 1 counter = counter + 1 Loop MsgBox "循環(huán)重復(fù)了 " counter " 次。" End Sub
Sub ChkLastWhile() Dim counter, myNum counter = 0 myNum = 9 Do myNum = myNum - 1 counter = counter + 1 Loop While myNum > 10 MsgBox "循環(huán)重復(fù)了 " counter " 次。" End Sub
重復(fù)執(zhí)行語句直到條件變?yōu)?True Until 關(guān)鍵字用于檢查 Do...Loop 語句中的條件。有兩種方式檢查條件:在進入循環(huán)之前檢查條件(如下面的 ChkFirstUntil 示例);或者在循環(huán)至少運行完一次之后檢查條件(如下面的 ChkLastUntil 示例)。只要條件為 False,就會進行循環(huán)。 Sub ChkFirstUntil() Dim counter, myNum counter = 0 myNum = 20 Do Until myNum = 10 myNum = myNum - 1 counter = counter + 1 Loop MsgBox "循環(huán)重復(fù)了 " counter " 次。" End Sub
Sub ChkLastUntil() Dim counter, myNum counter = 0 myNum = 1 Do myNum = myNum + 1 counter = counter + 1 Loop Until myNum = 10 MsgBox "循環(huán)重復(fù)了 " counter " 次。" End Sub
退出循環(huán) Exit Do 語句用于退出 Do...Loop 循環(huán)。因為通常只是在某些特殊情況下要退出循環(huán)(例如要避免死循環(huán)),所以可在 If...Then...Else 語句的 True 語句塊中使用 Exit Do 語句。如果條件為 False,循環(huán)將照常運行。 在下面的示例中,myNum 的初始值將導(dǎo)致死循環(huán)。If...Then...Else 語句檢查此條件,防止出現(xiàn)死循環(huán)。
Sub ExitExample() Dim counter, myNum counter = 0 myNum = 9 Do Until myNum = 10 myNum = myNum - 1 counter = counter + 1 If myNum 10 Then Exit Do Loop MsgBox "循環(huán)重復(fù)了 " counter " 次。" End Sub
Sub DoMyProc50Times() Dim x For x = 1 To 50 MyProc Next End Sub
關(guān)鍵字 Step 用于指定計數(shù)器變量每次增加或減少的值。在下面的示例中,計數(shù)器變量 j 每次加 2。循環(huán)結(jié)束后,total 的值為 2、4、6、8 和 10 的總和。 Sub TwosTotal() Dim j, total For j = 2 To 10 Step 2 total = total + j Next MsgBox "總和為 " total "。" End Sub
Sub NewTotal() Dim myNum, total For myNum = 16 To 2 Step -2 total = total + myNum Next MsgBox "總和為 " total "。" End Sub
Exit For 語句用于在計數(shù)器達到其終止值之前退出 For...Next 語句。因為通常只是在某些特殊情況下(例如在發(fā)生錯誤時)要退出循環(huán),所以可以在 If...Then...Else 語句的 True 語句塊中使用 Exit For 語句。如果條件為 False,循環(huán)將照常運行。
使用 For Each...Next For Each...Next 循環(huán)與 For...Next 循環(huán)類似。For Each...Next 不是將語句運行指定的次數(shù),而是對于數(shù)組中的每個元素或?qū)ο蠹现械拿恳豁椫貜?fù)一組語句。這在不知道集合中元素的數(shù)目時非常有用。 在以下示例中,Dictionary 對象的內(nèi)容用于將文本分別放置在多個文本框中:
HTML> HEAD>TITLE>窗體與元素/TITLE>/HEAD> SCRIPT LANGUAGE="VBScript"> !-- Sub cmdChange_onClick Dim d '創(chuàng)建一個變量 Set d = createObject("Scripting.Dictionary") d.Add "0", "Athens" '添加鍵和項目 d.Add "1", "Belgrade" d.Add "2", "Cairo"
For Each I in d Document.frmForm.Elements(I).Value = D.Item(I) Next End Sub --> /SCRIPT> BODY> CENTER> FORM NAME="frmForm"
Input Type = "Text">p> Input Type = "Text">p> Input Type = "Text">p> Input Type = "Text">p> Input Type = "Button" NAME="cmdChange" VALUE="單擊此處">p> /FORM> /CENTER> /BODY> /HTML>