阿七
级别: 未验证会员
精华:
0
发帖: 909
威望: 0 点
金钱: 2161 RMB
贡献值: 0 点
在线时间:512(小时)
注册时间:2006-03-29
最后登录:2008-08-07
|
介绍一个制作下拉菜单完全不同的办法。
介绍一个制作下拉菜单完全不同的办法。 ;HlVU 出处 q*SX.A>YR 22a$//}E 介绍一个制作下拉菜单完全不同的办法。 T_lexX[\ 作者: 未知 5 S$*YRp H5j~<@STC …… 3+;]dqZ 我是头一回知道这个方法,以前从没听用过,以前如果我从数据库里读出内容来制作下拉菜单的话都是用循环来做的,现在,让我们来看一下老外的办法。 qY]IX9'kV 利用RecordSet.GetString来制作动态下拉菜单。 3(Kj|u
adodb.recordset的getstring方法有一些BUG,但是你使用得小心一点的话它可以为您工作的很好。 n{J<7I e"* 先介绍一下GETSTRING的用法……如下: '=EaZ>= stringValue = rsObject.GetString( format, numRows, columnDelimiter, rowDelimiter, ifNull ) hs}nI/# 只要建立了RS对象,并且执行了相应操作,不管那是返回一条或者多条记录,甚至是空记录,getstring照样工作,但是如果不加注意的话,这个结果可能就不大好玩了,:P(这个老外也够幽默的) ]7}2"?J4v FORMAT参数只有一个合法值,而且是可选的,让我们略过不管它,如果您想返回全部记录的话,那么那个numrows参数也可以不管它了(可选),IFNULL……照我的理解就象TSQL里的isnull函数差不多,如果是NULL,则随便搞个值替换它,所以也不管它。 +e. bO5Y 剩下两个参数了。。。。不多说废话了,先看他们的例子 M$d DExd~ <TABLE Border=1> /m%i"kki <TR><TD> ):E4qlB <% = Response.Write rs.GetString( , , "</TD><TD>", "</TD></TR><TR>", ) %> i9[=x(-@ </TABLE> y+\nj3v6 这样写的HTML结果如下: ZC'(^liAp <TABLE Border=1> C s?kZ
% <TR> 'Pk (
1: <TD>row1, field1 value</TD> !run3ip`Z <TD>row1, field2 value</TD> Jb
Hn/$ </TR> $rD&rsx6 <TR> *aT3L#0( <TD>row2, field1 value</TD> LRW7_XYz <TD>row2, field2 value</TD> yxh8sAZ </TR> TXD\i Dq <TR> BFc=GiPnQ </TABLE> {.v- 这个也是老外口中说的那个BUG了,让我们看一下具体怎么做的 Xs$k6C3 <% P#-Ye<V~J( Set RS = conn.Execute("SELECT theValue,theText FROM selectOptionsTable ORDER BY theText") jk,:IG optSuffix = "</OPTION>" & vbNewLine /DA'p [, valPrefix = "<OPTION Value='" L l\y2oJ valSuffix = "'>" fx2r\ usX[ opts = RS.GetString( , , valSuffix, optSuffix & valPrefix, "--error--" ) eSHyA+F ' Next line is the key to it! 3QM6M9M opts = Left( opts, Len(opts)-Len(valPrefix) ) gTcLS|& | |