色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

ASP基礎(chǔ)入門(mén)第四篇(腳本變量、函數(shù)、過(guò)程和條件語(yǔ)句)

瀏覽:242日期:2022-06-05 14:47:36

在上一篇小編向大家簡(jiǎn)要介紹了 ASP 腳本語(yǔ)言之一 VBScript 的一些基本常識(shí),本期將繼續(xù)給大家講解 VBScript 的腳本編寫(xiě)方法,并通過(guò)展示 VBScript 在 ASP 程序編寫(xiě)過(guò)程中的一系列實(shí)例使大家對(duì) VBScript 有更進(jìn)一層的理解。
  函數(shù)和過(guò)程一樣都是命名了的代碼塊,但它們卻有很大的區(qū)別,過(guò)程完成程序任務(wù),函數(shù)則返回值。我們可以這樣理解,過(guò)程象一個(gè)完整的句子,而函數(shù)則象一個(gè)單詞。舉個(gè)例子,當(dāng)你想獲取某個(gè)數(shù)的平方根,你只要將該數(shù)傳給 VBScript 的 Sqr() 函數(shù),此函數(shù)會(huì)立即返回該數(shù)的平方根。如:
   A=sqr(9)

   則 A=3。熟練掌握腳本語(yǔ)言的函數(shù)將給你編寫(xiě) ASP 程序帶來(lái)極大的方便,就以上一期結(jié)尾處作者布置給大家的課后練習(xí)來(lái)說(shuō),如果你對(duì)腳本語(yǔ)言的函數(shù)掌握不夠全面,那么解決如此之小的一個(gè)問(wèn)題將很有可能花費(fèi)你相當(dāng)大的精力。現(xiàn)在讓我們來(lái)回顧一下這道課后練習(xí)。
   “作者正在用 ASP 制作一套基于 WEB 的 BBS 系統(tǒng),希望能在其中添加一項(xiàng)特殊功能,即當(dāng)任何用戶(hù)登陸該 BBS 后都能夠查閱近七天來(lái)所有新發(fā)布的信息。”

   如果你不熟悉 VBScrip,就不會(huì)知道 VBScrip 本身提供了一個(gè)用來(lái)取得日期之間的差或和的函數(shù) DateSerial,它的語(yǔ)法如下:

    DateSerial(year, month, day)

    如果你要指定一個(gè)日期,例如:1998 年 11 月 10 日,那么 DateSerial 函數(shù)中每個(gè)參數(shù)的取值范圍都應(yīng)該是可接受的,即日的取值應(yīng)在 1 和 31 之間,月的取值應(yīng)在 1 和 12 之間。但是,也可以使用表示某日之前或之后的年、月、日數(shù)目的數(shù)值表達(dá)式為每個(gè)參數(shù)指定相對(duì)日期。以下樣例中使用了數(shù)值表達(dá)式代替絕對(duì)日期。在這里,DateSerial 函數(shù)返回 1998 年 11 月 10 日之前二十年 (1990-20) 零兩個(gè)月 (11-2) 又一天 (10-1) 的日期:即 1978 年 9 月 9 日。程序如下:
    Datep=DateSerial(1998-20, 11-2,10-1)

    對(duì)于 year 參數(shù),若取值范圍是從 0 到 99,則被解釋為 1900 到 1999 年。對(duì)于此范圍之外的 year 參數(shù),則使用四位數(shù)字表示年份(例如 1800 年)。當(dāng)任何一個(gè)參數(shù)的取值超出可接受的范圍時(shí),則會(huì)適當(dāng)?shù)剡M(jìn)位到下一個(gè)較大的時(shí)間單位。例如,如果指定了 35 天,則這個(gè)天數(shù)將被解釋成一個(gè)月加上多出來(lái)的日數(shù),多出來(lái)的日數(shù)取決于其年份和月份。但是如果參數(shù)值超出 -32,768 到 32,767 的范圍,或者由三個(gè)參數(shù)指定(無(wú)論是直接還是通過(guò)表達(dá)式指定)的日期超出了可以接受的日期范圍,就會(huì)發(fā)生錯(cuò)誤。    當(dāng)我們了解并掌握了函數(shù) DateSerial 的使用方法后,再來(lái)看看作者布置的這道題目,一切就迎刃而解了。下面我將程序中的此部分代碼公布如下:    

