婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 在VBScript中使用類

在VBScript中使用類

熱門標(biāo)簽:武夷山旅游地圖標(biāo)注 怎么在地圖標(biāo)注自己 縣域地圖標(biāo)注打印店 個人可以辦理400電話么 修改地圖標(biāo)注 外呼系統(tǒng)API接口 萊西電子地圖標(biāo)注 金昌電話機器人價格 鳳臺百度地圖標(biāo)注店
首先,在我進(jìn)入實質(zhì)性主題并解釋如何建立類之前,我希望保證你知道“對象”。雖然你可以在程序中使用對象而不用知道其正確的規(guī)則,但我并不建議如此!對于對象的初學(xué)者,接下來的部分將讓你了解其概念及內(nèi)容。已經(jīng)了解面向?qū)ο缶幊蹋∣OP)的讀者可以跳過這章節(jié)。
導(dǎo)論
l “對象是什么?”——對象通常代表某種實體,主要是一個變量和函數(shù)的集合。
l “實體是什么?”——字面上說,實體是一個“事物”,我的意思是一個概念或者任何一個物體。例如,一輛汽車是一個實體,因為它是一個物體。你公司銷售部門銷售產(chǎn)品也是一個實體,當(dāng)然,你也可以將其拆開來看,銷售人員、客戶、產(chǎn)品等都是實體。
讓我們更深入的來看“銷售”這個實體(對象)。為了使你更準(zhǔn)確地有一個銷售的“映像”,你需要知道客戶買了什么,是哪個客戶,誰是銷售人員等等……這看來是一個簡單的事件,但假設(shè)所有信息是存儲在單獨的數(shù)據(jù)庫表中的,那么當(dāng)你需要獲得某個銷售過程所有相關(guān)信息時,你必須在你的數(shù)據(jù)庫中做多次獨立查詢,再將所有的數(shù)據(jù)集攏。有沒有更簡便的辦法而一次獲得銷售的所有信息呢?“對象”。
在對象中,你可以植入代碼以從其他表中獲得數(shù)據(jù),你也可以保存對象屬性的所有信息,這樣,你可以輕松地使用代碼管理你的銷售數(shù)據(jù)。例如:
''''''''Open the database connection
Set objConn = Server.CreateObject("ADODB.Connection")
objConn.Open "MyDSN"
''''''''Create the recordset object
Set objRS = Server.CreateObject("ADODB.Recordset")
''''''''Define the SQL query
strComplexSQLQuery = "SELECT C.Name, S.Name FROM Customers C, "  _
"Salespeople S, Sales Sl WHERE Sl.CustomerID=C.ID AND "  _
"Sl.SalespersonID=S.ID AND Sl.ID="  strIDOfThisSale  ";"
''''''''Open the recordset
objRS.Open strComplexSQLQuery, objConn, adOpenForwardOnly, _
adLockReadOnly, adCmdText
''''''''Take the customer and sales person names from the recordset
strCustomerName = objRS(0)
strSalesPersonName = objRS(1)
''''''''Tidy up the objects
objRS.Close
objConn.Close
Set objRS = Nothing
Set objConn = Nothing
''''''''Output the data
Response.Write "This sale was made by "  strSalesPersonName  _
" to "  strCustomerName
可以使用“對象”來替代:
''''''''Create the "Sale" object
Set objSale = New Sale
''''''''Lookup the correct sale
objSale.ID = strIDOfThisSale
''''''''Output the data
Response.Write "This sale was made by "  objSale.SalesPersonName  _
" to "  objSale.CustomerName
''''''''Tidy up the objects
objSale.Close
Set objSale = Nothing
如果你使用“Sale”對象做比打印更多的事,可以讓你省去很多的打字時間。
計算中,對象包括“屬性”和“方法”。屬性主要是儲存在對象中的一個變量,其用法與變量相同。唯一的區(qū)別在于參數(shù)賦值為:strMyVar = "This is a string variant", 而對象屬性為 objObject.Property="This is a string variant"。這點非常簡單而有用處。方法可以理解為植入對象中的函數(shù)與過程,可以使用strMyVar = objObject.MethodName(strMyVar)來代替strMyVar =FunctionName(strMyVar)。寫法不同,但功能相同。屬性的一個例子是對象Response中的ExpireAbsolute, Response.ExpiresAbsolute = CDate("1 September 1999")。方法的一個例子是對象Response中的Write方法,Response.Write "Hello world!"。
VBScript的一個新特性就是其可以創(chuàng)建新的對象而不需要求諸于花銷時間都極大的編譯器。我將向讀者展示如何創(chuàng)建對象的類,并希望提供一個良好的開端。 
創(chuàng)建對象
在VBScript中創(chuàng)建對象類型(類)時,你首先要知道,這真的很容易!我在一個下午自學(xué),只是閱讀了Microsof VB Script 的參考書,但必須承認(rèn),這書不是最容易閱讀的文檔。
初學(xué)者需要安裝VBScript 5.0引擎,可以在Microsoft''''''''s Scripting Site下載。
我們來看代碼。類的定義與函數(shù)和子過程非常類似。起始行為Class ,結(jié)尾是End Class,所有的對象定義寫在中間部門。現(xiàn)在我們可以用所學(xué)的來建立第一個類,不實現(xiàn)任何功能的類。
Class 4GuysTestObject
End Class
這看上去不是那么回事,但當(dāng)你寫入下面的代碼后,你將創(chuàng)建一個對象的實例:
Dim objTestObject
Set objTestObject = New 4GuysTestObject
Set objTestObject = Nothing
顯然,我們現(xiàn)在還不能用對象做任何事,現(xiàn)在我將解釋如何在對象中定義屬性和方法。
使用對象可以做的最基礎(chǔ)的,是建立一組數(shù)據(jù)。例如,假如要將時間、日期及視頻程序標(biāo)題建立在一起,你可以創(chuàng)建一個包含屬性“StartTime”, “ProgramDate”和“ProgramTitle”的對象。代碼如下:
Class TVProgram
Public StartTime
Public ProgramDate
Public ProgramTitle
End Class
Dim objTVShow
Set objTVShow = New TVProgram
objTVShow.StartTime = CDate("17:30")
objTVShow.ProgramDate = DateSerial(1999,9,17)
objTVShow.ProgramTitle = "The Jerry Springer Show"
Response.Write objTVShow.ProgramTitle  " is on at "  _
objTVShow.StartTime  " on "  objTVShow.ProgramDate
代碼工作的方式是,我們定義StartTime,ProgramDate和ProgramTitle為類TVProgram的屬性。這樣,這些屬性就像其他變量一樣來處理,沒有設(shè)置值則不會執(zhí)行代碼。屬性名字前的Public字段有其真實含義,而且非常重要。如果你不特指一個方法或?qū)傩詾閜ublic或 private,系統(tǒng)默認(rèn)值為public,但最好養(yǎng)成定義任何值的良好書寫習(xí)慣(也方便你之后自己的閱讀)。
上面程序的結(jié)果大致如下(決定于你的本地服務(wù)器配置):
The Jerry Springer Show is on at 5:30pm on 17/09/99.
我在英國,所以日期現(xiàn)實如上。不論你跑什么工程,它的效果都不錯,但只有你開始使用其他對象的功能,為你可能需要的所有信息和功能,創(chuàng)建一個完美的接口,以支持你所建對象包圍的實體,你才會體會到對象的真正實力。
現(xiàn)在,如果你不喜歡上面例子顯示日期的方法,而希望以同一種格式現(xiàn)實日期,也沒有不要在引用每個ProgramDate屬性時加FormatDateTime(),你只需要將此類代碼植入屬性本身。
這樣需要用另一種方法定義屬性。同樣,我們將使用ProgramDate為外部可見屬性,但因為ProgramDate屬性將成為一個函數(shù)而不是靜態(tài)值,我們將實際日期保存在另一個屬性中internal_ProgramDate。
Class TVProgram
Public StartTime
Public internal_ProgramDate
Public Property Get ProgramDate
ProgramDate = Day(internal_ProgramDate)  _
" "  MonthName(Month(internal_ProgramDate))  _
" "  Year(internal_ProgramDate)
End Property
Public ProgramTitle
End Class
Dim objTVShow
Set objTVShow = New TVProgram
objTVShow.StartTime = CDate("17:30")
objTVShow.internal_ProgramDate = DateSerial(1999,9,17)
objTVShow.ProgramTitle = "The Jerry Springer Show"
Response.Write objTVShow.ProgramTitle  " is on at "  _
objTVShow.StartTime  " on "  objTVShow.ProgramDate  "."
程序的結(jié)果如下:
The Jerry Springer Show is on at 5:30pm on 17 September 1999. 
我們來分析一下(2)中的程序:
Class TVProgram
Public StartTime
Public internal_ProgramDate
Public Property Get ProgramDate
ProgramDate = Day(internal_ProgramDate)  _
" "  MonthName(Month(internal_ProgramDate))  _
" "  Year(internal_ProgramDate)
End Property
Public ProgramTitle
End Class
Dim objTVShow
Set objTVShow = New TVProgram
objTVShow.StartTime = CDate("17:30")
objTVShow.internal_ProgramDate = DateSerial(1999,9,17)
objTVShow.ProgramTitle = "The Jerry Springer Show"
Response.Write objTVShow.ProgramTitle  " is on at "  _
objTVShow.StartTime  " on "  objTVShow.ProgramDate  "."
當(dāng)調(diào)用對象的屬性ProgramDate時,實際上執(zhí)行了函數(shù)ProgramDate,即如上定義的函數(shù),而很快你也將習(xí)慣這種在聲明部分使用Public 或Private關(guān)鍵字的方式。關(guān)鍵字“Property”,告知了編譯器如同調(diào)用屬性一樣在外部調(diào)用函數(shù)。接著的“Get”,表明該函數(shù)是輸出還是獲得一個值。
Get的意思是“允許外部代碼去‘獲取'一個值”,與其類似的關(guān)鍵字還有“Let”和“Set”,但這兩個比較復(fù)雜,因而我們以后再討論。
接下去的代碼看來有點難度的,給objectname.internal_ProgramDate賦值并通過objectname.ProgramDate來調(diào)用它。如果可以使用相同關(guān)鍵字同時為其賦值并獲得它的值不是更好嗎?當(dāng)然,那也可以。
如果定義Get和Let屬性的名稱相同,可以將它們當(dāng)作對象相同的屬性,但這只限于它們定義了相同數(shù)量的成員。(以下代碼看來不太相同,僅作為實例參考)
Class TVProgram
Public StartTime
Public internal_ProgramDate
Public Property Get ProgramDate
ProgramDate = Day(internal_ProgramDate)  " " _
 MonthName(Month(internal_ProgramDate))  _
