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

主頁 > 知識庫 > [ASP]使用類,實現模塊化

[ASP]使用類,實現模塊化

熱門標簽:外呼系統API接口 修改地圖標注 武夷山旅游地圖標注 金昌電話機器人價格 個人可以辦理400電話么 怎么在地圖標注自己 縣域地圖標注打印店 鳳臺百度地圖標注店 萊西電子地圖標注
所有寫程序的人都知道,當你逐漸對您要實現的功能展開的時候,很大的時候,第一天寫的東西第二天就忘了寫到那里了,很多的時候,不得不寫上詳細的程序開發筆記,這在ASP的系統開發中感覺尤其文件、函數復雜的時候,當我們打算對網站的一部分功能進行修改的時候,感覺無從下手或者感覺要修改的地方。這時候,如果您學過任何一門面向對象的編程的語言的話,自然想到怎么能把代碼功能實現模塊話,asp本質上不是面向對象的編程,但VBSCRPIT6.0提供了類,我們可以通過類實現代碼的封裝,實現模塊話。

首先,我要在這里寫上一些很官方的概念,意在說明面向對象是很具體化的,很實體的模式,不能讓有些人看見“對象”就被嚇跑了。

對象,就是能看到,感到,聽到,觸摸到,嘗到或聞到的東西,在這里我們這樣“定義”:對象是一個自包含的實體,用一組可識別的特性和行為來標識。
在面向對象的編程(oop)的編程方式,用使用下面的兩個術語。
類:這是對象的模板,定義了對象的特性。
實例:這是一個真實的對象,可以與之交互的東西。

屬性,方法和事件

在OOP中,下面的術語描述對象的特性:

屬性:這是一個名次,描述了某個對象的屬性。

方法:這是一個動詞,描述了對象可以完成的工作,或者希望它完成的工作。

事件:描述了對象為相應某個動作而執行的操作。
在編程時,對象的面向對象編程和面向對象設計的一部分,它們具有非常大的優勢,許多人認為這是一個復雜的主題,但實際上,它非常簡單,可以用四個簡單的術語來解釋:抽象、封裝、多態和繼承。

抽象:這是一個隱藏復雜性,類的內部工作情況,所以用戶不必知道它的運作方式,就像。如果想要看電視,就不必知道電視機時如何工作的,只需打開電視機,搜索頻道即可,on/off開關抽象了實際的操作,在string例子里,有一個trim方法,它可以刪除字符串尾部的空格,同樣不需要知道他是如何完成這個任務的,只要知道它有這個功能即可。

封裝:每個對象都包含進行操作所需要的所有信息,這個對象稱為封裝,因此對象不比依賴其他對象來完成自己的操作,在術語TOupper()方法中,string不必到其他地方獲取信息來把所有的字符轉換為大寫。

多態:這個術語用于表示不同的對象可以執行相同的動作,但要通過他們自己的實現代碼來執行,名稱一樣,但底層實現的代碼是不一樣的。

繼承:它定義了類如何相互關聯,共享特性的,繼承的工作方式是,定義類和子類,其中子類繼承了父類的所有特性,繼承的重要性是,它迫使類型相似的類具有一致性,并允許共享代碼,如果決定創建一個新類,就不必定義父類的所有特性。

在ASP中使用類,實現模塊化

下面我通過舉上幾個簡單的例子說明一下,注意,這里強調的是一種思想,如果在您開發ASP網站的時候能用一個類(基類)展開的話,這是很有必要的(也是很有難度的)。

我們先選擇一個簡單的例子:

我們要顯示經典論壇用戶的信息,當輸入用戶的ID以后能,顯示出該用戶的一些信息,這是一個過程,可以這樣考慮,我們把用戶當作一個對象,他有的屬性是ID,性別,積分,權限,實現的方法有顯示這些信息,ok,這樣寫:

Class blueidea
Private bname,bpoint,bsex,blevel
''''...................
end class

這里先聲明了一個名為 blueidea的類,接著是一些私有變量,用于存儲blueidea類的屬性,這些變量在代碼的外部不能訪問,這就是數據保護,要定義這些變量,使用了property語句獲得值間接的付給私有變量

''''-----------------------------------------------------------------
Property Get getname
getname=bname
End Property

Property Let getname(nameid)
bname=nameid
If nameid="" Then
bname="沒注冊用戶"
End If
End Property
''''------------------------------------------------------------------
Property Get getsex
getsex=bsex
End Property

Property Let getsex(sex)
bsex=killint(sex,0,0)
If bsex=0 Then
bsex="男"
Else
bsex="女"
End if
End Property
''''------------------------------------------------------------------
Property Get getpoint
getpoint=bpoint
End Property