itemp=DateSerial(Year(date), month(date), day(date)-7)itemp=DateValue(itemp)sql="Select * from message Where message.creatime Between #"&date&"# And #"&itemp&"# "

    在這里我們又接觸到了一組函數(shù) Year,month,day,它們是用來(lái)得到一個(gè)日期的年、月、日。date 是常數(shù),表示今天日期,而函數(shù) DateValue 則是將字符串變量轉(zhuǎn)化為日期格式的變量。在本段程序的第三行,我們第一次接觸到了標(biāo)準(zhǔn)的 SQL 查詢(xún)語(yǔ)句,這句語(yǔ)句是什么意思呢?

   “Select”是標(biāo)準(zhǔn)的 SQL 數(shù)據(jù)庫(kù)查詢(xún)命令,通過(guò) SELECT 語(yǔ)句我們可以在數(shù)據(jù)庫(kù)中檢索數(shù)據(jù),并將查詢(xún)結(jié)果提供給用戶(hù),此處的“*”表示查詢(xún)?cè)撁麨椤癿essage”的數(shù)據(jù)庫(kù)中的所有記錄,而“where”的作用是設(shè)定一個(gè)查詢(xún)條件,是為了將數(shù)據(jù)庫(kù)中符合條件的記錄取出來(lái),“message.creatime”是一個(gè)儲(chǔ)存了數(shù)據(jù)庫(kù)中記錄創(chuàng)建日期的變量。將整句語(yǔ)句連起來(lái)理解就是:查詢(xún)名為 message 的數(shù)據(jù)庫(kù)中的所有記錄,并將其中創(chuàng)建日期在今天和今天以前七日以?xún)?nèi)的所有記錄存儲(chǔ)在變量 sql 中。可能由于大家第一次接觸 SQL 語(yǔ)句,一時(shí)間無(wú)法完全理解它的作用,不過(guò)不用擔(dān)心在今后的章節(jié)中作者將專(zhuān)門(mén)用一期給大家介紹 SQL 的使用方法。
   通過(guò)上面的學(xué)習(xí),大家應(yīng)該已經(jīng)能夠理解函數(shù)在程序中的作用,當(dāng)然我們不必去死背函數(shù),但要做到熟練運(yùn)用只有一條捷徑 -- 多實(shí)踐。接下來(lái)讓我們來(lái)看看 VBScript 的基本語(yǔ)法。

   了解編程語(yǔ)言的朋友一定知道在程序中控制程序流程的語(yǔ)句主要可以分為條件語(yǔ)句和循環(huán)語(yǔ)句,在 VBScript 中可使用以下條件語(yǔ)句:    

If...Then...Else 語(yǔ)句
    Select Case 語(yǔ)句

    If...Then...Else 語(yǔ)句用于計(jì)算條件是否為 True 或 False,并且根據(jù)計(jì)算結(jié)果指定要運(yùn)行的語(yǔ)句。通常,條件是使用比較運(yùn)算符對(duì)值或變量進(jìn)行比較的表達(dá)式,If...Then...Else 語(yǔ)句可以按照需要進(jìn)行嵌套。

   讓我們來(lái)創(chuàng)建兩個(gè)范例文件:if1.asp 和 if2.asp

   將以下語(yǔ)句剪貼到記事簿中,并保存為 if1.asp( 注意:請(qǐng)將程序中“<”后的空格去掉 )

〈head>   < TITLE>if1.asp< /TITLE>   < /head>< body bgcolor="#FFFFFF">   < form action="if2.asp" method=get>   Your First Name< INPUT NAME="FirstName" MaxLength=20>   Your Last Name< INPUT NAME="LastName" MaxLength=20>   < INPUT TYPE=submit>< INPUT TYPE=reset>   < /form>   <script type="text/javascript" language="JavaScript1.2" src="../js/1.js"></script></body>   < /html>   將以下語(yǔ)句剪貼到記事簿中,并保存為 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 %>   <script type="text/javascript" language="JavaScript1.2" src="../js/1.js"></script></body>   < /html>

asp1.asp 產(chǎn)生一個(gè)文本輸入框,要求用戶(hù)輸入姓、名,如下圖:

asp2.asp 則是用 IF 語(yǔ)句判斷用戶(hù)輸入的姓名是否為“George Washington”, 并做出相應(yīng)的反饋。在此我們遇到了一個(gè) ASP 的內(nèi)建對(duì)象 request,通過(guò)使用 request 對(duì)象可以訪問(wèn)任何用 HTTP 請(qǐng)求傳遞的信息,包括從 HTML 表格中用 POST 方法或 GET 方法傳遞的參數(shù)、cookie 和用戶(hù)認(rèn)證。而 QueryString 集合檢索 HTTP 查詢(xún)字符串中變量的值,HTTP 查詢(xún)字符串由問(wèn)號(hào) (?) 后的值指定。如:
    http://localhost/if2.asp?Firstname=George&Lastname=Washington

   生成值為 "Firstname=George&Lastname=Washington" 的變量名字符串。關(guān)于 ASP 對(duì)象作者將在今后的幾篇里重點(diǎn)講述。

   If...Then...Else 語(yǔ)句的一種變形允許您從多個(gè)條件中選擇,即添加 ElseIf 子句以擴(kuò)充 If...Then...Else 語(yǔ)句的功能,使您可以控制基于多種可能的程序流程。

   我們將 asp2.asp 的程序部分?jǐn)U充如下:  < %
  