" "  Year(internal_ProgramDate)
End Property
Public Property Let ProgramDate(ByVal varDateIn)
internal_ProgramDate = CDate(varDateIn)
End Property
Public ProgramTitle
End Class
Dim objTVShow
Set objTVShow = New TVProgram
objTVShow.StartTime = CDate("17:30")
objTVShow.ProgramDate = "17 Sept 99"
objTVShow.ProgramTitle = "The Jerry Springer Show"
Response.Write objTVShow.ProgramTitle  " is on at "  _
objTVShow.StartTime  " on "  objTVShow.ProgramDate  "."
以上代碼中Let的聲明部分看來似乎是一個多余的元素,當(dāng)我第一次看到時研究了很長時間。每次我使用“0”作為變量用在每個屬性上,我總是得到這個錯誤信息,“元素數(shù)量必須相等”。“它們確實相等!”抓狂之后,我回過頭去看程序才覺得自己的愚蠢!:)
原因是,當(dāng)你試圖為ProgramDate賦值時,你會使用這樣一行程序:
objTVShow.ProgramDate = dtmMyDate
為了方便,等號右邊的值(這里指dtmMyDate)作為了一個程元賦給了函數(shù)。因此編譯器可能會認(rèn)為在Get ProgramDate行有0程元,而Let ProgramDate卻多一個!分配的值總是被略過而作為屬性的最后一個程元,所以即使你使用其他程元,所賦的值總是作為最后一個程元。
現(xiàn)在看程序。無論通過ProgramDate設(shè)置日期為文本形式,還是用internal_ProgramDate譯成日期變量,程序都沒有問題。但能不能只使用一個入口呢?
如果internal_ProgramDate只能在內(nèi)部有效,而使用Let ProgramDate檢查傳輸?shù)臄?shù)據(jù)類型,我們就可以作出選擇。例如:
Class TVProgram
Public StartTime
Private internal_ProgramDate
Public Property Get ProgramDate
ProgramDate = Day(internal_ProgramDate)  " "  _
MonthName(Month(internal_ProgramDate))  _
" "  Year(internal_ProgramDate)
End Property
Public Property Let ProgramDate(ByVal varDateIn)
If IsDate(varDateIn) Then
internal_ProgramDate = varDateIn
Else
''''''''Place some error handling code in here.
End If
End Property
Public ProgramTitle
End Class
并同樣聲明StartTime屬性:
Class TVProgram
Private internal_StartTime
Public Property Get StartTime
StartTime = Hour(internal_StartTime)  ":" _
 Minute(internal_StartTime)
End Property
Public Property Let StartTime(ByVal varTimeIn)
If IsDate(varTimeIn) Then
internal_StartTime = varTimeIn
End If
End Property
Private internal_ProgramDate
Public Property Get ProgramDate
ProgramDate = Day(internal_ProgramDate)  " " _
 MonthName(Month(internal_ProgramDate))  _
" "  Year(internal_ProgramDate)
End Property
Public Property Let ProgramDate(ByVal varDateIn)
If IsDate(varDateIn) Then
internal_ProgramDate = varDateIn
End If
End Property
Public ProgramTitle
End Class
...
現(xiàn)在的代碼離我們想要的還是有些不太實用,我們將在其他頁使用類TVProgram,因此最好將其獨立定義,以便所有也面都可以調(diào)用。我們將在第四部分討論這點
現(xiàn)在的代碼離我們想要的還是有些不太實用,我們將在其他頁使用類TVProgram,因此最好將其獨立定義,以便所有也面都可以調(diào)用。創(chuàng)建一個ASP頁面,并命名為TVProgramClass.asp,我們在其中定義類TVProgram。
--TVProgramClass.asp--
%
       Class TVProgram
              Private internal_StartTime
              Public Property Get StartTime
                      StartTime = Hour(internal_StartTime)  _
                              ":"  Minute(internal_StartTime)
              End Property
              Public Property Let StartTime(ByVal varTimeIn)
                      If IsDate(varTimeIn) Then
                              internal_StartTime = varTimeIn
                      End If
              End Property
              Private internal_ProgramDate
              Public Property Get ProgramDate
                      ProgramDate = Day(internal_ProgramDate)  _
                              " "  MonthName(Month(internal_ProgramDate))  _
                              " "  Year(internal_ProgramDate)
              End Property
              Public Property Let ProgramDate(ByVal varDateIn)
                      If IsDate(varDateIn) Then
                              internal_ProgramDate = varDateIn
                      End If
              End Property
              Public ProgramTitle
       End Class
