» 您尚未 登录   注册 | 社区服务 | 帮助 | 社区 | 无图版


常州五颜六色网络技术有限公司 -> 网站建设 -> 介绍一个制作下拉菜单完全不同的办法。
 XML   RSS 2.0   WAP 

--> 本页主题: 介绍一个制作下拉菜单完全不同的办法。 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题
阿七




该用户目前不在线
级别: 未验证会员
精华: 0
发帖: 909
威望: 0 点
金钱: 2161 RMB
贡献值: 0 点
在线时间:512(小时)
注册时间:2006-03-29
最后登录:2008-08-07
查看作者资料 发送短消息 推荐此帖 引用回复这个帖子

介绍一个制作下拉菜单完全不同的办法。

介绍一个制作下拉菜单完全不同的办法。 G's/Q-'[\  
出处   T&S< 0  
5fLCmLM`  
介绍一个制作下拉菜单完全不同的办法。 U}5uy9A  
作者: 未知 kNjbpCE\!  
*i n_Z t3  
…… |_ @iaLE  
我是头一回知道这个方法,以前从没听用过,以前如果我从数据库里读出内容来制作下拉菜单的话都是用循环来做的,现在,让我们来看一下老外的办法。 $Z(zO;k.  
利用RecordSet.GetString来制作动态下拉菜单。 m.$Oo Mu'  
adodb.recordset的getstring方法有一些BUG,但是你使用得小心一点的话它可以为您工作的很好。 x x 'XR'zK  
先介绍一下GETSTRING的用法……如下: QHQj6]  
stringValue = rsObject.GetString( format, numRows, columnDelimiter, rowDelimiter, ifNull ) 7; _5 [_  
只要建立了RS对象,并且执行了相应操作,不管那是返回一条或者多条记录,甚至是空记录,getstring照样工作,但是如果不加注意的话,这个结果可能就不大好玩了,:P(这个老外也够幽默的) I%(+tJ  
FORMAT参数只有一个合法值,而且是可选的,让我们略过不管它,如果您想返回全部记录的话,那么那个numrows参数也可以不管它了(可选),IFNULL……照我的理解就象TSQL里的isnull函数差不多,如果是NULL,则随便搞个值替换它,所以也不管它。 ~bwFQYY=  
剩下两个参数了。。。。不多说废话了,先看他们的例子 Xr~r`bR=  
<TABLE Border=1> fkI< RgM  
<TR><TD> @&~BGh  
<% = Response.Write rs.GetString( , , "</TD><TD>", "</TD></TR><TR>", ) %> i'57 |;?  
</TABLE> j`#|z9`(pB  
这样写的HTML结果如下: : i(h[0  
<TABLE Border=1> Wm\f:|U5`  
<TR> 8+!$k!=X  
<TD>row1, field1 value</TD> u ) ld  
<TD>row1, field2 value</TD> :wF(([&4p!  
</TR> X%gJ, c(4  
<TR> F{}z[0  
<TD>row2, field1 value</TD> [&39Yv.k,7  
<TD>row2, field2 value</TD> sF|lhLi  
</TR> C :e 'wmA  
<TR> "W1q}4_  
</TABLE> %d=-<EQ|&  
这个也是老外口中说的那个BUG了,让我们看一下具体怎么做的 (V+(\<M  
<% adxJA}K}  
Set RS = conn.Execute("SELECT theValue,theText FROM selectOptionsTable ORDER BY theText") B8P%4@T  
optSuffix = "</OPTION>" & vbNewLine *Lufz-[1  
valPrefix = "<OPTION Value='" yRy9*r=  
valSuffix = "'>" ;ndg,05_  
opts = RS.GetString( , , valSuffix, optSuffix & valPrefix, "--error--" ) E+Gea[c  
' Next line is the key to it! ZHB'^#b  
opts = Left( opts, Len(opts)-Len(valPrefix) ) jb*#!m.l  
Response.Write "<SELECT ...>" & vbNewLine 5= F-^  
Response.Write valPrefix & opts p;B +g X  
Response.Write "</SELECT>" jRBx7|ON  
%> x~(Ul\EX  
你用过这种方法么,实话,我可从没见过,也没听有人说起,:( +wio:==  
附带一下,您如果想建立一个正确的表格的话,也就是我头上说的那个BUG,只要这样做就可以了: ^yb_aCw  
<% fW\u*dMMZE  
Set RS = conn.Execute("SELECT * FROM table") 0xjV*0?s  
tdSuffix = "</TD>" & vbNewLine & "<TD> [0rG"$(0Y  
trPrefix = "<TR>" & vbNewLine & "<TD>" 11)~!in  
trSuffix = "</TD>" & vbNewLine & "</TR>" & vbNewLine & "<TR>" & vbNewLine =6 [!'K  
opts = RS.GetString( , , tdSuffix, trSuffix & trPrefix, "--error--" ) x^;n fqn|  
' Next line is the key to it! |W::\yu6  
opts = Left( opts, Len(opts)-Len(trPrefix) ) {vU '>pp  
Response.Write "<TABLE Border=1 CellPadding=5>" & vbNewLine YvU#)M_h  
Response.Write trPrefix & opts jrW7AT)\  
Response.Write "</TABLE>" & vbNewLine & v`kyc  
%> pLIBNo?  
------------------------------------------------------------------------ \k* ]w_m-  
再介绍一个完全不同的办法。。。(我看了快昏倒) PJ_|=bn  
<% oL~Yrb%R  
SQL = "SELECT '<OPTION Value=''',value,'''>',text,'</OPTION>' FROM table ORDER BY text" -Wig k['v  
Set RS = conn.Execute(SQL) XrvrN^'  
Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" !]`]67lC  
%> >Te{a*`"m:  
你用过吗。。。 {7;T Q?/  
看到了吗?可以直接从查询中返回结果。 6?Wsg`9  
再进一步,您可以这样做(ACCESS下我试过) |)lo<}{  
<% m760K*:i\  
SQL = "SELECT '<OPTION Value=''' & value & '''>' & text & '</OPTION>' FROM table ORDER BY text" 'R$~U?i8  
Set RS = conn.Execute(SQL) (Hs frc  
Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" ,rN7X<s54  
%> S !e0 :  
…………………… /2z 2a-!r  
:( z4<h)hh"k6  
不多说了 JAn3  
希望能对你有所帮助

[楼 主] | Posted: 2006-04-03 13:59 顶端

常州五颜六色网络技术有限公司 -> 网站建设



Copyright © 2005-2009 5y6s Inc. 苏ICP备05001866号 Powered by PHPWind 5.0.1
Total 0.010929(s) query 4, Gzip enabled
会员言论不代表本站立场 本站法律顾问:北京汇泽律师事务所 韩律师
QQ:点击这里给我发消息 /点击这里给我发消息 /点击这里给我发消息