Avatar billede barbar Nybegynder
31. oktober 2001 - 10:17 Der er 3 kommentarer og
2 løsninger

Flere valgte felter i en select list ....

Hejsa Eksperter...

Er der nogen der kan se hvad der er galt med følgende;

<%
Dim compareRS, compareSQL, ansvar
                 
if opgRS(\"ansvarlig\") <> \"\" Then
                 
ansvar = opgRS(\"ansvarlig\")
Set compareRS = Server.CreateObject(\"ADODB.Recordset\")
compareSQL = \"SELECT * FROM ansvarlig WHERE ansvid IN (\"& ansvar &\") OR ansvid LIKE \'%\"& ansvar &\"%\'\"
Set compareRS = Connect.execute(compareSQL)
%>
<select name=\"ansv\" size=\"4\" multiple>
<% While not ansvRS.EOF %>
<option value=\"<%=ansvRS(\"ansvid\")%>\" <%
While not CompareRS.EOF
If ansvRS(\"ansvid\") = compareRS(\"ansvid\") Then
Response.Write \"selected\"
end if
CompareRS.MoveNext
Wend
%>><%=ansvRS(\"ansvnavn\")%></option>
<%
ansvRS.MoveNext
Wend
%>
</select>

Det er meningen, at hvis der er flere ansvarlig tilknyttet skal alle tilknyttede vælges i listen.
Der bliver dog kun valgt én, selvom der er 2 eller flere ?! ;)
Avatar billede darkhero Nybegynder
31. oktober 2001 - 13:56 #1
Prøv dette:

<%
Dim compareRS, compareSQL, ansvar
                 
if opgRS(\"ansvarlig\") <> \"\" Then
                 
ansvar = opgRS(\"ansvarlig\")
Set compareRS = Server.CreateObject(\"ADODB.Recordset\")
compareSQL = \"SELECT * FROM ansvarlig WHERE ansvid IN (\"& ansvar &\") OR ansvid LIKE \'%\"& ansvar &\"%\'\"
Set compareRS = Connect.execute(compareSQL)
%>
<select name=\"ansv\" size=\"4\" multiple>
<% do While not ansvRS.EOF %>
<option value=\"<%=ansvRS(\"ansvid\")%>\" <%
do While not CompareRS.EOF
If ansvRS(\"ansvid\") = compareRS(\"ansvid\") Then
Response.Write \"selected\"
end if
CompareRS.MoveNext
loop
%>><%=ansvRS(\"ansvnavn\")%></option>
<%
ansvRS.MoveNext
loop
%>
</select>
Avatar billede barbar Nybegynder
31. oktober 2001 - 15:33 #2
Nope - det giver det samme resultat :(
Avatar billede darkhero Nybegynder
31. oktober 2001 - 19:38 #3
du mangler at angive \"ansvRS\" verdi!
Avatar billede eagleeye Praktikant
31. oktober 2001 - 23:37 #4
<%
Dim compareRS, compareSQL, ansvar

if opgRS(\"ansvarlig\") <> \"\" Then

ansvar = opgRS(\"ansvarlig\")
Set compareRS = Server.CreateObject(\"ADODB.Recordset\")
compareSQL = \"SELECT * FROM ansvarlig WHERE ansvid IN (\"& ansvar &\") OR ansvid LIKE \'%\"& ansvar &\"%\'\"
Set compareRS = Connect.execute(compareSQL)
%>
<select name=\"ansv\" size=\"4\" multiple>
<%While not ansvRS.EOF %>
  <option value=\"<%=ansvRS(\"ansvid\")%>\" <%
    compareRS.MoveFirst
    While not CompareRS.EOF
      If ansvRS(\"ansvid\") = compareRS(\"ansvid\") Then
        Response.Write \" selected\"
        end while
      end if
      CompareRS.MoveNext
    Wend%>>
    <%=ansvRS(\"ansvnavn\")%>
  </option>
<% ansvRS.MoveNext
  Wend
%>
</select>
Avatar billede barbar Nybegynder
05. november 2001 - 15:20 #5
Fik det til at virke på følgende måde:


<select name=\"ansv\" size=\"4\" multiple>
<%While not ansvRS.EOF %>
  <option value=\"<%=ansvRS(\"ansvid\")%>\" <%
    compareRS.MoveFirst
    While not CompareRS.EOF
      If ansvRS(\"ansvid\") = compareRS(\"ansvid\") Then
        Response.Write \" selected\"
        end if
      CompareRS.MoveNext
    Wend%>>
    <%=ansvRS(\"ansvnavn\")%>
  </option>
<% ansvRS.MoveNext
  Wend
%>
</select>


Jeg deler point\'ene mellen darkhero og eagleeye - dog var ingen af svarene 100% korrekte, men jeg fik da løst opgaven alligvel ;)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester