|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
使用filesystemobject,可以对服务器上的文件进行操作,浏览、复制、移动、删除等。有ado的支持,asp对数据库的操作非常得心应手。你甚至可以像使用本地数据库那样,管理远程主机上的数据库,对表格、记录进行各种操作。模板 在内容体系开辟中,触及内容和模式分别的进程,也就是依据用户自界说页面模板然后交换成相干内容的进程。这和里面良多整站的内容办理体系,有实质上的区分。有很多内容办理体系,几何人用,都是一个模样,由于页面没法自界说,不懂编程的用户没法修正。象那种,只填几个参数就出来的网站,我估量是没有甚么出路的。由于人人都是一个模样,人人都是会填那些参数的。
举个例子,你检查一下以下几个站点,你会以为他们是一套法式吗?
www.blueidea.com
http://pages.blueidea.com
http://digi.blueidea.com
http://wuyi.digichina.net
http://www.dcshooter.com
假如我告知你,他们都是一个法式,只是由相干的站长,设计分歧的模板失掉的页面显示,你就会发明,这个体系的优秀性。
固然因为这套体系的高端性,今朝通俗用户没法利用,因而我开辟了我本人的内容办理体系 kiss 内容办理体系。人人可以会见 http://aston.blueidea.com
而要给用户一个模板体系,起首,就是要有一个复杂易懂的标志体系。人人看看上面的代码,看是不是轻易了解:
<tag:loop channelid="1" pagesize="10" title="20" type="NEW" column="1">
略有HTML经历的人,就晓得,这是一个模板标志里的轮回标志,由于这是最经常使用的,你看咱们网站的首页,列出10条则档也就只需求写一个如许的标志就完成了,这是否是让不分明编程的人,也很轻易做出本人设计的页面出来呢?
参数申明:
channelid 为一个栏目标在数据库中的ID
pagesize 为罗列几何个文档
title 为题目的长度
type 为列表列型,这里的”NEW”咱们设定为最新的文档
column 为显示几列
以上引见是给不会编程,或对不懂得内容体系的人做个普及,而且给我的内容办理体系打个告白,并且我想说的是,蓝色幻想站点用的内容办理体系模板模块,要比我的壮大良多。
上面轮到法式员了,其它人可以不必往下看。
那末怎样把它们的值读出来呢?
上面这个函数是最初的,用来解析一切模板的内容
代码拷贝框
'【功效】自界说模板标签Function ProcessCustomTags(ByVal sContent) Dim objRegEx, Match, Matches '创立正则表达式 Set objRegEx = New RegExp '查找内容 objRegEx.Pattern = "<tag:.*/>" '疏忽巨细写 objRegEx.IgnoreCase = True '全局查找 objRegEx.Global = True 'Run the search against the content string we've been passed Set Matches = objRegEx.Execute(sContent) '轮回已发明的婚配 For Each Match in Matches 'WordStr each match with the appropriate HTML from our ParseTag function sContent = WordStr(sContent, Match.Value, ParseTag(Match.Value)) Next '消毁对象 set Matches = nothing set objRegEx = nothing '前往值 ProcessCustomTags = sContentEnd Function
[Ctrl+A 全体选择 然后拷贝]
在下面的代码中,用到了正则表达式,假如你对它还不是很懂得,请参阅相干材料,这里就不具体引见了。
那末怎样掏出参数值呢,也是一个函数:
代码拷贝框
'【功效】获得模板标签的参数名'如:<tag:loop channelid="1" pagesize="10" title="20" type="NEW" column="1">function GetAttribute(ByVal strAttribute, ByVal strTag) Dim objRegEx, Matches '创立正则表达式 Set objRegEx = New RegExp '查找内容 (the attribute name followed by double quotes etc) objRegEx.Pattern = lCase(strAttribute) & "=""[0-9a-zA-Z]*""" '疏忽巨细写 objRegEx.IgnoreCase = True '全局查找 objRegEx.Global = True '履行搜刮 Set Matches = objRegEx.Execute(strTag) '若有婚配的则前往值, 否则前往空值 if Matches.Count > 0 then GetAttribute = Split(Matches(0).Value,"""")(1) else GetAttribute = "" end if '消毁对象 set Matches = nothing set objRegEx = nothingend function
[Ctrl+A 全体选择 然后拷贝]
OK好了,那怎样解析像下面<tagloop:>内容呢?
上面就是一个函数:
代码拷贝框
'【功效】解析并交换响应的模板标签内容function ParseTag(ByVal strTag) dim arrResult, ClassName, arrAttributes, sTemp, i, objClass '假如标签是空的则加入函数 if len(strTag) = 0 then exit function 'Split the match on the colon character (:) arrResult = Split(strTag, ":") 'Split the second item of the resulting array on the space character, to 'retrieve the name of the class ClassName = Split(arrResult(1), " ")(0) 'Use a select case statement to work out which class we're dealing with 'and therefore which properties to populate etc select case uCase(ClassName) 'It's a loop class, so instantiate one and get it's properties case "LOOP" set objClass = new LOOP_Class LOOP.Channelid= GetAttribute("channelid", strTag") LOOP.Pagesize= GetAttribute("pagesize", strTag") LOOP.title = GetAttribute("title", strTag") LOOP.type = GetAttribute("Type", strTag") ParseTag = LOOP.column (GetAttribute("column", strTag"), true) 'Destroy our class object set objClass = nothing end selectend function
[Ctrl+A 全体选择 然后拷贝]
下面的loop是一个类,这里也不再详说了。由于很久没有措辞了,不太习气,呵呵。
结论,经由过程下面的函数,你可以很快的编写相干的模板法式了。但愿对你有匡助。
因为ASP脚本语言非常简单,因此其代码也简单易懂,结合HTML代码,可快速地完成网站的应用程序。还无法完全实现一些企业级的功能:完全的集群、负载均横。 |
|