Property Let getpoint(point)
bpoint=killint(point,0,0)
End Property
''''------------------------------------------------------------------

這里有個killint函數,是判斷數據合法性的,它的原形是:

Private Function killint(i,killstr,killsub)
If Not IsNumeric(i) Then
i=killstr
ElseIf i=0 Then
i=killsub
End if
killint=Int(Left(i,5))
End Function

該函數功能很明確,不再繁瑣說。

由于我們要通過積分判斷用戶級別,這里定義了一個私有函數:

Private Function getlevel()
bpoint=killint(bpoint,0,0)
If bpoint500 Then
blevel="初級會員"
ElseIf bpoint>=500 And bpoint=100 Then
blevel="高級會員"
Else
blevel="終極會員"
End If
Getlevel=blevel
End Function

我們要得是回送用戶的信息,必須定義一個public公用函數,顯示信息:

Public Function showuser()
response.write("h5>以下顯示font color=red>"bname"/font>的資料:/h5>")
response.write("h5>性別:font color=red>"bsex"/font>/h5>")
response.write("h5>積分:font color=red>"bpoint"/font>/h5>")
getlevel
response.write("h5>級別:font color=red>"blevel"/font>/h5>")
End Function
End class

使用這個類的時候這樣使用:(我在這里寫了一個表單處理的)

Set blueideauser=new blueidea
blueideauser.getname=Trim(request("id"))
blueideauser.getsex=request("sex")
blueideauser.getpoint=request("point")
blueideauser.showuser

控制讀取數據庫信息的類:
參考源碼:

''''名稱:ado_5do8
''''作用:讀取數據庫的各項操作
''''來源-耕耘村http://www.5do8.com http://www.Blueidea.com-5do8
''''創作:5do8
''''聯系:5do8@5do8.com
''''更新:2005年11月13日
''''授權:藍色理想網站積分超過3000,耕耘村所有注冊用戶
''''類的接口:ado_5do8.ConnectString=數據庫絕對路徑
 ''''ado_5do8.rs_top 調用數目,表的名稱 
Class ado_5do8
Private conn,sqlstr,rs,iid,itable,isession
  ''''sqlstr:數據庫地址,為絕對路徑,私有
  ''''conn:打開數據庫的連接,私有

''''------------------------------------------------------------------
rem 消除一些不想要的數字  
Private Function litter_in(r1,r2)
If IsNumeric(r1) and IsNumeric(r2) Then
Dim dimrr
If r1>r2 Then
dimrr=r2
Else
dimrr=r1
End If
Else
dimrr=0
End if
litter_in=dimrr
End Function
''''-----------------------------------------------------------------
Private Function killint(i,killstr,killsub)
 If Not IsNumeric(i) Then
 i=killstr
 ElseIf i=0 Then
 i=killsub
 End if
 killint=Int(Left(i,5))
 End Function
''''-----------------------------------------------------------
private Sub startconn()
  On Error Resume Next 
   Set conn=server.CreateObject("adodb.connection")
  strconn="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="  Server.MapPath(sqlstr)
  conn.open strconn
  If Err Then
  err.Clear
  Set Conn = Nothing
  mess="發生錯誤,不能連接數據庫"
  response.write(mess)
  response.End
  Else
  mess="連接數據庫conn成功...........
"
  response.write(mess)
  End If
  End Sub
''''----------------------------------------------------------------
private Sub closeconn()
  conn.close 
  Set conn=Nothing
  response.write("strong style=''''color:red''''>關閉conn連接/strong>...hr/>")
 End sub 
''''-----------------------------------------------------------------
Private Sub closers()
 rs.close
 Set rs=Nothing
 response.write("strong style=''''color:#085420''''>關閉數據庫RS/strong>.......
")

 End Sub

''''-----------------------------------------------------------------
Property Get havese
 havese=isession
 End Property

Property Let havese(yoursession)
 isession=yoursession
 If yoursession="" Then
 isession="nodef"
 End If
 End Property

''''-----------------------------------------------------------------
Public Function makesession(arraydata)
  If IsArray(arraydata) then
  makear=arraydata
  Else
  makear=Array(0,0,0,0)
  End If
  If isession="" Then
  isession="nodef"
  End if
  session(isession)=makear
  End Function
''''-----------------------------------------------------------------

private Function getsession()
 thisget=session(isession)
 If Not IsArray(thisget) Then
 thisget=Array(0,0,0,0)
 End If
 Getsession=thisget
 End function
''''-----------------------------------------------------------------
Property Get ConnectString 
ConnectString = sqlstr
End Property
Property Let ConnectString(str) 
sqlstr = str
End Property
''''-----------------------------------------------------------------

Property Get getid 
getid = iid
End Property
Property Let getid(id) 
iid = id
End Property
''''-----------------------------------------------------------------

Property Get gettable 
gettable = itable
End Property
Property Let gettable(table) 
itable = table
End Property
''''-----------------------------------------------------------------
''''------------------------------------------------------------------
public Function readarraysession(iStart,ipageno,irowid)
 rowid=killint(irowid,0,0)
 start=killint(istart,0,0)
 pageno=killint(ipageno,5,5)
  data=getsession
 iRows = UBound(data, 2)
 iCols = UBound(data, 1)
 response.write("h5>總數獲得了:")
 response.write("b> "iRows+1"/b>條信息/h5>hr/>ul style=''''width:100%;''''>")
 If rowid = 0 then
 If iRows > (ipageno + iStart) Then
 iStop = ipageno + iStart - 1
 Else
 iStop = iRows
 End If
 For iRowLoop = Start to iStop
 Response.Write ("li style=''''padding:4px 0;''''>a href=?k=readrowid="irowloop+1">"data(1, iRowLoop)  " /a>span style=''''padding:4px 0 4px 10px;background-color:#ccc; ''''>較慢,不推薦點擊-->a href=?k=listid="data(0,irowloop)">更新/a>/span>/li>")
 Next 
 Response.Write "/ul>div style=''''top:20px;background-color:#ccc;color:#020;font-weight:bold;bordr-top:2px solid #008;padding:10px 0;color:#b00''''>列表(a href=default.asp>回到典型模式/a>):"
 if Start > 0 then
  Response.Write "A HREF=""?k=readStart="  iStart-ipageno "pageno="  ipageno  """>Previous/A>"
 end if 
 if iStop  iRows then
 Response.Write " A HREF=""?k=readStart="  iStart+ipageno "pageno="  ipageno  """>Next/A>"
 end If

 response.write"/div>"

 Else
 rowid=litter_in(rowid-1,iRows)
 response.write("div style=''''width:85%''''>h4 style=''''text-align:center''''>a href=?k=readpageno="pageno"start="start">返回列表/a>/h4>/h2>hr/>h5>"server.htmlencode(data(1,rowid))"/h5>p>"server.htmlencode(data(2,rowid))"h5>+-----"server.htmlencode(data(3,rowid))"")
 response.write("div >")
 End if
 End Function

''''-----------------------------------------------------------------
Public Function list_ids()
 sql3="select * from "itable" where id="iid" "
 startconn()
 Set rs=conn.execute(sql3)
 If rs.eof And rs.bof Then
 data=Array(0,0,0,0)
 Else
 data=Rs.GetRows()
 End If
 closers
 closeconn
  response.write(UBound(data)":")
 response.write(server.htmlencode(data(2,0)))
 End function

''''-----------------------------------------------------------------
Public Function rs_top(num,table,whe)
 startconn()
 sql="select top "num" * from "table""
 sql2="select count(*) as szd_count from "table" "" "whe""
 Set rs=conn.execute(sql2)
 szd_count=rs("szd_count")
 closers
  Set rs = Conn.Execute(sql)
  dim data
 If Rs.Eof Then
 data="no data"
 Else
 data=Rs.GetRows()
 End if
 closers
 closeconn()
 Call makesession (data)
   End Function
''''+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
End Class

試用方法:
Dim action 
action=request("k")
If action="view"  Then
Call viewnew
ElseIf action="list" Then
Call list()
 ElseIf action="read" Then
Call read()
Else
Call ff()
End if
 Sub ff()
%> 
form style="border-top:2px solid #008;border-bottom:2px solid #008;margin:auto;background-color:#eee;padding:20px 5px;color:#008;font-weight:bold;"> 
  label>顯示信息總數:input name="n" type="text" maxlength="4" size="10" />每頁數目:input name="pagesize" type="text" maxlength="4" size="10" value="5"/>input name="arrstart" type="hidden" value="0">/label>

  h5 style="border-top:1px solid #000;padding:5px 0"> 操作:input name="k" type="submit" value="view" />/h5>

/form> %End sub%>
 %Sub viewnew()
 f_num=killint(request("n"),1,1)
  pagesize=killint(request("pageno"),5,5)
 arrstart=killint(request("start"),0,0)
 rowid=killint(request("rowid"),0,0)
Set cs=new ado_5do8
cs.ConnectString="data/a.mdb"
cs.havese="shi"
  cs.rs_top f_num,"site_szd",""
cs.readarraysession  arrstart,pagesize,rowid
     End sub
 Sub list()
 response.write("h5>a href=default.asp>返回默認模式/a>/h5>")
    response.write"下面顯示具體信息:hr/>"
   id=request("id")
   id=killint(id,1,1)
   Set listid=new ado_5do8
   listid.ConnectString="data/a.mdb"
    listid.getid=id
   listid.gettable="site_szd"
   listid.list_ids()
End Sub

Sub read()
 response.write"div style=''''background-color:#ccc;padding:20px 0;color:080;font-weight:bold;border-bottom:2px solid #008''''>頁面分析完畢,要更新請選擇a href=default.asp>回到典型模式/a>參數:Start,開始元素;pageno,每頁條數/div>"
  pagesize=killint(request("pageno"),5,5)
 arrstart=killint(request("start"),0,0)
 rowid=killint(request("rowid"),0,0)
 Set cs=new ado_5do8
 cs.havese="shi"
 cs.readarraysession  arrstart,pagesize,rowid

End sub

Function killint(i,killstr,killsub)
 If Not IsNumeric(i) Then
 i=killstr
 ElseIf i=0 Then
 i=killsub
 End if
 killint=Int(Left(i,5))
 End Function 
%>

說明:

