如果用戶單擊確定或按下 ENTER,則 InputBox 函數(shù)返回文本框中的內(nèi)容。如果用戶單擊取消,則函數(shù)返回一個零長度字符串 ("")。
這是參考手冊對InputBox函數(shù)返回值的說明,簡單而明了,還有必要專門寫一篇文章來討論?我知道你一定對標題不屑一顧,換成是我,我也一定會不屑一顧,如果我沒有看到百度VBS吧里的一個帖子。
關于Inputbox 疑惑
————————————————————————————
如果用戶單擊確定或按下 ENTER,則 InputBox 函數(shù)返回文本框中的內(nèi)容。如果用戶單擊取消,則函數(shù)返回一個零長度字符串 ("")。
————————————————————————————
那如何區(qū)分用戶是沒有輸入字符按了“確定”
還是按了“取消”呢?
有些時候想傳入空字符的,而有些時候想取消輸入
按照參考手冊的說法,無論是用戶沒有輸入字符按了“確定”,還是按了“取消”,函數(shù)的返回值都是零長度字符串""。這樣看來,似乎沒有辦法區(qū)分用戶是沒有輸入字符按了“確定”,還是按了“取消”。
我也以為這是無法實現(xiàn)的,但是下面卻有人給出了解決方案:
代碼如下:
Str=InputBox("???")
If Str="wffheu" Then MsgBox("a")
Else if Str=False Then "您按。。。取消"
End If
雖然有語法錯誤,但是用False的確可以區(qū)分出“確定”和“取消”。為什么呢?因為如果用戶單擊取消,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返回真,于是可以判斷。
看來文檔寫的也不一定是對的,盡信文檔,不如無文檔。