国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > ASP > 正文

ASP 三層架構(gòu) Convert類實(shí)現(xiàn)代碼

2024-05-04 11:08:46
字體:
供稿:網(wǎng)友
第二個重要的類,作用是類型轉(zhuǎn)換,類名Con_Convert.在頁面代碼的開頭實(shí)例化,對象名為Convert,借用了.net的類型轉(zhuǎn)換的對象名稱.
 
 
 
這個類主要解決在類型轉(zhuǎn)換時,如果直接使用類型轉(zhuǎn)換函數(shù),會因為變量為空或者格式不對而導(dǎo)致程序報錯,而這種報錯在大多數(shù)情況下是允許的.例如要轉(zhuǎn)換一個字符串變量為數(shù)字,如果變量為空,則一般需要自動返回0. 
另外一個重要功能就是封裝變量格式化操作,可以保持整個網(wǎng)站的輸出格式統(tǒng)一,例如時間格式,貨幣格式等等. 日期和貨幣格式化的時候,極易遇到因空值報錯的情況,一般都不得不寫個預(yù)判斷空值的邏輯,再格式化變量. 使用這個類負(fù)責(zé)類型轉(zhuǎn)換和格式化輸出后,就不用操心這些瑣碎的細(xì)節(jié)了,可以讓編程的心情得到大大改善啊. 
還有些其他格式化功能,也加了進(jìn)去,例如Convert.ToPer()是用來轉(zhuǎn)換數(shù)字成百分?jǐn)?shù),Convert.FirstUppercase()用來做首字母大寫...... 你可以根據(jù)自己的需要,隨時擴(kuò)展這個類,不要忘記了和大家分享哦. 
有些基本的函數(shù),如果隨便寫一寫,基本可以湊合著用,但是遇到特殊情況,就要重新改寫.比如我寫的Convert.ToInt()方法,將變量轉(zhuǎn)換為Integer. 最基本的操作,是判斷一下是否為空,不為空就直接用Cint()就可以了. 但是遇到變量超出了范圍,又得判斷是否在Integer范圍內(nèi),所以又寫了一個私有方法IsOverflowInteger(),用于判斷變量值是否為某一個范圍內(nèi)的數(shù)字.經(jīng)過這樣的處理,相信基本可以處理所有的情況了. 
所以我想,Convert類中的已有方法還是會有不少需要改善的,大家如果有更好更完善的函數(shù)請發(fā)上來分享,讓它形成ASP中最標(biāo)準(zhǔn)的變量處理的類,再不用依賴ASP中那些有限的功能了. 
如下列舉一些比較主要的方法,具體細(xì)節(jié)請看代碼. 
類型判斷: 
Convert.IsInteger(ByVal Value) 判斷是否整數(shù),只允許0~9和-號 
Convert.IsInt(ByVal Value) 判斷是否int型,其下類似,不用解釋了. 
Convert.IsLng(ByVal Value) 
Convert.IsDecimal(ByVal Value) 
Convert.IsSng(ByVal Value) 
Convert.IsDbl(ByVal Value) 
Convert.IsCur(ByVal Value) 
Convert.IsBln(ByVal Value) 
Convert.IsDat(ByVal Value) 
Convert.IsArr(ByVal Value) 
類型轉(zhuǎn)換: 
Convert.ToStr(ByVal Value) 
Convert.ToInt(ByVal Value) 
Convert.ToLng(ByVal Value) 
Convert.ToSng(ByVal Value) 
Convert.ToDbl(ByVal Value) 
Convert.ToBln(ByVal Value) 
Convert.ToCur(ByVal Value) 
Convert.ToDat(ByVal Value) 
格式化: 
Convert.FormatDat(ByVal Value, ByVal vStyle) 日期格式化 
Convert.FormatCur(ByVal Value,ByVal vDecimal) 貨幣格式化 
Convert.FormatNum(ByVal Value,ByVal vDecimal) 數(shù)字格式化 
其他格式化: 
Convert.ToPer(Byval value,Byval value0) 百分?jǐn)?shù),帶% 
Convert.FirstUppercase(ByVal value) 首字母大寫 
Convert.SafeSql(ByVal value) 替換sql中的'為'' 
代碼如下: (我不會插入代碼,不知道CSDN是怎么操作的,點(diǎn)插入代碼就是一個<textarea>,而不是可以折疊代碼的風(fēng)格,向了解的朋友請教.) 
復(fù)制代碼代碼如下:

