VBS中InputBox函式的返回值使用技巧

NO IMAGE

如果使用者單擊確定或按下 ENTER,則 InputBox 函式返回文字框中的內容。如果使用者單擊取消,則函式返回一個零長度字串 (“”)。

這是參考手冊對InputBox函式返回值的說明,簡單而明瞭,還有必要專門寫一篇文章來討論?我知道你一定對標題不屑一顧,換成是我,我也一定會不屑一顧,如果我沒有看到百度VBS吧裡的一個帖子。

關於Inputbox 疑惑
————————————————————————————
如果使用者單擊確定或按下 ENTER,則 InputBox 函式返回文字框中的內容。如果使用者單擊取消,則函式返回一個零長度字串 (“”)。
————————————————————————————
那如何區分使用者是沒有輸入字元按了“確定”
還是按了“取消”呢?
有些時候想傳入空字元的,而有些時候想取消輸入

按照參考手冊的說法,無論是使用者沒有輸入字元按了“確定”,還是按了“取消”,函式的返回值都是零長度字串””。這樣看來,似乎沒有辦法區分使用者是沒有輸入字元按了“確定”,還是按了“取消”。

我也以為這是無法實現的,但是下面卻有人給出瞭解決方案:
複製程式碼 程式碼如下:
Str=InputBox(“???”)
If Str=”wffheu” Then MsgBox(“a”)
Else if Str=False Then “您按。。。取消”
End If

雖然有語法錯誤,但是用False的確可以區分出“確定”和“取消”。為什麼呢?因為如果使用者單擊取消,InputBox返回的並不是一個零長度的字串””,而是Empty

用一個簡單的程式就可以測試出來:
複製程式碼 程式碼如下:
str = InputBox(“Enter a string”)
MsgBox TypeName(str)

當沒有輸入字元直接按“確定”時輸出String,而按“取消”時輸出Empty。於是,似乎可以這樣來判斷到底是“確定”還是“取消”:
複製程式碼 程式碼如下:
str = InputBox(“Enter a string”)
If str = Empty Then
MsgBox “Cancel”
Else
MsgBox “OK”
End If

只可惜上面的程式碼是錯的,無論按下“確定”還是“取消”,都會輸出Cancel。因為無論是”” = Empty(比較前Empty會隱式轉化成””)還是Empty = Empty都會返回真,正確的方法是用IsEmpty來判斷:
複製程式碼 程式碼如下:
str = InputBox(“Enter a string”)
If IsEmpty(str) Then
MsgBox “Cancel”
Else
MsgBox “OK”
End If

再說說為什麼可以用False來判斷,”” = False返回假(比較前False會隱式轉換成字串”False”),而Empty = False返回真,於是可以判斷。

看來文件寫的也不一定是對的,盡信文件,不如無文件。
原文: http://demon.tw/programming/vbs-inputbox.html