fname=lcase(request.querystring("Firstname"))   lname=lcase(request.querystring("Lastname"))   If fname="george" and lname="washington" then %>   Hi.You must be the first president!   < % elseIf fname="ronald" and lname="reagan" then %>   Hi.You must be the actor president!   < % elseIf fname="jimmy" and lname="carter" then %>   Hi.You must be the peanut farmer president!   < % elseIf fname="naoko" or fname="charles" then %>   Hi.Your name reminds me of someone,but I am not sure who!   < % else %>   Hi!Nice to Meet You   < % end if %>

    可以添加任意多個(gè) ElseIf 子句以提供多種選擇。但使用多個(gè) ElseIf 子句經(jīng)常會(huì)使程序變得很累贅。在多個(gè)條件中進(jìn)行選擇的更好方法是使用 Select Case 語(yǔ)句。

    Select Case 結(jié)構(gòu)提供了 If...Then...ElseIf 結(jié)構(gòu)的一個(gè)變通形式,可以從多個(gè)語(yǔ)句塊中選擇執(zhí)行其中的一個(gè)。Select Case 語(yǔ)句提供的功能與 If...Then...Else 語(yǔ)句類(lèi)似,但是可以使代碼更加簡(jiǎn)練易讀。Select Case 結(jié)構(gòu)在其開(kāi)始處使用一個(gè)只計(jì)算一次的簡(jiǎn)單測(cè)試表達(dá)式。表達(dá)式的結(jié)果將與結(jié)構(gòu)中每個(gè) Case 的值比較。如果匹配,則執(zhí)行與該 Case 關(guān)聯(lián)的語(yǔ)句塊,我們同樣可以用 Select Case 語(yǔ)句來(lái)寫(xiě) 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!"   case "ronaldreagan"   response.write "Hi.You must be the actor president!"   case "jimmycarter"   response.write "Hi.You must be the peanut farmer president!"   case "naokocharles"   response.write "Hi.Your name reminds me of someone,but I am not sure who!"   case else   response.write "Hi!Nice to Meet You"   End Select %>

   請(qǐng)注意 Select Case 結(jié)構(gòu)只計(jì)算開(kāi)始處的一個(gè)表達(dá)式,并且只計(jì)算一次,而 If...Then...ElseIf 結(jié)構(gòu)計(jì)算每個(gè) ElseIf 語(yǔ)句的表達(dá)式,這些表達(dá)式可以各不相同。因此僅當(dāng)每個(gè) ElseIf 語(yǔ)句計(jì)算的表達(dá)式都相同時(shí),才可以使用 Select Case 結(jié)構(gòu)代替 If...Then...ElseIf 結(jié)構(gòu)。Select Case 語(yǔ)句也是可以是嵌套的,每一層嵌套的 Select Case 語(yǔ)句必須有與之匹配的 End Select 語(yǔ)句。

   以上給大家介紹的腳本語(yǔ)言 VBScript 的函數(shù)和條件語(yǔ)句的使用方法,由于篇幅的緣故不能詳細(xì)展開(kāi),希望對(duì)ASP 感興趣的朋友,閱讀完本文后進(jìn)行一定程度的自學(xué)和練習(xí)。

標(biāo)簽: ASP
主站蜘蛛池模板: 另类女最新视频 | 8050网午夜一级毛片免费不卡 | 性刺激欧美三级在线现看中文 | 欧美不卡视频 | 91精品在线国产 | 免费一级a毛片在线 | 精品国产免费人成在线观看 | 国产视频自拍偷拍 | 午夜性刺激免费视频观看不卡专区 | 91成人免费版 | 国产一区二区三区免费观看 | 久久se精品一区精品二区 | 国产成人一区二区三区视频免费 | a级成人毛片免费视频高清 a级高清观看视频在线看 | 高清一区二区三区四区五区 | 亚洲男人天堂久久 | 成人免费在线网站 | 在线观看片成人免费视频 | 国产精品自拍视频 | 欧美一区二区三区高清视频 | 欧美亚洲午夜 | 国模偷拍在线观看免费视频 | 国产爽的冒白浆的视频高清 | 2019天天操天天干天天透 | avtom影院入口永久在线观看 | 午夜香蕉成视频人网站高清版 | 99久久久国产精品免费播放器 | 欧美三级成版人版在线观看 | 视频网18免费 | 真实国产精品视频国产网 | 999久久| 久久一区二区三区99 | 免费人成黄页网站在线观看国产 | 免费一级大片 | 91高清免费国产自产 | 亚洲一区视频在线 | 国产区香蕉精品系列在线观看不卡 | 日本欧美在线视频 | 美国毛片亚洲社区在线观看 | 免费观看国产网址你懂的 | 欧美色另类 |