Class Con_Convert 
' ******global message 
private i,j,value0,value1,value2 
Private Sub Class_Initialize 
End Sub 
Private Sub Class_Terminate 
End Sub 
' ============================================================================== 
' Check Type, Return ture/false 
' ============================================================================== 
Public Function IsStr(ByVal Value) 
IsStr=true 
End Function 
' ****** check string if is Integer 
Public Function IsInteger(ByVal Value) 
if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then 
IsInteger=false 
else 
IsInteger = True 
value0=Trim(Value) 
For i = 1 To len(value0) 
If Asc(Mid(value0, i, 1))>= Asc("0") and Asc(Mid(value0, i, 1)) <= Asc("9") Then 
Else 
if Asc(Mid(value0, i, 1))= Asc("-") and i=1 then 
else 
IsInteger = false 
Exit For 
end if 
End If 
Next 
end if 
End Function 
' ****** check if Value is in range of integer 
' Only use in this class 
' Value : 
' vBound : max 
Private Function IsOverflowInteger(ByVal Value,ByVal vBound) 
if IsInteger(Value) and IsInteger(vBound) then 
IsOverflowInteger=false 
value0=trim(value) 
value1=trim(vBound) 
if IsOverflowInteger=false then 
'delete 0 from left 
do while ( left(value0,1)="0" or left(value0,1)="-" ) 
value0=right(value0,len(value0)-1) 
loop 
do while ( left(value1,1)="0" or left(value1,1)="-" ) 
value1=right(value1,len(value1)-1) 
loop 
if len(value0)=len(value1) then 
for i=1 to len(value0) 
if Asc(mid(value0,i,1)) > Asc(mid(value1,i,1)) or Asc(mid(value0,i,1)) > Asc("9") or Asc(mid(value0,i,1)) < Asc("0") then 
IsOverflowInteger=true 
exit for 
end if 
next 
else 
if len(value0)>len(value1) then 
IsOverflowInteger=true 
end if 
end if 
end if 
else 
IsOverflowInteger=true 
end if 
End Function 
Public Function IsInt(ByVal Value) 
IsInt=true 
if left(trim(value),1)="-" then 
if IsOverflowInteger(trim(value),"-32768") then 
IsInt=false 
end if 
else 
if IsOverflowInteger(trim(value),"32767") then 
IsInt=false 
end if 
end if 
end function 
Public Function IsLng(ByVal Value) 
IsLng=true 
if left(trim(value),1)="-" then 
if IsOverflowInteger(trim(value),"-2147483648") then 
IsLng=false 
end if 
else 
if IsOverflowInteger(trim(value),"2147483647") then 
IsLng=false 
end if 
end if 
End Function 
' ************************************** 
' Decimal 
' ************************************** 
' ****** check string if is Decimal 
Private Function IsDecimal(ByVal Value) 
dim intDecimalCount 
intDecimalCount=0 
if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then 
IsDecimal=false 
else 
IsDecimal = True 
value0=Trim(Value) 
For i = 1 To len(value0) 
If Asc(Mid(value0, i, 1))>= Asc("0") and Asc(Mid(value0, i, 1)) <= Asc("9") Then 
Else 
select case Asc(Mid(value0, i, 1)) 
case Asc("-") 
if i=1 then 
else 
IsDecimal = false 
Exit For 
end if 
case Asc(".") 
if intDecimalCount<2 then 
intDecimalCount=intDecimalCount + 1 
else 
IsDecimal = false 
Exit For 
end if 
case else 
IsDecimal = false 
Exit For 
end select 
End If 
Next 
end if 
End Function 
' ****** check if Value is in range of Decimal 
' Only use in this class 
' Value : 
' vBound : 
Private Function IsOverflowDecimal(ByVal Value,ByVal vBound) 
if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) or Trim(vBound)="" or IsNull(vBound) or IsEmpty(vBound) then 
IsOverflowDecimal=true 
else 
end if 
End Function 
Public Function IsSng(ByVal Value) 
IsSng=IsDecimal(value) 
' -340282300000000000000000000000000000000 ~ -0.000000000000000000000000000000000000000000001401298 
' 0.000000000000000000000000000000000000000000001401298 ~ 340282300000000000000000000000000000000 
' -3.402823 E38 ~ -1.401298 E-45 
' 1.401298 E-45 ~ 3.402823 E38 
End Function 
Public Function IsDbl(ByVal Value) 
IsDbl=IsDecimal(value) 
' -1.79769313486232 E308 ~ -4.94065645841247 E-324 
' 4.94065645841247 E-324 ~ 1.7976931348623 E308 
End Function 
Public Function IsCur(ByVal Value) 
IsCur=IsDecimal(value) 
'-922337203685477.5808 ~ 922337203685477.5807 
End Function 
Public Function IsBln(ByVal Value) 
if Value=true or Value=false or trim(Value)="1" or trim(Value)="0" then 
IsBln=true 
else 
IsBln=false 
end if 
End Function 
Public Function IsDat(ByVal Value) 
if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then 
IsDat=false 
else 
IsDat=IsDate(Value) 
end if 
End Function 
Public Function IsArr(ByVal Value) 
if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then 
IsArr=false 
else 
IsArr=IsArray(Value) 
end if 
End Function 
' ============================================================================== 
' Convert Type, Return value/initial value 
' ============================================================================== 
Public Function ToStr(ByVal Value) 
ToStr=trim(Value) 
End Function 
Public Function ToInt(ByVal Value) 
if IsInt(Value) then 
ToInt=Cint(Value) 
else 
ToInt=0 
end if 
End Function 
Public Function ToLng(ByVal Value) 
if IsLng(Value) then 
ToLng=clng(Value) 
else 
ToLng=0 
end if 
End Function 
Public Function ToSng(ByVal Value) 
if IsSng(Value) then 
ToSng=cSng(Value) 
else 
ToSng=0 
end if 
End Function 
Public Function ToDbl(ByVal Value) 
if IsDbl(Value) then 
ToDbl=cDbl(Value) 
else 
ToDbl=0 
end if 
End Function 
Public Function ToBln(ByVal Value) 
if IsBln(Value) then 
ToBln=cbool(Value) 
else 
ToBln=false 
end if 
End Function 
' ****** vDecimal : number of decimal places 
Public Function ToCur(ByVal Value) 
if IsCur(Value) then 
ToCur=ccur(Value) 
else 
ToCur=0 
end if 
End Function 
' ****** vType : format of date 
Public Function ToDat(ByVal Value) 
if IsDat(Value) then 
ToDat=cdate(value) 
else 
ToDat="" 
end if 
End Function 
' ============================================================================== 
' Format 
' ============================================================================== 
' ******************************************************* 
'FormatDat 
'vdate 
'vStyle 0:2008-1-30 1:2008/1/30 2:1/30/2008 3:30/1/2008 4:30-JAN-2008 
' 10:2008-1 11:2008/1 12:1/2008 
' 22:JAN-2008 
' 30:2008-1-30 11:20:20 
' 40:2008-01-09 
Public Function FormatDat(ByVal Value, ByVal vStyle) 
dim dateThis,intStyle 
dateThis=ToDat(Value) 
intStyle=ToInt(vStyle) 
if dateThis="" or isnull(dateThis) then 
FormatDat = "" 
else 
Dim arrMonthArray(12) 
arrMonthArray(1)="JAN" 
arrMonthArray(2)="FEB" 
arrMonthArray(3)="MAR" 
arrMonthArray(4)="APR" 
arrMonthArray(5)="MAY" 
arrMonthArray(6)="JUN" 
arrMonthArray(7)="JUL" 
arrMonthArray(8)="AUG" 
arrMonthArray(9)="SEP" 
arrMonthArray(10)="OCT" 
arrMonthArray(11)="NOV" 
arrMonthArray(12)="DEC" 
select case intStyle 
case 1 
FormatDat=cstr(year(dateThis)) &"/"& cstr(month(dateThis)) &"/"& cstr(day(dateThis)) 
case 2 
FormatDat= cstr(month(dateThis)) &"/"& cstr(day(dateThis)) &"/"& cstr(year(dateThis)) 
case 3 
FormatDat= cstr(day(dateThis)) &"/"& cstr(month(dateThis)) &"/"& cstr(year(dateThis)) 
case 4 
FormatDat= cstr(day(dateThis)) &"-"& arrMonthArray(month(dateThis)) &"-"& cstr(year(dateThis)) 
case 10 
FormatDat=cstr(year(dateThis)) &"-"& cstr(month(dateThis)) 
case 11 
FormatDat=cstr(year(dateThis)) &"/"& cstr(month(dateThis)) 
case 12 
FormatDat= cstr(month(dateThis)) &"/"& cstr(year(dateThis)) 
case 22 
FormatDat= arrMonthArray(month(dateThis)) &"-"& cstr(year(dateThis)) 
case 30 
FormatDat= cstr(year(dateThis)) &"-"& cstr(month(dateThis)) &"-"& cstr(day(dateThis)) &" "& hour(dateThis) &":"& minute(dateThis) &":"& second(dateThis) 
case 40 
FormatDat=cstr(year(dateThis)) &"-"& ZeroPad(cstr(month(dateThis)),2) &"-"& ZeroPad(cstr(day(dateThis)),2) 
case else 
FormatDat=cstr(year(dateThis)) &"-"& cstr(month(dateThis)) &"-"& cstr(day(dateThis)) 
end select 
end if 
End Function 
' ************** 
'FormatCur 
' ************** 
Public Function FormatCur(ByVal Value,ByVal vDecimal) 
FormatCur=Formatcurrency(ToCur(Value),ToInt(vDecimal)) 
End Function 
Public Function FormatNum(ByVal Value,ByVal vDecimal) 
FormatNum=FormatNumber(ToDbl(Value),ToInt(vDecimal)) 
End Function 
' ============================================================================== 
' other format 
' ============================================================================== 
Public Function ToPer(Byval value,Byval value0) 
if Convert.ToDbl(value0)<>0 then 
ToPer = me.FormatNum( Convert.ToDbl(value) / Convert.ToDbl(value0) * 100,2 ) & "% " 
else 
ToPer = "0.00%" 
end if 
End Function 
' ****** value -> Value first code change to uppercase 
Public Function FirstUppercase(ByVal value) 
value0 = trim(value) 
if len(value0)=0 then 
FirstUppercase = "" 
else 
FirstUppercase = UCase(left(value0,1)) & right(value0,len(value0)-1) 
end if 
End Function 
Public Function SafeSql(ByVal value) 
SafeSql = replace(value,"'","''") 
End Function 
End Class 

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
丁香综合五月| 成人精品福利| 国产精品乱码一区二区三区视频| 国产裸舞福利在线视频合集| 国产麻豆精品入口在线观看| 成人午夜无人区一区二区| 国产免费福利| 91这里只有精品| eeuss影院在线观看第一页| 精品孕妇一区二区三区| 国产亚洲精品一区二区在线观看| 国产免费专区| 在线午夜影院| 五月婷婷在线观看| 夜夜嗨yeyeh| 中文字幕国产在线| av免费在线播放| 最近最好的中文字幕2019免费| 国产福利电影在线观看| 黄色毛片在线看| 精精国产xxxx视频在线中文版| 国产在线观看a视频| 18激情网站| 国产鲁鲁视频在线观看特色| av免费在线一区二区三区| 丁香花视频在线观看| 91香蕉视频免费在线观看| 精品中文字幕不卡在线视频| 在线黄色国产电影| 国产精品99999| 国产网站在线免费观看| 成年人在线观看| 精品美女视频在线观看免费软件| 激情亚洲综合网| 亚洲精品乱码电影在线观看| 国产福利片在线| 国产精品你懂的在线观看| 国产毛片毛片| 国产麻豆免费| 最近久乱中文字幕| 中文字幕亚洲免费| 国产69久久| 国产免费av高清在线| 懂色一区二区三区| 五月婷婷导航| 国产精品白浆流出视频| 国产精品扒开做爽爽爽的视频| 五月婷婷导航| 国产特级淫片免费看| 国产精品被窝福利一区| 国产黄色片大全| 在线观看精品视频一区二区三区| 伊人色综合网| 免费三级毛片| 资源视频在线播放免费| 国产无遮挡又黄又爽免费网站 | 国产高清视频免费最新在线| 国产一起色一起爱| 国产黄色网页| 亚洲xxxxxx| 国产麻豆免费| 精品国内一区二区三区免费视频| 亚洲私人影吧| 国产一卡二卡3卡4卡四卡在线| 国产高清视频免费最新在线| eeuss影影院www在线播放| 美女av在线播放| 国产馆av播放| 激情丁香在线| 在线免费看av| 国内a∨免费播放| 精品一区二区在线欧美| 国产在线观看a视频| 精品99又大又爽又硬少妇毛片| 黄色毛片在线观看| 伊人影院在线观看| 最新天堂资源在线| www.国产精| 99中文字幕一区| 国产午夜在线| 国产精品一区牛牛影视| 亚洲综合在线不卡| 2020国产在线视频| 午夜视频在线免费 | 国产精品第八页| 欧美日韩**字幕一区| 国产成人福利| 国产三级在线播放| 综合图区亚洲白拍在线| 免费三级毛片| 日本调教视频在线观看| 中文资源在线网| 国产日韩精品在线看| 激情五月色综合亚洲小说| 天天干天天摸| 欧美日韩视频精品一区二区| 亚洲男人网站| av在线播放网| 日本视频一二三区中文字幕| 国产超碰在线观看| 国产jizz| 亚洲欧洲成人| 另类综合图区| 99视频免费| 国产午夜精品一区理论片| 日本中文字幕在线观看| 国产一级在线观看www色| 午夜视频99| 国产福利片在线| 精品欧美日韩一区二区| 伊人网在线视频| 亚色视频在线观看| 久热免费在线视频| 综合激情丁香| 国产精品一品| 国产福利在线免费观看| 91激情在线| 超碰免费97在线观看| 丁香花高清视频完整版在线观看| 国产乱子视频| 国产超碰97| 免费a级在线播放| 最近中文av字幕在线中文| 精品国产高清a毛片无毒不卡| 青青草免费在线视频| 午夜伦全在线观看| 91亚洲天堂| 男人天堂亚洲| 91激情在线| 亚洲人成电影| 午夜国产视频| 日本成人免费网站| 国产精品视频一区二区图片| 日本黄色免费网址| 国产精品免费视频二三区| 免费高清视频日韩| 99爱视频在线观看| 大香伊人中文字幕精品| 在线免费观看黄色片| 浪潮av一区| 亚洲精品一区中文字幕电影| 中文字幕在线视频观看| 男人操女人免费网站| 伊人网在线视频| 国产精品美女一区二区三区四区| 日本国产在线| 日日夜夜中文字幕| av激情在线| 在线色视频网| 精品入口麻豆传煤| 国产成人精品自线拍| 国产精品入口免费麻豆| 午夜视频在线免费| 高清av在线| 国产精品探花在线| 欧美黑人乱大交| 久热中文字幕在线观看| 男人天堂99| 免费av在线| www中文字幕在线观看| 精品亚洲成a人片在线观看| 国产美女一区视频| 超碰国产在线| 成人亚洲一区二区三区| 国产女王在线**视频 | 牛牛在线精品视频| 亚洲欧美日韩综合精品网| 中文字幕2019第三页| 一个人看的www免费观看视频| 精品视频一二区| 在线视频观看你懂的| 四虎一区二区三区| 九九热在线观看| 国产性一级片| 在线一区二区三区精品| 亚洲精品在线播放视频| 四虎成人免费| 五月婷婷在线视频| 精品无吗乱吗av国产爱色| av麻豆国产| 久热av在线| 国产黄色网页| 波多野结衣久久高清免费| 天堂资源最新在线| av福利在线| 国产美女被草| 羞羞视频在线观看免费| 成网站在线观看人免费| 91视频久色| 国产在线第一页| av丝袜在线| 国产三级在线观看| 日韩精品免费一区二区| 中文字幕有码在线视频| 在线观看国产福利视频| 狠狠操狠狠色| av在线免费播放网站| 国产视频一二区| 日本久久网站| 91麻豆精品国产91久久|