ASP 三层架构 Convert类实现代码

这个类主要解决在类型转换时,如果直接使用类型转换函数,会因为变量为空或者格式不对而导致程序报错,而这种报错在大多数情况下是允许的.例如要转换一个字符串变量为数字,如果变量为空,则一般需要自动返回0.

另外一个重要功能就是封装变量格式化操作,可以保持整个网站的输出格式统一,例如时间格式,货币格式等等. 日期和货币格式化的时候,极易遇到因空值报错的情况,一般都不得不写个预判断空值的逻辑,再格式化变量. 使用这个类负责类型转换和格式化输出后,就不用操心这些琐碎的细节了,可以让编程的心情得到大大改善啊.

还有些其他格式化功能,也加了进去,例如Convert.ToPer()是用来转换数字成百分数,Convert.FirstUppercase()用来做首字母大写...... 你可以根据自己的需要,随时扩展这个类,不要忘记了和大家分享哦.

有些基本的函数,如果随便写一写,基本可以凑合着用,但是遇到特殊情况,就要重新改写.比如我写的Convert.ToInt()方法,将变量转换为Integer. 最基本的操作,是判断一下是否为空,不为空就直接用Cint()就可以了. 但是遇到变量超出了范围,又得判断是否在Integer范围内,所以又写了一个私有方法IsOverflowInteger(),用于判断变量值是否为某一个范围内的数字.经过这样的处理,相信基本可以处理所有的情况了.

所以我想,Convert类中的已有方法还是会有不少需要改善的,大家如果有更好更完善的函数请发上来分享,让它形成ASP中最标准的变量处理的类,再不用依赖ASP中那些有限的功能了.

如下列举一些比较主要的方法,具体细节请看代码.

类型判断:

Convert.IsInteger(ByVal Value) 判断是否整数,只允许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)

类型转换:

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) 数字格式化

其他格式化:

Convert.ToPer(Byval value,Byval value0) 百分数,带%

Convert.FirstUppercase(ByVal value) 首字母大写

Convert.SafeSql(ByVal value) 替换sql中的'为''

代码如下: (我不会插入代码,不知道CSDN是怎么操作的,点插入代码就是一个<textarea>,而不是可以折叠代码的风格,向了解的朋友请教.)

复制代码 代码如下:

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

时间: 2024-08-30 04:24:40

ASP 三层架构 Convert类实现代码的相关文章

ASP 三层架构 Convert类实现代码_应用技巧

这个类主要解决在类型转换时,如果直接使用类型转换函数,会因为变量为空或者格式不对而导致程序报错,而这种报错在大多数情况下是允许的.例如要转换一个字符串变量为数字,如果变量为空,则一般需要自动返回0. 另外一个重要功能就是封装变量格式化操作,可以保持整个网站的输出格式统一,例如时间格式,货币格式等等. 日期和货币格式化的时候,极易遇到因空值报错的情况,一般都不得不写个预判断空值的逻辑,再格式化变量. 使用这个类负责类型转换和格式化输出后,就不用操心这些琐碎的细节了,可以让编程的心情得到大大改善啊.

ASP 三层架构 Error处理类_应用技巧

从这节开始,将会给大家介绍几个ASP中的三大通用类,它贯穿于我所设计的三层架构中,是对ASP语法的扩展,可以提高很多细节处理上的效率,可以算是一点点框架的味道. 本节介绍错误处理类,类名Con_Error,在代码页面之初就进行初始化,实例名为e,以下的e.add 即使用该错误类的实例化对象进行操作. 方法介绍: e.Add(ByVal vErrorMessage ) 记录一个错误,并且设置 e.Error = true . 在程序检测用户名合法性等地方发现错误时,就调用这个方法,记录一个错误信息

ASP 三层架构 Error处理类

从这节开始,将会给大家介绍几个ASP中的三大通用类,它贯穿于我所设计的三层架构中,是对ASP语法的扩展,可以提高很多细节处理上的效率,可以算是一点点框架的味道. 本节介绍错误处理类,类名Con_Error,在代码页面之初就进行初始化,实例名为e,以下的e.add 即使用该错误类的实例化对象进行操作. 方法介绍: e.Add(ByVal vErrorMessage ) 记录一个错误,并且设置 e.Error = true . 在程序检测用户名合法性等地方发现错误时,就调用这个方法,记录一个错误信息

实现ASP程序执行时间统计类的代码_ASP CLASS类

第一次写ASP类,实现功能:分段统计程序执行时间,输出统计表等.  复制代码 代码如下: Class ccClsProcessTimeRecorder  '程序作者:明月星光  '作者主页:http://www.5iya.com/blog  'http://www.kuozhanming.com  'ASP程序代码执行时间统计类    Private ccInti,ccIntNonceTime,ccIntDecimal    Private ccIntStartTime,ccIntEndTime

ASP.NET三层架构详解 如何实现三层架构_实用技巧

一.数据库 /*==============================================================*/ /* DBMS name: Microsoft SQL Server 2000 */ /*==============================================================*/ if exists (select 1 from sysobjects where id = object_id('newsConte

如何在ASP.NET中使用三层架构

  学ASP.NET都知道它的最经典的架构是三层架构,也是目前应用得最广泛的一种架构.以前说起三层架构大家都知道MVC架构,这是html开发中用得比较多的,现在AJAX主要就是用这种架构.大家ASP.NET的三层是指数据访问层,业务逻辑层和表示层,而且都知道数据访问层是用来访问数据的,业务逻辑层是用来处理一些系统的业务逻辑的,表示层就是把内容呈现出来给用户,与用户进行交互的.划分三层的好处就是每一层都是独立的,修改其中一层一般不会影响其他层的代码,这样就大大的方便了日后的维护和升级.它最大的缺点

ASp.net 剖析三层架构

转自:http://blog.sina.com.cn/s/blog_5ea9354f0100dea0.html 三层实现的留言和查看留言 本文不是从理论的角度来探讨三层架构,而是用一个示例来介绍如何建设一个三层架构的项目,并说明项目中各个文件所处的层次与作用.写本文的目的,不是为了说明自己的这个方法有多对,别人的肯定不对,而是希望给那些初学三层架构却不知从何入手的朋友提供一点帮助.因为网上的文章,大多是注重理论的介绍,而忽略了具体的实践应用,或者有示例但讲得不透彻.导致看了之后,理论上又学习了一

ASP.NET 三层架构使用IDAL 接口层有什么作用,有和妙用,使用业务逻辑层BLL直接调用数据层DAL不可以嘛。

问题描述 我们通常是UIweb层调用BLL层,BLL层调用DAL达到数据的交换.但是看到大多数项目是有个IDAL接口,只是声明方法没有任何的代码实现部分,代码实现部分都放在了DAL层,然后BLL层去调用IDAL接口层的方法实现,并没有去调用DAL层,UI层调用BLL层,这里的接口层有和作用,请教各位帮忙解答,不胜感激! 解决方案 解决方案二:IDAL是DAL层的类要实现的接口.DAL层的各类需要完成对数据库的访问,但是不同的数据库需要使用不同的DAL对象,这样对于BLL层来说无法实现数据库无关性

ASP.NET存储过程实现分页效果(三层架构)_实用技巧

本文实例为大家分享了ASP.NET存储过程实现分页的具体代码,供大家参考,具体内容如下 实现效果: 文本框内输入跳转的页数,点击GO会跳转到该页 首先在项目下加入BLL,DAL,DataAccess,MODEL类库1.前台界面 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="原始刷新分页.aspx.cs" Inherits="分页.原始刷新分页" %&g