佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 使用類,實(shí)現(xiàn)模塊化

使用類,實(shí)現(xiàn)模塊化

熱門標(biāo)簽:科大訊飛語音識(shí)別系統(tǒng) 銀行業(yè)務(wù) 阿里云 Linux服務(wù)器 服務(wù)器配置 電子圍欄 Mysql連接數(shù)設(shè)置 團(tuán)購網(wǎng)站

寫在前面的話:

  所有寫程序的人都知道,當(dāng)你逐漸對(duì)您要實(shí)現(xiàn)的功能展開的時(shí)候,很大的時(shí)候,第一天寫的東西第二天就忘了寫到那里了,很多的時(shí)候,不得不寫上詳細(xì)的程序開發(fā)筆記,這在ASP的系統(tǒng)開發(fā)中感覺尤其文件、函數(shù)復(fù)雜的時(shí)候,當(dāng)我們打算對(duì)網(wǎng)站的一部分功能進(jìn)行修改的時(shí)候,感覺無從下手或者感覺要修改的地方。這時(shí)候,如果您學(xué)過任何一門面向?qū)ο蟮木幊痰恼Z言的話,自然想到怎么能把代碼功能實(shí)現(xiàn)模塊話,asp本質(zhì)上不是面向?qū)ο蟮木幊?,但VBSCRPIT6.0提供了類,我們可以通過類實(shí)現(xiàn)代碼的封裝,實(shí)現(xiàn)模塊話。

  首先,我要在這里寫上一些很官方的概念,意在說明面向?qū)ο笫呛芫唧w化的,很實(shí)體的模式,不能讓有些人看見“對(duì)象”就被嚇跑了。

  對(duì)象,就是能看到,感到,聽到,觸摸到,嘗到或聞到的東西,在這里我們這樣“定義”:對(duì)象是一個(gè)自包含的實(shí)體,用一組可識(shí)別的特性和行為來標(biāo)識(shí)。

  在面向?qū)ο蟮木幊?oop)的編程方式,用使用下面的兩個(gè)術(shù)語。

  類:這是對(duì)象的模板,定義了對(duì)象的特性。

  實(shí)例:這是一個(gè)真實(shí)的對(duì)象,可以與之交互的東西。

  屬性,方法和事件

  在OOP中,下面的術(shù)語描述對(duì)象的特性:

  屬性:這是一個(gè)名次,描述了某個(gè)對(duì)象的屬性。

  方法:這是一個(gè)動(dòng)詞,描述了對(duì)象可以完成的工作,或者希望它完成的工作。

  事件:描述了對(duì)象為相應(yīng)某個(gè)動(dòng)作而執(zhí)行的操作。

  在編程時(shí),對(duì)象的面向?qū)ο缶幊毯兔嫦驅(qū)ο笤O(shè)計(jì)的一部分,它們具有非常大的優(yōu)勢(shì),許多人認(rèn)為這是一個(gè)復(fù)雜的主題,但實(shí)際上,它非常簡單,可以用四個(gè)簡單的術(shù)語來解釋:抽象、封裝、多態(tài)和繼承。

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

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

  多態(tài):這個(gè)術(shù)語用于表示不同的對(duì)象可以執(zhí)行相同的動(dòng)作,但要通過他們自己的實(shí)現(xiàn)代碼來執(zhí)行,名稱一樣,但底層實(shí)現(xiàn)的代碼是不一樣的。

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

  在ASP中使用類,實(shí)現(xiàn)模塊化

  下面我通過舉上幾個(gè)簡單的例子說明一下,注意,這里強(qiáng)調(diào)的是一種思想,如果在您開發(fā)ASP網(wǎng)站的時(shí)候能用一個(gè)類(基類)展開的話,這是很有必要的(也是很有難度的)。

  我們先選擇一個(gè)簡單的例子:

  我們要顯示經(jīng)典論壇用戶的信息,當(dāng)輸入用戶的ID以后能,顯示出該用戶的一些信息,這是一個(gè)過程,可以這樣考慮,我們把用戶當(dāng)作一個(gè)對(duì)象,他有的屬性是ID,性別,積分,權(quán)限,實(shí)現(xiàn)的方法有顯示這些信息,ok,這樣寫:
