如果用戶單擊確定或按下 ENTER,則 InputBox 函數(shù)返回文本框中的內(nèi)容。如果用戶單擊取消,則函數(shù)返回一個(gè)零長(zhǎng)度字符串 ("")。
這是參考手冊(cè)對(duì)InputBox函數(shù)返回值的說明,簡(jiǎn)單而明了,還有必要專門寫一篇文章來討論?我知道你一定對(duì)標(biāo)題不屑一顧,換成是我,我也一定會(huì)不屑一顧,如果我沒有看到百度VBS吧里的一個(gè)帖子。
關(guān)于Inputbox 疑惑
————————————————————————————
如果用戶單擊確定或按下 ENTER,則 InputBox 函數(shù)返回文本框中的內(nèi)容。如果用戶單擊取消,則函數(shù)返回一個(gè)零長(zhǎng)度字符串 ("")。
————————————————————————————
那如何區(qū)分用戶是沒有輸入字符按了“確定”
還是按了“取消”呢?
有些時(shí)候想傳入空字符的,而有些時(shí)候想取消輸入
按照參考手冊(cè)的說法,無論是用戶沒有輸入字符按了“確定”,還是按了“取消”,函數(shù)的返回值都是零長(zhǎng)度字符串""。這樣看來,似乎沒有辦法區(qū)分用戶是沒有輸入字符按了“確定”,還是按了“取消”。
我也以為這是無法實(shí)現(xiàn)的,但是下面卻有人給出了解決方案:
代碼如下:
Str=InputBox("???")
If Str="wffheu" Then MsgBox("a")
Else if Str=False Then "您按。。。取消"
End If
雖然有語(yǔ)法錯(cuò)誤,但是用False的確可以區(qū)分出“確定”和“取消”。為什么呢?因?yàn)槿绻脩魡螕羧∠?,InputBox返回的并不是一個(gè)零長(zhǎng)度的字符串"",而是Empty
用一個(gè)簡(jiǎn)單的程序就可以測(cè)試出來:
代碼如下:
str = InputBox("Enter a string")
MsgBox TypeName(str)
當(dāng)沒有輸入字符直接按“確定”時(shí)輸出String,而按“取消”時(shí)輸出Empty。于是,似乎可以這樣來判斷到底是“確定”還是“取消”:
代碼如下:
str = InputBox("Enter a string")
If str = Empty Then
MsgBox "Cancel"
Else
MsgBox "OK"
End If
只可惜上面的代碼是錯(cuò)的,無論按下“確定”還是“取消”,都會(huì)輸出Cancel。因?yàn)闊o論是"" = Empty(比較前Empty會(huì)隱式轉(zhuǎn)化成"")還是Empty = Empty都會(huì)返回真,正確的方法是用IsEmpty來判斷:
代碼如下:
str = InputBox("Enter a string")
If IsEmpty(str) Then
MsgBox "Cancel"
Else
MsgBox "OK"
End If
再說說為什么可以用False來判斷,"" = False返回假(比較前False會(huì)隱式轉(zhuǎn)換成字符串"False"),而Empty = False返回真,于是可以判斷。
看來文檔寫的也不一定是對(duì)的,盡信文檔,不如無文檔。