%>
這樣就可以在任何ASP中調(diào)用我們定義的類了,語法如下:
!-- #include virtual="TVProgramClass.asp" -->
%
       Dim objTVShow
       Set objTVShow = New TVProgram
       objTVShow.StartTime = CDate("17:30")
       objTVShow.ProgramDate = DateSerial(1999,9,17)
       objTVShow.ProgramTitle = "The Jerry Springer Show"
%>
%= objTVShow.ProgramTitle %> is on at %= objTVShow.StartTime %> on %= objTVShow.ProgramDate %>.
   這里有一個建議。如果你重命名你的包含文件.asp,并保證所有重要代碼都在CODE>% ... %> CODE>中,那么就算有人猜到了你包含文件的文件名,也沒辦法看見里面的內(nèi)容! 

標(biāo)簽:清遠(yuǎn) 上海 赤峰 涼山 邢臺 南京 楚雄 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在VBScript中使用類》,本文關(guān)鍵詞  在,VBScript,中,使用,類,在,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在VBScript中使用類》相關(guān)的同類信息!
  • 本頁收集關(guān)于在VBScript中使用類的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产网红主播福利一区二区| 国产自产视频一区二区三区| 在线观看不卡视频| 国产乱子伦视频一区二区三区| 日韩毛片精品高清免费| 日韩午夜av一区| 欧美综合一区二区三区| 懂色av一区二区三区免费看| 日韩av一二三| 亚洲午夜免费视频| 亚洲女人的天堂| 国产精品日韩精品欧美在线| 日韩精品一区二区三区四区| 色狠狠色噜噜噜综合网| 99国产精品久| www.欧美亚洲| 色综合天天做天天爱| zzijzzij亚洲日本少妇熟睡| 粉嫩aⅴ一区二区三区四区| 国产精品99久久久久久似苏梦涵| 香蕉乱码成人久久天堂爱免费| 亚洲一区二区三区精品在线| 综合欧美亚洲日本| 日本一区二区免费在线| 亚洲国产岛国毛片在线| 一区二区三区视频在线看| 久久伊人蜜桃av一区二区| 日韩精品91亚洲二区在线观看| 国产精品高潮呻吟久久| 国产精品国产三级国产专播品爱网| 精品福利二区三区| 欧美国产日韩在线观看| 亚洲国产乱码最新视频| 开心九九激情九九欧美日韩精美视频电影 | 美腿丝袜亚洲色图| 欧美在线免费视屏| 国产成人精品免费网站| 激情文学综合网| 国产精品亚洲成人| 成人小视频免费在线观看| 99精品久久只有精品| 色一情一乱一乱一91av| 欧美天堂亚洲电影院在线播放| 欧美久久久久久久久中文字幕| 欧美成人一区二区三区片免费| 丁香另类激情小说| 色综合色综合色综合| 欧美一区国产二区| 国产区在线观看成人精品 | 亚洲欧美另类图片小说| 亚洲视频在线观看一区| 97精品国产露脸对白| 欧美性色黄大片| 波多野结衣中文字幕一区 | 国产福利一区二区三区视频| 国产乱妇无码大片在线观看| 99久久夜色精品国产网站| 欧美日韩午夜在线视频| 久久美女艺术照精彩视频福利播放| 国产精品福利一区二区三区| 日韩和欧美一区二区三区| 成人激情黄色小说| 日韩美女在线视频| 欧美人成免费网站| 成人免费一区二区三区在线观看 | 91精品国产综合久久小美女| 久久精品亚洲精品国产欧美| 一区二区三区四区中文字幕| 韩国三级中文字幕hd久久精品| 在线看国产日韩| 国产精品毛片久久久久久| 精品少妇一区二区三区 | 日本亚洲电影天堂| 99v久久综合狠狠综合久久| 日韩一区二区三区电影| 亚洲精品国产视频| 不卡的av电影| 久久久久久9999| 免费在线看一区| 9191久久久久久久久久久| 亚洲欧美色综合| 国产成人免费视频网站高清观看视频| 91精品国产手机| 五月天精品一区二区三区| 在线观看免费一区| 亚洲一区二区三区中文字幕在线| 99国产精品久久| 亚洲色图欧美激情| 欧美在线观看视频在线| 一区二区三区免费| 色国产综合视频| 亚洲动漫第一页| 91精品国产福利| 久色婷婷小香蕉久久| 日韩视频不卡中文| 国内精品久久久久影院薰衣草| 欧美大片日本大片免费观看| 九九**精品视频免费播放| 精品成人一区二区三区四区| 国产乱码精品一区二区三区五月婷 | 国产精品午夜春色av| 国产精品18久久久久久vr| 欧美成人在线直播| 国产综合色视频| 日本一区二区成人| 91在线视频免费91| 亚洲乱码国产乱码精品精可以看| 丁香一区二区三区| |精品福利一区二区三区| 91久久免费观看| 亚洲图片有声小说| 日韩一区二区影院| 国产一区二区三区| 欧美日韩国产bt| 亚洲成人资源网| 精品美女被调教视频大全网站| 亚洲国产日韩一区二区| 欧美日韩视频第一区| 九色综合狠狠综合久久| 精品99久久久久久| 国产精品香蕉一区二区三区| 精品va天堂亚洲国产| 国产精品综合网| 国产精品久久久久久久久快鸭| 色视频欧美一区二区三区| 捆绑变态av一区二区三区| 午夜国产精品影院在线观看| 视频一区在线视频| 国产一区在线不卡| 久久成人18免费观看| 国产一区二区三区黄视频 | 欧美性猛交xxxx黑人交| 国产精品理论片在线观看| 欧美肥妇毛茸茸| 美女视频免费一区| 亚洲视频电影在线| 欧美亚洲国产一区在线观看网站| 精品一区二区影视| 不卡一区二区三区四区| 亚洲综合激情另类小说区| 欧美精品一区二区久久婷婷| 国产精品性做久久久久久| 日韩成人免费电影| 久久久99久久精品欧美| 91.com在线观看| 国产一区二区三区综合| 伊人开心综合网| 国产精品久久久久久久蜜臀| 在线观看国产精品网站| aaa亚洲精品| 免费在线一区观看| 水蜜桃久久夜色精品一区的特点| 久久婷婷国产综合精品青草| 欧美高清一级片在线| 精品一区二区三区免费视频| 婷婷六月综合网| 色美美综合视频| 美国三级日本三级久久99| 亚洲图片欧美色图| 精品福利一区二区三区免费视频| 在线播放日韩导航| 丁香婷婷综合激情五月色| 奇米精品一区二区三区四区 | 97aⅴ精品视频一二三区| 香蕉av福利精品导航| 亚洲男女毛片无遮挡| 精品国产乱码久久久久久图片| 欧美日韩精品三区| 99久久精品免费| 97se亚洲国产综合自在线| 老汉av免费一区二区三区 | 一本色道亚洲精品aⅴ| 国产黑丝在线一区二区三区| 午夜婷婷国产麻豆精品| 精品久久久久久久人人人人传媒 | 欧美电视剧在线看免费| 成人一区二区三区| 久久精品国产久精国产| 亚洲国产aⅴ天堂久久| 亚洲国产精品视频| 一区二区三区日韩精品视频| 一区二区三区在线免费播放| 国产日韩精品一区二区三区| 欧美精品一区二区蜜臀亚洲| 国产乱对白刺激视频不卡| 国产精品一区三区| 99精品视频一区二区三区| 成人av电影免费在线播放| av电影在线观看完整版一区二区| 国产毛片精品视频| 色综合久久综合网欧美综合网| 国产超碰在线一区| 色伊人久久综合中文字幕| 欧美撒尿777hd撒尿| 在线精品国精品国产尤物884a| 欧美性大战久久| 欧美亚洲综合一区| 久久天天做天天爱综合色| 久久草av在线| 国产精品911|