此源碼5do8單獨寫出,本源碼我享有解釋權,但不保證源碼的安全,任何損失使用者自己承擔,本源碼僅僅限于在耕耘村(http: //www.5do8.com),藍色理想(http://www.blueidea.com)和締客論壇(http://www.dw8.cn)站內交流。當然,不許抄襲。

標簽:通遼 涼山 上海 南京 邢臺 赤峰 清遠 楚雄

巨人網絡通訊聲明:本文標題《[ASP]使用類,實現模塊化》,本文關鍵詞  ASP,使用,類,實現,模塊化,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《[ASP]使用類,實現模塊化》相關的同類信息!
  • 本頁收集關于[ASP]使用類,實現模塊化的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本不卡的三区四区五区| 国产精品久久久久婷婷二区次| 91精品国产综合久久香蕉的特点 | 久久久精品免费网站| 国产精品盗摄一区二区三区| 国产亚洲一区二区三区| 亚洲综合区在线| 久久99精品国产91久久来源| 91玉足脚交白嫩脚丫在线播放| 91丨九色丨尤物| 欧美电影免费观看完整版| 亚洲欧美影音先锋| 午夜精品久久久久影视| 成人网页在线观看| 91精品国产综合久久久蜜臀粉嫩| 国产欧美视频一区二区| 亚洲美女屁股眼交| 韩国av一区二区三区四区| 色婷婷综合久久久久中文| 精品国产百合女同互慰| 亚洲一区二区三区小说| 国产白丝精品91爽爽久久| 欧美日韩久久久一区| 精品国产乱码久久久久久1区2区| 一区二区不卡在线视频 午夜欧美不卡在 | 91网上在线视频| 亚洲精品在线观看网站| 亚洲国产精品天堂| 国内精品自线一区二区三区视频| 精品视频全国免费看| 亚洲欧洲另类国产综合| 日本系列欧美系列| 欧美日韩视频在线第一区 | 日韩高清欧美激情| 一本大道久久a久久综合| 国产日韩精品一区二区三区在线| 偷拍日韩校园综合在线| 欧美日韩免费视频| 国产精品二三区| 成人a免费在线看| 国产视频一区二区在线| 狠狠色综合播放一区二区| 日韩你懂的在线观看| 亚洲高清视频的网址| 欧美日韩在线直播| 亚洲不卡一区二区三区| 欧美性色欧美a在线播放| 亚洲二区视频在线| 欧美成人在线直播| 成人激情动漫在线观看| 国产精品网站在线观看| 成人美女视频在线观看18| 国产亚洲一区二区三区| 成年人网站91| 日韩一区在线播放| 色综合中文综合网| 欧美一区二区视频在线观看2020 | 欧美精品v日韩精品v韩国精品v| 亚洲一二三级电影| 欧美剧在线免费观看网站| 亚洲va在线va天堂| 久久蜜桃av一区精品变态类天堂| 色综合亚洲欧洲| 激情六月婷婷综合| 亚洲女与黑人做爰| 久久久亚洲国产美女国产盗摄| 99re亚洲国产精品| 免费成人在线观看视频| 国产精品久久久久影院老司| 欧美日韩成人综合天天影院| 久久国产精品72免费观看| 亚洲欧洲日产国产综合网| 日韩一级成人av| 色婷婷精品久久二区二区蜜臀av | 午夜不卡av免费| 久久欧美一区二区| 欧美日韩一区高清| 97久久精品人人澡人人爽| 久久不见久久见免费视频1| 亚洲综合视频网| 国产精品不卡在线| 久久综合久久综合亚洲| 精品视频1区2区3区| 99综合影院在线| 国产伦精品一区二区三区视频青涩 | 亚洲地区一二三色| 中文字幕不卡三区| 精品国产123| 欧美日韩国产一级二级| 色综合久久久久综合99| 国产高清在线精品| 久久精品噜噜噜成人88aⅴ| 亚洲自拍欧美精品| 亚洲人快播电影网| 国产欧美日韩在线| 久久精品亚洲精品国产欧美| 欧美一区二区三区日韩视频| 欧洲另类一二三四区| 99re成人精品视频| 岛国精品在线播放| 懂色av中文一区二区三区| 国产乱子轮精品视频| 激情五月播播久久久精品| 美女视频黄免费的久久 | 麻豆91在线播放免费| 亚洲mv在线观看| 亚洲国产欧美在线| 亚洲一区在线播放| 亚洲午夜三级在线| 亚洲va国产天堂va久久en| 亚洲午夜在线电影| 亚洲不卡一区二区三区| 亚洲h精品动漫在线观看| 午夜精品一区二区三区免费视频 | 韩国成人在线视频| 国产一区二区三区不卡在线观看 | 国产福利一区二区| 国产成人精品免费视频网站| 国产精品一区二区久久不卡| 国产精品白丝jk黑袜喷水| 国产一区二区三区不卡在线观看| 国产福利一区在线观看| 成人毛片老司机大片| 色综合久久综合| 91精品国产综合久久精品| 日韩欧美中文字幕精品| 久久香蕉国产线看观看99| 国产网站一区二区三区| 亚洲天堂中文字幕| 亚洲一区二区综合| 精品一区二区三区不卡| 高清视频一区二区| 欧美在线观看你懂的| 欧美刺激脚交jootjob| 国产喷白浆一区二区三区| 一区二区三区在线看| 日韩电影一二三区| 国产成人一区二区精品非洲| 日本精品免费观看高清观看| 日韩一区二区高清| 国产精品色哟哟| 午夜精品久久久久久久久| 国产在线精品免费av| 不卡电影免费在线播放一区| 日本高清成人免费播放| 欧美大胆一级视频| 国产精品区一区二区三区| 夜夜精品视频一区二区| 久久精品国产久精国产| 91网址在线看| 精品久久久久av影院| 悠悠色在线精品| 国产麻豆91精品| 制服丝袜亚洲网站| 国产精品美女久久久久久久久久久| 天天操天天干天天综合网| 国产黄人亚洲片| 666欧美在线视频| 亚洲欧美一区二区三区极速播放 | 久久丁香综合五月国产三级网站| 成人黄色在线网站| 欧美xfplay| 午夜a成v人精品| 91免费在线看| 国产网站一区二区| 精品亚洲porn| 91麻豆精品91久久久久久清纯| 日韩美女啊v在线免费观看| 国产精品中文字幕欧美| 欧美一区2区视频在线观看| 一区二区在线观看av| voyeur盗摄精品| 久久精品亚洲一区二区三区浴池| 奇米色一区二区| 欧美久久久久久久久| 伊人婷婷欧美激情| 色综合网站在线| 国产精品传媒入口麻豆| 国产成人99久久亚洲综合精品| 日韩欧美第一区| 七七婷婷婷婷精品国产| 欧美图区在线视频| 亚洲一级二级三级| 欧美专区在线观看一区| 一区二区三区中文字幕电影 | 99精品欧美一区二区三区小说| 国产亚洲成aⅴ人片在线观看| 久久精品国产精品亚洲综合| 日韩美女天天操| 精品在线免费观看| 日韩一区二区三区视频在线| 天天综合天天做天天综合| 欧美日本免费一区二区三区| 午夜天堂影视香蕉久久| 欧美日韩国产综合一区二区三区| 亚洲一二三区在线观看| 欧美在线观看18| 奇米色一区二区| 久久先锋影音av鲁色资源网| 国产乱人伦偷精品视频不卡|