阿七 |
2006-04-03 13:59 |
介绍一个制作下拉菜单完全不同的办法。 q[lqEc 出处 oCS NA.z XA68H!I 介绍一个制作下拉菜单完全不同的办法。 *(rE< 作者: 未知 Oc>-
jhx? E7D
DMU
…… "7DPsPs 我是头一回知道这个方法,以前从没听用过,以前如果我从数据库里读出内容来制作下拉菜单的话都是用循环来做的,现在,让我们来看一下老外的办法。 03PVbDq- 利用RecordSet.GetString来制作动态下拉菜单。 I~I%z'"RQd adodb.recordset的getstring方法有一些BUG,但是你使用得小心一点的话它可以为您工作的很好。 6~s,j({^ 先介绍一下GETSTRING的用法……如下: NKRXY~zHh stringValue = rsObject.GetString( format, numRows, columnDelimiter, rowDelimiter, ifNull ) shB(kb{{ 只要建立了RS对象,并且执行了相应操作,不管那是返回一条或者多条记录,甚至是空记录,getstring照样工作,但是如果不加注意的话,这个结果可能就不大好玩了,:P(这个老外也够幽默的) uH#NJoRO FORMAT参数只有一个合法值,而且是可选的,让我们略过不管它,如果您想返回全部记录的话,那么那个numrows参数也可以不管它了(可选),IFNULL……照我的理解就象TSQL里的isnull函数差不多,如果是NULL,则随便搞个值替换它,所以也不管它。 V-31x) 剩下两个参数了。。。。不多说废话了,先看他们的例子 g6farLBF <TABLE Border=1> a5iMCmL+ <TR><TD> 19EU[eb <% = Response.Write rs.GetString( , , "</TD><TD>", "</TD></TR><TR>", ) %> fjb2-K </TABLE> 2:abe 这样写的HTML结果如下: U6Qeode <TABLE Border=1> z}%to0W <TR> A28w/=e7 <TD>row1, field1 value</TD> B@4#y9`5 <TD>row1, field2 value</TD> 4Y]`> ;w </TR> -}(W=r\ <TR> VlEkT9^: <TD>row2, field1 value</TD> >dM'UpN@ <TD>row2, field2 value</TD> PQK_*hJG" </TR> Kk,
->q<1 <TR> b7n~z1$ </TABLE> @ZVc!5J_, 这个也是老外口中说的那个BUG了,让我们看一下具体怎么做的 ;ry{cq <% @6E[K'5c1 Set RS = conn.Execute("SELECT theValue,theText FROM selectOptionsTable ORDER BY theText") /\9Kr
;@vk optSuffix = "</OPTION>" & vbNewLine IH0Uq_ valPrefix = "<OPTION Value='" "n\!y~: valSuffix = "'>" ]
!H<vR$8 opts = RS.GetString( , , valSuffix, optSuffix & valPrefix, "--error--" )
`>*P(yIN ' Next line is the key to it! IoX(Pa opts = Left( opts, Len(opts)-Len(valPrefix) ) s^U^n// Response.Write "<SELECT ...>" & vbNewLine H0Tt(:.& Response.Write valPrefix & opts )*uI/E Response.Write "</SELECT>" G$Dg*< %> RsbrD8*AD 你用过这种方法么,实话,我可从没见过,也没听有人说起,:( 2|cIu 'U 附带一下,您如果想建立一个正确的表格的话,也就是我头上说的那个BUG,只要这样做就可以了: ,"/_G <%
~2qFA2 Set RS = conn.Execute("SELECT * FROM table") \KEL.}B9E tdSuffix = "</TD>" & vbNewLine & "<TD> lRrOoON trPrefix = "<TR>" & vbNewLine & "<TD>" 7}*5Mir p trSuffix = "</TD>" & vbNewLine & "</TR>" & vbNewLine & "<TR>" & vbNewLine n"pADTaB opts = RS.GetString( , , tdSuffix, trSuffix & trPrefix, "--error--" )
[W;14BD7 ' Next line is the key to it! NZ_45/(dx opts = Left( opts, Len(opts)-Len(trPrefix) )
V=c&QPP Response.Write "<TABLE Border=1 CellPadding=5>" & vbNewLine \CL`j Response.Write trPrefix & opts T7,tJk,( Response.Write "</TABLE>" & vbNewLine 5pDxFs=v %> kTzZj|l^\ ------------------------------------------------------------------------ WgjaMmht 再介绍一个完全不同的办法。。。(我看了快昏倒) Fr
VD~; <% NO<m
yN+N SQL = "SELECT '<OPTION Value=''',value,'''>',text,'</OPTION>' FROM table ORDER BY text" tpVtbh1)u Set RS = conn.Execute(SQL) mF_/Rhu Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" WcdU fv(> %> UeVF@rw 你用过吗。。。 )~J/,\ 看到了吗?可以直接从查询中返回结果。 g` Wr3 再进一步,您可以这样做(ACCESS下我试过) {c$W-t):U| <% ~E)I+$, SQL = "SELECT '<OPTION Value=''' & value & '''>' & text & '</OPTION>' FROM table ORDER BY text" "XH]B Set RS = conn.Execute(SQL) gC'GZi^
Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" #><.zZ %> u%T.XgY=j …………………… 0
xXAhv-)O :( -?
GYW81Q 不多说了 4(Mt6{q 希望能对你有所帮助 |
|