ASP脚本变量、函数、过程和条件语句
在上一期中作者向诸位简要介绍了 asp 脚本语言之一 vbscript 的一些基本常识,本期将继续给大家讲解 vbscript 的脚本编写方法,并通过展示 vbscript 在 asp 程序编写过程中的一系列实例使大家对 vbscript 有更进一层的理解。
大家在学习了脚本语言 vbscript 的变量、常量和过程的基本概念后,本期将继续向各位介绍 vbscript 的函数和语法。
函数和过程一样都是命名了的代码块,但它们却有很大的区别,过程完成程序任务,函数则返回值。我们可以这样理解,过程象一个完整的句子,而函数则象一个单词。举个例子,当你想获取某个数的平方根,你只要将该数传给 vbscript 的 sqr() 函数,此函数会立即返回该数的平方根。如:
a=sqr(9)
则 a=3。熟练掌握脚本语言的函数将给你编写 asp 程序带来极大的方便,就以上一期结尾处作者布置给大家的课后练习来说,如果你对脚本语言的函数掌握不够全面,那么解决如此之小的一个问题将很有可能花费你相当大的精力。现在让我们来回顾一下这道课后练习。
“作者正在用 asp 制作一套基于 web 的 bbs ,希望能在其中添加一项特殊功能,即当任何用户登陆该 bbs 后都能够查阅近七天来所有新发布的信息。”
如果你不熟悉 vbscrip,就不会知道 vbscrip 本身提供了一个用来取得日期之间的差或和的函数 dateserial,它的语法如下:
dateserial(year, month, day)
如果你要指定一个日期,例如:1998 年11月10日,那么 dateserial 函数中每个参数的取值范围都应该是可接受的,即日的取值应在1和31之间,月的取值应在1和12之间。但是,也可以使用表示某日之前或之后的年、月、日数目的数值表达式为每个参数指定相对日期。以下样例中使用了数值表达式代替绝对日期。在这里,dateserial 函数返回1998年11月10日之前二十年 (1990-20) 零两个月 (11-2) 又一天 (10-1) 的日期:即 1978 年9月9日。程序如下:
datep=dateserial(1998-20, 11-2,10-1)
对于 year 参数,若取值范围是从 0 到99,则被解释为 1900 到 1999 年。对于此范围之外的 year 参数,则使用四位数字表示年份(例如 1800 年)。当任何一个参数的取值超出可接受的范围时,则会适当地进位到下一个较大的时间单位。例如,如果指定了35 天,则这个天数将被解释成一个月加上多出来的日数,多出来的日数取决于其年份和月份。但是如果参数值超出 -32,768 到 32,767 的范围,或者由三个参数指定(无论是直接还是通过表达式指定)的日期超出了可以接受的日期范围,就会发生错误。
当我们了解并掌握了函数 dateserial 的使用方法后,再来看看作者布置的这道题目,一切就迎刃而解了。下面我将程序中的此部分代码公布如下: itemp=dateserial(year(date), month(date), day(date)-7)
itemp=datevalue(itemp)
sql="select * from message where message.creatime between #"&date&"# and #"&itemp&"# "
在这里我们又接触到了一组函数 year,month,day,它们是用来得到一个日期的年、月、日。date 是常数,表示今天日期,而函数 datevalue 则是将字符串变量转化为日期格式的变量。在本段程序的第三行,我们第一次接触到了标准的 sql 查询语句,这句语句是什么意思呢?
“select”是标准的 sql 查询命令,通过 select 语句我们可以在数据库中检索数据,并将查询结果提供给用户,此处的“*”表示查询该名为“message”的数据库中的所有记录,而“where”的作用是设定一个查询条件,是为了将数据库中符合条件的记录取出来,“message.creatime”是一个储存了数据库中记录创建日期的变量。将整句语句连起来理解就是:查询名为 message 的数据库中的所有记录,并将其中创建日期在今天和今天以前七日以内的所有记录存储在变量 sql 中。可能由于大家第一次接触 sql 语句,一时间无法完全理解它的作用,不过不用担心在今后的章节中作者将专门用一期给大家介绍 sql 的使用方法。
通过上面的学习,大家应该已经能够理解函数在程序中的作用,当然我们不必去死背函数,但要做到熟练运用只有一条捷径 -- 多实践。接下来让我们来看看 vbscript 的基本语法。
了解语言的朋友一定知道在程序中控制程序流程的语句主要可以分为条件语句和循环语句,在 vbscript 中可使用以下条件语句: if...then...else 语句
select case 语句
if...then...else 语句用于计算条件是否为 true 或 false,并且根据计算结果指定要运行的语句。通常,条件是使用比较运算符对值或变量进行比较的表达式,if...then...else 语句可以按照需要进行嵌套。
让我们来创建两个范例文件:if1. 和 if2.asp
将以下语句剪贴到记事簿中,并保存为 if1.asp( 注意:请将程序中“<”后的空格去掉 ) < html>
< head>
< title>if1.asp< /title>
< /head>< body bgcolor="#ffffff">
< form action="if2.asp" method=get>
your first name< input name="firstname" maxlength=20>< p>
your last name< input name="lastname" maxlength=20>< p>
< input type=submit>< input type=reset>
< /form>
< /body>
< /html>
将以下语句剪贴到记事簿中,并保存为 if2.asp
< html>
< head>
< title>ifrespond.asp< /title>
< /head>
< % fname=request.querystring("firstname")
lname=request.querystring("lastname")
if fname="george" and lname="washington" then %>
hi.you must be the first president!
< % else %>
hi!nice to meet you
< %end if %>
< /body>
< /html>
asp2.asp 则是用 if 语句判断用户输入的姓名是否为“george washington”, 并做出相应的反馈。在此我们遇到了一个 asp 的内建对象 request,通过使用 request 对象可以访问任何用 http 请求传递的信息,包括从 html 表格中用 post 方法或 get 方法传递的参数、cookie 和用户认证。而 querystring 集合检索 http 查询字符串中变量的值,http 查询字符串由问号 (?) 后的值指定。如:
http://localhost/if2.asp?firstname=george&lastname=washington
生成值为 "firstname=george&lastname=washington" 的变量名字符串。关于 asp 对象作者将在今后的几篇里重点讲述。
if...then...else 语句的一种变形允许您从多个条件中选择,即添加 elseif 子句以扩充 if...then...else 语句的功能,使您可以控制基于多种可能的程序流程。
我们将 asp2.asp 的程序部分扩充如下:< %
fname=lcase(request.querystring("firstname"))
lname=lcase(request.querystring("lastname"))
if fname="george" and lname="washington" then %>
hi.you must be the first president!< p>
< % elseif fname="ronald" and lname="reagan" then %>
hi.you must be the actor president!< p>
< % elseif fname="jimmy" and lname="carter" then %>
hi.you must be the peanut farmer president!< p>
< % elseif fname="naoko" or fname="charles" then %>
hi.your name reminds me of someone,but i am not sure who!< p>
< % else %>
hi!nice to meet you
< % end if %>
可以添加任意多个 elseif 子句以提供多种选择。但使用多个 elseif 子句经常会使程序变得很累赘。在多个条件中进行选择的更好方法是使用 select case 语句。
select case 结构提供了 if...then...elseif 结构的一个变通形式,可以从多个语句块中选择执行其中的一个。select case 语句提供的功能与 if...then...else 语句类似,但是可以使代码更加简练易读。select case 结构在其开始处使用一个只计算一次的简单测试表达式。表达式的结果将与结构中每个 case 的值比较。如果匹配,则执行与该 case 关联的语句块,我们同样可以用 select case 语句来写 asp2.asp 文件:
< %
fname=lcase(request.querystring("firstname"))
lname=lcase(request.querystring("lastname"))
name=fname+lname
select case name
case "georgewashington"
response.write "hi.you must be the first president!< p>"
case "ronaldreagan"
response.write "hi.you must be the actor president!< p>"
case "jimmycarter"
response.write "hi.you must be the peanut farmer president!< p>"
case "naokocharles"
response.write "hi.your name reminds me of someone,but i am not sure who!< p>"
case else
response.write "hi!nice to meet you"
end select %>
请注意 select case 结构只计算开始处的一个表达式,并且只计算一次,而 if...then...elseif 结构计算每个 elseif 语句的表达式,这些表达式可以各不相同。因此仅当每个 elseif 语句计算的表达式都相同时,才可以使用 select case 结构代替 if...then...elseif 结构。select case 语句也是可以是嵌套的,每一层嵌套的 select case 语句必须有与之匹配的 end select 语句。
以上给大家介绍的脚本语言 vbscript 的函数和条件语句的使用方法,由于篇幅的缘故不能详细展开,希望各位有志学习 asp 的朋友,能在课后进行一定程度的自学和练习。在日常开发 asp 应用程序的过程中作者本人日渐体会到了脚本语言的重要性,灵活运用脚本语言将非但可以大大