网络编程 
首页 > 网络编程 > 浏览文章

ASP代码的对象化

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )
提起ASP很多人就认为是一堆HTML脚本和被括在<%和%>之中的一些代码还有就是一些JAVASCRIPT脚本等筹在一起的一些代码的集合,这样的代码,再加上各类的不同格式的注释,看起来就一个字:乱。也不管别人能不能看得懂,只要是能实现自己的目的就可以了。
  因为ASP的代码也是脚本,给了客户也不可能不被人看到其中的内容,经多包容在DLL中一部分业务逻辑,但是还是觉得ASP代码是最不值钱的代码,没有人回去购买,可以随时从别人的网站中查看源码的形式得到别人辛辛苦苦编写出来的独特风格的东东。这些原因使ASP的发展成为了一种编的快忘的也快的代码,可读性,维护性也是各种语言中最为差的代码。
     其实,ASP代码也可以像其他语言一样的面向对象,模块化,将很多页面集成封装到一个类中,运用类中的不同方法来显示不同的页面,这样你可以将同一业务逻辑下的页面和逻辑封装到一个类里,用不同的方法来实现。说了这么多,可能大家的思路都乱了,赶快给大家一点范例来看看:
复制代码 代码如下: 
<%
'****************************************
'* 类名:clsWebWorkFlowLog     
'* 功能:工作流日志跟踪类
'* History:       
'*  作成:doface     
'*  日期:2003/10/24 Ver 1.0  
'*  改动:                
'*  日期:
'****************************************
class clsWebWorkFlowLog
 '定义公开属性存放Connection对象
 public ActiveConnection

 private oResponse

 '========================================
 '= 过程名:main
 '= 参  数:
 '= 功 能:主调函数
 '=   根据不同动作参数执行不同的操作
 '= 返回值:
 '========================================
 sub main()
  select case Request("act")
  case "list"
    list()
   case else
    list()
  end select
 end sub

 '========================================
 '= 过程名:list
 '= 参  数:
 '= 功 能:显示列表画面
 '= 返回值:
 '========================================
 sub list()
  dim oRs
  set oRs = ActiveConnection.execute("select *,(select name from wf_config where id=w.wf_id) as wfname from wf_log w where step_id=1 and user_id=" & session("usr")("uid"))
  '(select * from wf_log where id in (select max(id),wf_id,tab_id,rec_id from wf_log group by wf_id,tab_id,rec_id where wf_id= and tab_id=))
  %>  <p align="left"><img border="0" src="/UploadFiles/2021-04-02/workflow-new.gif">  <center>
  <table bgColor="#FFFFFF" border="1" borderColorDark="#ffffff" borderColorLight="#c0c0c0" cellSpacing="0" width="99%" height="25">
   <tr>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">流程名称</font></td>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">申请人</font></td>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">申请时间</font></td>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">完成时间</font></td>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">状态</font></td>
    <td bgColor="#808080" height="15"><font color="#FFFFFF">操作</font></td>
   </tr><%
  do while not oRs.eof
   dim maxID,Next_id
   if glbFunc.getMaxID(oRs("id").value,ActiveConnection,maxID,Next_id) then
   %><tr>
   <td bgColor="#ffffff" height="19"><%=oRs("wfname")%></a></td>
   <td bgColor="#ffffff" height="19"><%=session("usr")("name")%>&nbsp;</td>
   <td bgColor="#ffffff" height="19"><%=oRs("exetime")%>&nbsp;</td>
   <td bgColor="#ffffff" height="19">&nbsp;</td>
   <td bgColor="#ffffff" height="19"><%=glbFunc.getCurZT(oRs("id").value,ActiveConnection)%></td>
   <td bgColor="#ffffff" height="19"><p align="left"><a href="../PubExeTab/PubExeTab.asp?act=view&tab_id=<%=oRs("tab_id")%>&id=<%=oRs("rec_id")%>"><img src="/UploadFiles/2021-04-02/view.gif">end if
   %></tr><%
   oRs.movenext
  loop
  %></table> 
  </center>
  <%
 end sub
end class
'****************************************
'* 类结束                               
'****************************************
'****************************************
'ASP页面开始       
'****************************************
'输出标准HTML头
glbFunc.writeHEAD
dim oWebWorkFlowLog
set oWebWorkFlowLog = new clsWebWorkFlowLog
set oWebWorkFlowLog.ActiveConnection = glbFunc.getADOConnection
oWebWorkFlowLog.main 
glbFunc.writeTail()
%> 
  
  可以添加更多的方法,这样这一个类就能完成以前多个ASP文件的功能。访问的时候,在 .ASP之后加上参数(要访问哪个函数)即可区分出来。
上一篇:ASP连接11种数据库语法总结
下一篇:FSO一些代码
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。