阿七 |
2006-04-03 13:59 |
介绍一个制作下拉菜单完全不同的办法。 !<oe=)Iz| 出处 %)|s1B'd FlQGgVN 介绍一个制作下拉菜单完全不同的办法。 >usL*b0% 作者: 未知 n|hNM?v 7nSxi+6e …… .V
qhV 我是头一回知道这个方法,以前从没听用过,以前如果我从数据库里读出内容来制作下拉菜单的话都是用循环来做的,现在,让我们来看一下老外的办法。 :DNjhZ 利用RecordSet.GetString来制作动态下拉菜单。 D=$)n_F adodb.recordset的getstring方法有一些BUG,但是你使用得小心一点的话它可以为您工作的很好。 6LZCgdS{ 先介绍一下GETSTRING的用法……如下: t7pFW^& stringValue = rsObject.GetString( format, numRows, columnDelimiter, rowDelimiter, ifNull ) t:S+%u U 只要建立了RS对象,并且执行了相应操作,不管那是返回一条或者多条记录,甚至是空记录,getstring照样工作,但是如果不加注意的话,这个结果可能就不大好玩了,:P(这个老外也够幽默的) z{543~Og59 FORMAT参数只有一个合法值,而且是可选的,让我们略过不管它,如果您想返回全部记录的话,那么那个numrows参数也可以不管它了(可选),IFNULL……照我的理解就象TSQL里的isnull函数差不多,如果是NULL,则随便搞个值替换它,所以也不管它。 ~,Qp^"rlW 剩下两个参数了。。。。不多说废话了,先看他们的例子 >_TZ'FT <TABLE Border=1> [7-?7mp!B <TR><TD> >!JS:5| <% = Response.Write rs.GetString( , , "</TD><TD>", "</TD></TR><TR>", ) %> WAqINLdX </TABLE> 8|^7ai[am 这样写的HTML结果如下: pYg/Zm
Jd <TABLE Border=1> <v2;p}A <TR> ?0.NIu,,o <TD>row1, field1 value</TD> }vuARZ> <TD>row1, field2 value</TD> Mt$
*a
</TR> s.rm7r@# <TR> R_KH"`q <TD>row2, field1 value</TD> "Q<MS'a <TD>row2, field2 value</TD> wzA$'+Mb </TR> OI*H,Z" <TR> y-k.U% </TABLE> GdwVtqbX 这个也是老外口中说的那个BUG了,让我们看一下具体怎么做的 x2EUr,7 <% K9[UB Set RS = conn.Execute("SELECT theValue,theText FROM selectOptionsTable ORDER BY theText") ' QG?nu optSuffix = "</OPTION>" & vbNewLine ?[AD=rUC valPrefix = "<OPTION Value='" >z03{=sAN valSuffix = "'>" H|*m$|$, opts = RS.GetString( , , valSuffix, optSuffix & valPrefix, "--error--" ) 7_L;E~\ ' Next line is the key to it! T%Lx%Qn opts = Left( opts, Len(opts)-Len(valPrefix) ) 0@(&eH= Response.Write "<SELECT ...>" & vbNewLine ok[i<zl;' Response.Write valPrefix & opts .8R@2c`}Cs Response.Write "</SELECT>" w(/S?d
%> rsQtMtS2 你用过这种方法么,实话,我可从没见过,也没听有人说起,:( Ulyue 附带一下,您如果想建立一个正确的表格的话,也就是我头上说的那个BUG,只要这样做就可以了: ^#$n~]s <% XUYtEf Set RS = conn.Execute("SELECT * FROM table") x4 yR8n( tdSuffix = "</TD>" & vbNewLine & "<TD> &HW9Jn trPrefix = "<TR>" & vbNewLine & "<TD>" +R&gqja trSuffix = "</TD>" & vbNewLine & "</TR>" & vbNewLine & "<TR>" & vbNewLine *T/']t opts = RS.GetString( , , tdSuffix, trSuffix & trPrefix, "--error--" ) +2{Lh7Ks ' Next line is the key to it! 3$ pX opts = Left( opts, Len(opts)-Len(trPrefix) ) /7kC< Response.Write "<TABLE Border=1 CellPadding=5>" & vbNewLine nKY6[|!# Response.Write trPrefix & opts ;`&kZi60Hz Response.Write "</TABLE>" & vbNewLine ,prf;|e? %> Ytkv!]" ------------------------------------------------------------------------ xpt:BBo 再介绍一个完全不同的办法。。。(我看了快昏倒) C]6O!Pb0 <% Da|z"I
x SQL = "SELECT '<OPTION Value=''',value,'''>',text,'</OPTION>' FROM table ORDER BY text" s AkdMo
Set RS = conn.Execute(SQL) Psf#c:*_
) Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" 7
I}uZ/N %> LoV<:|GTI 你用过吗。。。 G\i9:7 ` 看到了吗?可以直接从查询中返回结果。 zPO9!?7| 再进一步,您可以这样做(ACCESS下我试过) TOt dUO <% ZVBXx\{s SQL = "SELECT '<OPTION Value=''' & value & '''>' & text & '</OPTION>' FROM table ORDER BY text" ?< +WG/(d Set RS = conn.Execute(SQL) )5,v!X) Response.Write "<SELECT>" & vbNewLine & RS.GetString(,,"",vbNewLine) & "</SELECT>" CJ
}%W# %> o&%g8=
n% …………………… ?`s8 pPc4 :( :TbgFQ86~ 不多说了 FPz9N@M%Q 希望能对你有所帮助 |
|