程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> ASP技巧 >> 使用VBScript操作Html復選框(CheckBox)控件

使用VBScript操作Html復選框(CheckBox)控件

編輯:ASP技巧

這兩天看到有朋友問起Html內的各種控件怎麼用script進行操作,現在自己也總結一下。因為項目原因,很多程序都是用VBScript寫的,感興趣的朋友可以改寫成JavaScript,到時候別忘了共享一下啊,活活。

OK,切入主題,現介紹一下:

今天介紹使用VBScript判斷復選框的選中數量和被選中的復選框的值。

在生成某個一覽表時,比如一個訂貨單一覽表,每條訂貨單記錄前面可能會放置一個復選框,以提供批量刪除,發行等功能。一般每個復選框的值也就是後面對應記錄的主鍵的值,如訂貨單編號。在執行刪除、發行等功能時,就要知道選了幾個復選框,這些復選框分別對應什麼值,下面就說一下方法。

程序分為三部分:

一、判斷被選定的CheckBox是一個還是一個以上

      主要思路是:當有多個同名的復選框,但ID不同時,舉例復選框控件名為chkTest,那麼它將被以數組的形式調用,比如說有三個復選框名字叫chkTest,ID分別是chkTest1,chkTest2,chkTest3,那麼要想查看三個復選框的checked屬性就要這麼寫:chkTest(0).checked, chkTest(1).checked, chkTest(2).checked (數組從零開始);而當只有一個復選框的時候,直接可以使用chkTest.checked。這樣就決定了對於數量不同的(1個或多個兩種分別),只能采用不同的方法來取得復選框的信息。由於當有多個同名不同ID的控件時,該控件擁有“控件名.type”這個屬性,而這個只讀的屬性可以等於任何字符串,也就是說 控件名.type = “任意字符串“ 恆為true。當然,這只是對有控件名.type這個屬性的時候,否則恆為false,這樣也就分辨出在一覽表裡的復選框是單個還是多個了。程序如下:

'*************************************************
'<函數名>
' gfIs_ArrayTest(obj)
'<功能>
' 判斷選定的CheckBox的是一個還是一個以上
'<參數>
' CheckBox對象名
'<返回值>
' true
' false
'<備注>
' Created on Mar.15th.2004 by AITD
'*************************************************
function gfIs_ArrayTest(obj)
on error resume next
 if obj.type = "flag" then
  gfIs_ArrayTest = True
 else
  gfIs_ArrayTest = False
 end if
end function

二、檢查畫面上復選框的選擇是否符合要求

         所謂是否符合要求的意思就是,比如說,刪除的時候選擇起碼一條記錄,修正的時候選且只能選擇一條記錄,至於其他的,什麼只能選擇5條,只能選擇10條等等,下面的程序改以下就行了。別忘了剛才說的,只有一個復選框和有多個復選框的處理方法是不一樣的。

'******************************************************
'<函數名>
' gfChkCheckbox()
'<功能>
' 檢查畫面CheckBox的選擇是否符合要求
'<參數>
' obj: 對應的checkbox控件
' flag: 檢查規則:0 可有多個被選中
'       1 只能有一個被選中
' name:  提示用戶那個控件報錯的信息
'<返回值>
' true
' false
'<備注>
' Created on Mar.15th.2004 by AITD
'******************************************************
function gfChkCheckbox(obj,flag,name)
 Dim i
 Dim j
 
 gfChkCheckbox = false
 i = 0
 j = 0
 '若對象不存在
 if isnull(obj) then
  msgbox "請選擇一個 " + name + "。"  '請選擇一個對象
  gfChkCheckbox = false
  exit function
 end if
 
 '對象只有一個
 if not gfIs_ArrayTest(obj) then
  if obj.checked = false then
   msgbox "請選擇一個 " + name + "。"  '請選擇一個對象
   gfChkCheckbox =  false
   exit function
  else
   gfChkCheckbox = true
   exit function
  end if
 end if

 '若有多個對象存在

 for i = 0 to (obj.length - 1)
  if obj(i).type = "checkbox" then
   if obj(i).checked = true then
    j = j + 1
   end if
  end if
 next
 
 if j = 0 then
  msgbox "請選擇 " + name + "。"  '請選擇一個對象
  gfChkCheckbox =  false
  exit function
 end if
 if j = 1 then
  gfChkCheckbox = true
  exit function
 end if
 if j > 1 then
  if flag = 1 then
   msgbox "只能選擇一個 " + name + "。"  '只能選擇一個對象
   gfChkCheckbox =  false
   exit function
  else
   gfChkCheckbox =  true
   exit function
  end if
 end if

end function

三、取得復選框的值

         為了後面處理的方便,常把重要的信息保存在復選框的value屬性裡,以便後面取用。下面的程序將選中的復選框的值以間隔符 “^|^“ 串成一個字符串並返回。

'*************************************************
'<函數名>
' gfGetCheckBoxValue(obj)
'<功能>
' 取得選定的CheckBox的值
'<參數>
' CheckBox對象名
'<返回值>
' 選定的CheckBox的值
'<備注>
' Created on Mar.15th.2004 by AITD
'*************************************************
function gfGetCheckBoxValue(obj)

 dim strValue
 dim intCounter
 dim i

 strValue = ""
 intCounter = 0

 '如果對象不存在
 if isnull(obj) then
  gfGetCheckBoxValue = strValue
  exit function
 end if

 '如果對象為一個
 if not gfIs_ArrayTest(obj) then
  if obj.checked = false then
   gfGetCheckBoxValue = strValue
   exit function
  else
   gfGetCheckBoxValue = obj.value
   exit function
  end if
 end if

 '如果對象為多個
 for i = 0 to obj.length - 1
  if obj(i).checked = true then
   if intCounter > 0 then
    strValue = strValue & "^|^" & CStr(obj(i).value)
   else
    strValue = CStr(obj(i).value)
   end if
   intCounter = intCounter + 1
  end if
 next

 gfGetCheckBoxValue = strValue
end function

上面就是VBScript裡面處理復選框的方法(偶用的)。可以把這幾個函數封裝到一個共通的vbs文件中,並在Html的<head>標記區內引用就可以通用了~ 如 <head><script language=vbscript src=vbsChkBoxTool.vbs></script></head>

還要注意一個問題,在實際應用中,有可能根據查詢條件生成的一覽表裡一條記錄也沒有,就是說沒有復選框控件,如果仍舊調用這樣一個名字的控件,這時候IE就會報錯。沒有什麼太好的解決辦法,於是寫了一段程序繞過這個沒有復選框控件的情況:

function sIsChkBoxExist()
 on error resume next
  err.clear
  if isEmpty(document.frmOrderList.chkOrder) then
  end if
  if err.number <> 0 then
  else
   sIsChkBoxExist=true
  end if
  err.clear
 end function

程序中對預定的控件隨便做一個操作,如isEmpty,如果捕捉到了err.number>0的情況,就說明該控件不存在,但由於有on error resume next,所以不會提示錯誤,這樣也就判斷出了控件存不存在。

每次在調用上面三個函數之前,先調用一次sIsChkBoxExist函數,看看對應的控件存不存在,這樣就不會有錯了。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved