亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

ASP使用類概念實現模塊化

2024-05-04 11:07:58
字體:
來源:轉載
供稿:網友

寫在前面的話: 

  所有寫程序的人都知道,當你逐漸對您要實現的功能展開的時候,很大的時候,第一天寫的東西第二天就忘了寫到那里了,很多的時候,不得不寫上詳細的程序開發筆記,這在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 bpoint<500 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 

  是不是想看看效果,那就看看這里:  http://www.5do8.com/net/aspclass/class.asp 

  控制讀取數據庫信息的類: 
  參考源碼 
'名稱: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成功...........<br/>" 
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>.......<br/>") 

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=read&rowid="&irowloop+1&">"&data(1, iRowLoop) & " </a><span style='padding:4px 0 4px 10px;background-color:#ccc; '>較慢,不推薦點擊--><a href=?k=list&id="&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=read&Start=" & iStart-ipageno &"&pageno=" & ipageno & """>Previous</A>" 
end if 
if iStop < iRows then 
Response.Write " <A HREF=""?k=read&Start=" & 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=read&pageno="&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 
%> 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲免费伊人电影在线观看av| 亚洲一区二区三区毛片| 国产精品国产福利国产秒拍| 精品爽片免费看久久| 欧美富婆性猛交| 伊是香蕉大人久久| 亚洲成人黄色在线观看| 亚洲激情电影中文字幕| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美性xxxx| 国产欧美韩国高清| 久久在精品线影院精品国产| 日本中文字幕不卡免费| 韩国精品美女www爽爽爽视频| 国产精品亚洲激情| 成人精品久久一区二区三区| 色噜噜狠狠色综合网图区| 蜜臀久久99精品久久久无需会员| 色综合伊人色综合网站| 亚洲天堂色网站| 欧美另类精品xxxx孕妇| 久久精品欧美视频| 亚洲精品一区在线观看香蕉| 欧美激情网站在线观看| 亚洲图片在区色| 亚洲女同性videos| 亚洲精品99久久久久| 久久久久久久久久婷婷| 亚洲人成伊人成综合网久久久| 国产黑人绿帽在线第一区| 久久久人成影片一区二区三区观看| 国产亚洲一区二区精品| 国产精品wwwwww| 美女少妇精品视频| 色综合久久久888| 国产a∨精品一区二区三区不卡| 久久精品99久久香蕉国产色戒| 精品久久久免费| 亚洲欧洲黄色网| 亚洲精品欧美日韩| 自拍偷拍亚洲欧美| 日韩欧美亚洲国产一区| 国产精品黄页免费高清在线观看| 91成品人片a无限观看| 福利视频一区二区| 国产日本欧美在线观看| 日本欧美黄网站| 在线色欧美三级视频| 精品无人区太爽高潮在线播放| 日韩av不卡电影| 久久99精品国产99久久6尤物| 5252色成人免费视频| 91精品国产乱码久久久久久久久| 欧美大片免费观看| 欧美精品一本久久男人的天堂| 国产成人一区二区三区小说| 亚洲男人天堂网| 国产精品福利在线观看| 成人97在线观看视频| 久久九九国产精品怡红院| 亚洲欧美国产另类| 亚洲欧美日韩国产精品| 91欧美精品成人综合在线观看| 精品久久香蕉国产线看观看亚洲| 青草青草久热精品视频在线网站| 日韩麻豆第一页| 精品久久久久人成| 日韩暖暖在线视频| 欧美精品激情视频| 日本成人在线视频网址| 精品国内产的精品视频在线观看| 亚洲影院在线看| 狠狠色狠色综合曰曰| 亚洲精品一区二三区不卡| 日韩电影免费观看在线| 亚洲毛片一区二区| 伦伦影院午夜日韩欧美限制| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲黄色免费三级| 热久久视久久精品18亚洲精品| 国内外成人免费激情在线视频| www.日韩av.com| 亚洲男人av电影| 亚州成人av在线| 欧美成人在线影院| 91爱爱小视频k| 奇门遁甲1982国语版免费观看高清| 国产有码在线一区二区视频| 欧美久久精品午夜青青大伊人| 国产亚洲精品久久久久久| 亚洲级视频在线观看免费1级| 亚洲成人精品视频| 欧美日韩国产丝袜另类| 69视频在线免费观看| 九九视频直播综合网| 成人国产精品av| 欧美综合一区第一页| 久久亚洲成人精品| 国产精品久久久久久久app| 成人免费网视频| 国产性猛交xxxx免费看久久| 日本一区二区在线免费播放| 最近2019年手机中文字幕| 日韩精品视频在线播放| 欧美精品久久一区二区| 中文日韩在线观看| 亚洲精品成人网| 久久国产精品免费视频| 亚洲天堂av在线播放| 一本一本久久a久久精品牛牛影视| 久久成人精品电影| 欧美成人精品在线播放| 久久99热精品这里久久精品| 高清欧美一区二区三区| 国产精品久久久久久久7电影| 亚洲精品久久久久| 美女精品久久久| 国产精品亚洲综合天堂夜夜| 亚洲高清免费观看高清完整版| 亚洲女人天堂网| 欧美黑人巨大xxx极品| 97香蕉久久夜色精品国产| 国产精品男女猛烈高潮激情| 欧美三级免费观看| 91精品国产高清久久久久久91| 亚洲精品视频播放| 黑人巨大精品欧美一区二区三区| 日韩在线播放视频| 国产精品吊钟奶在线| 日韩精品免费观看| 91精品国产91久久久久福利| 国产亚洲a∨片在线观看| 欧美日韩国产第一页| 国产精品免费一区| 日韩欧美在线视频免费观看| 亚洲人成亚洲人成在线观看| 国产福利视频一区二区| 91最新国产视频| 亚洲午夜久久久影院| 国内精品久久久久久久久| 欧美诱惑福利视频| 欧美日韩美女在线| 国产成人综合亚洲| 久久成人精品电影| 欧美日韩国产在线| 色偷偷亚洲男人天堂| 亚洲自拍偷拍一区| 欧美激情精品久久久久久大尺度| 91日本视频在线| 国产欧美在线看| 欧美精品www在线观看| 亚洲色图50p| 欧美日韩免费观看中文| 亚洲最大福利视频网| 久热精品视频在线| 成人av电影天堂| 日韩av理论片| 久久99热这里只有精品国产| 亚洲国产99精品国自产| 亚洲最新在线视频| 日韩视频免费中文字幕| 亚洲精品日产aⅴ| 国产精品九九久久久久久久| 久久色免费在线视频|