Class blueidea
Private bname,bpoint,bsex,blevel
'...................
end class

  這里先聲明了一個(gè)名為 blueidea的類,接著是一些私有變量,用于存儲(chǔ)blueidea類的屬性,這些變量在代碼的外部不能訪問,這就是數(shù)據(jù)保護(hù),要定義這些變量,使用了property語句獲得值間接的付給私有變量
'-----------------------------------------------------------------
Property Get getname
getname=bname
End Property

Property Let getname(nameid)
bname=nameid
If nameid="" Then
bname="沒注冊(cè)用戶"
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
'------------------------------------------------------------------

  這里有個(gè)killint函數(shù),是判斷數(shù)據(jù)合法性的,它的原形是:
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

  該函數(shù)功能很明確,不再繁瑣說。 

由于我們要通過積分判斷用戶級(jí)別,這里定義了一個(gè)私有函數(shù):
Private Function getlevel()
bpoint=killint(bpoint,0,0)
If bpoint500 Then
blevel="初級(jí)會(huì)員"
ElseIf bpoint>=500 And bpoint=100 Then
blevel="高級(jí)會(huì)員"
Else
blevel="終極會(huì)員"
End If
Getlevel=blevel
End Function

  我們要得是回送用戶的信息,必須定義一個(gè)public公用函數(shù),顯示信息:
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>級(jí)別:font color=red>"blevel"/font>/h5>")
End Function
End class

  使用這個(gè)類的時(shí)候這樣使用:(我在這里寫了一個(gè)表單處理的)
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

  控制讀取數(shù)據(jù)庫信息的類:
  參考源碼
'名稱:ado_5do8
'作用:讀取數(shù)據(jù)庫的各項(xiàng)操作
'來源-耕耘村http://www.5do8.com http://www.Blueidea.com-5do8
'創(chuàng)作:5do8
'聯(lián)系:5do8@5do8.com
'更新:2005年11月13日
'授權(quán):藍(lán)色理想網(wǎng)站積分超過3000,耕耘村所有注冊(cè)用戶
'類的接口:ado_5do8.ConnectString=數(shù)據(jù)庫絕對(duì)路徑
'ado_5do8.rs_top 調(diào)用數(shù)目,表的名稱 
Class ado_5do8
Private conn,sqlstr,rs,iid,itable,isession
'sqlstr:數(shù)據(jù)庫地址,為絕對(duì)路徑,私有
'conn:打開數(shù)據(jù)庫的連接,私有

'------------------------------------------------------------------
rem 消除一些不想要的數(shù)字 
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="發(fā)生錯(cuò)誤,不能連接數(shù)據(jù)庫"
response.write(mess)
response.End
Else
mess="連接數(shù)據(jù)庫conn成功...........br/>"
response.write(mess)
End If
End Sub
'----------------------------------------------------------------
private Sub closeconn()
conn.close 
Set conn=Nothing
response.write("strong style='color:red'>關(guān)閉conn連接/strong>...hr/>")
End sub 
'-----------------------------------------------------------------
Private Sub closers()
rs.close
Set rs=Nothing
response.write("strong style='color:#085420'>關(guān)閉數(shù)據(jù)庫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>總數(shù)獲得了:")
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; '>較慢,不推薦點(diǎn)擊-->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

  使用的時(shí)候:
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>顯示信息總數(shù):input name="n" type="text" maxlength="4" size="10" />每頁數(shù)目: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>返回默認(rèn)模式/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'>頁面分析完畢,要更新請(qǐng)選擇a href=default.asp>回到典型模式/a>參數(shù):Start,開始元素;pageno,每頁條數(shù)/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 
%>

  演示在:http://www.5do8.com/net/aspclass

標(biāo)簽:萍鄉(xiāng) 衡水 棗莊 衢州 廣元 蚌埠 江蘇 大理

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用類,實(shí)現(xiàn)模塊化》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    保康县| 三都| 米泉市| 偏关县| 金平| 荣成市| 醴陵市| 海丰县| 遂川县| 彰武县| 阜城县| 金川县| 富裕县| 泸溪县| 微博| 于都县| 乐都县| 荣成市| 康马县| 繁峙县| 平乡县| 兰溪市| 睢宁县| 岳阳市| 洛阳市| 庆云县| 遂川县| 虎林市| 酉阳| 鹿邑县| 灵璧县| 区。| 胶南市| 刚察县| 康定县| 崇明县| 盐源县| 金山区| 浮梁县| 张掖市| 新源县|