Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Hämta data från Datalist

Postades av 2003-03-09 15:01:44 - Tomas Lundgren, i forum asp.net generellt, Tråden har 2 Kommentarer och lästs av 867 personer

Från en nybörjare!

Jag har en enkät där frågorna kommer från en databasen. Frågorna publicerar jag med en datalist och till varje fråga har jag en radiobuttonlist. När jag sedan submittar sidan vill jag skicka ner svaren i databasen.

Hur kommer jag åt värdena i min radiobuttonlist som "loopas" upp till varje fråga. Någon som har ett bra exempel, jag kodar i vb.

Lite kod:
<code>
<HTML>
<HEAD>
<title>TEST</title>
<LINK href="inc/ie.css" type="text/css" rel="STYLESHEET">
</HEAD>
<body>
<form id="Form1" method="post" runat="server">
<P>
<ASP:DATALIST id="DataList1" runat="server" Width="420px">
<ItemTemplate>
<%# FixaRubrik(Container.DataItem("fldFraga"),Container.DataItem("fldTyp")) %>
<asp:RadioButtonList id="rdoLst" runat="server" RepeatDirection="Horizontal" CssClass="liten">
<asp:ListItem Value="1"></asp:ListItem>
<asp:ListItem Value="2"></asp:ListItem>
<asp:ListItem Value="3"></asp:ListItem>
<asp:ListItem Value="4"></asp:ListItem>
<asp:ListItem Value="5"></asp:ListItem>
</asp:RadioButtonList>
</ItemTemplate>
</ASP:DATALIST></P>
</form>
</body>
</HTML>
</code>


Svara

Sv: Hämta data från Datalist

Postades av 2003-03-10 13:02:37 - Mikael Deurell

Hej!
För att lösa problemet kan det vara bra att känna till hur asp.net hanterar din sida och dina kontroller som adderats till datalisten. Egentligen är en asp.net sida bara en klass som ärver från page (som implementerar ihttphandler interfacet). Denna består av samling kontroller (page är rooten) med underkontroller som i sin tur kan ha underkontroller.

Ett kontrollträd byggs upp för din sida där varje kontroll kan ha underkontroller. Enkel html kommer tex. att bli en literalcontrol. Det som du sätter inom <% %> kommer dock skrivas in i en dynamiskt skapad metod (typ __Render__control1 (Kolla din kompilerade sida med ildasm).

När pagecontrollen renderas ger den i sin tur order om att varje underkontroll som denna har skall renderas.

Nog om detta, över till problemet!

När du droppar en kontroll i en ItemTemplate så kommer denna att hamna som en underkontroll till respektive item i din datalist. För att nå dessa kan du iterera igenom denna. t.ex. på detta sätt:

<code>
Dim ctl As Control
Dim dlItem As DataListItem
For Each dlItem In dlMain.Items
For Each ctl In dlItem.Controls
If ctl.GetType.ToString() = "System.Web.UI.WebControls.RadioButtonList" Then
Dim tempctl As RadioButtonList = DirectCast(ctl, RadioButtonList)
If Not tempctl.SelectedItem Is Nothing Then
Response.Output.Write("<BR>Text: {0}, värde: {1}", tempctl.SelectedItem.Text, tempctl.SelectedItem.Value)
End If
End If
Next
Next

</code>

Du når alltså ditt data genom att kolla igenom alla dina datalistitems i din datalist och för dessa gå igenom alla kontroller som finns i denna.

Exempelkod för detta:

<code>
<%@ Page Language="vb" AutoEventWireup="false" Codebehind="Questions.aspx.vb" Inherits="micke.Questions"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<title>Questions</title>
<meta content="Microsoft Visual Studio.NET 7.0" name="GENERATOR">
<meta content="Visual Basic 7.0" name="CODE_LANGUAGE">
<meta content="JavaScript" name="vs_defaultClientScript">
<meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema">
</HEAD>
<body>
<form id="Form1" method="post" runat="server">
<asp:datalist id="dlMain" runat="server">
<ItemTemplate>
<%# Databinder.Eval(Container.DataItem,"Question")%>
<asp:RadioButtonList id="rblQuestion" runat="server">
<asp:ListItem Value="Value1">Text1</asp:ListItem>
<asp:ListItem Value="Value2">Text2</asp:ListItem>
<asp:ListItem Value="Value3">Text3</asp:ListItem>
</asp:RadioButtonList>
</ItemTemplate>
</asp:datalist><BR>
<asp:button id="cmdSubmit" runat="server" Text="Submit"></asp:button></form>
</body>
</HTML>
</code>

<code>
Option Explicit On
Option Strict On

Imports System.Data
Imports System.Data.SqlClient

Public Class Questions
Inherits System.Web.UI.Page
Protected WithEvents cmdSubmit As System.Web.UI.WebControls.Button
Protected WithEvents dlMain As System.Web.UI.WebControls.DataList

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Put user code to initialize the page here
If Not IsPostBack Then
Dim cmd As SqlCommand = New SqlCommand("SELECT * FROM tQuestions")
cmd.Connection = New SqlConnection("server=.;database=testdb;trusted_connection=true")
cmd.Connection.Open()
Dim rdr As IDataReader = cmd.ExecuteReader

dlMain.DataSource = rdr
dlMain.DataBind()

rdr.Close()
cmd.Dispose()
End If
End Sub

Private Sub cmdSubmit_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmdSubmit.Click
Dim ctl As Control
Dim dlItem As DataListItem
For Each dlItem In dlMain.Items
For Each ctl In dlItem.Controls
If ctl.GetType.ToString() = "System.Web.UI.WebControls.RadioButtonList" Then
Dim tempctl As RadioButtonList = DirectCast(ctl, RadioButtonList)
If Not tempctl.SelectedItem Is Nothing Then
Response.Output.Write("<BR>Text: {0}, värde: {1}", tempctl.SelectedItem.Text, tempctl.SelectedItem.Value)
End If
End If
Next
Next

End Sub
End Class
</code>




Svara

Sv: Hämta data från Datalist

Postades av 2003-03-10 13:20:48 - Tomas Lundgren

Tack för ett mycket bra svar!


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 155
27 952
271 704
662
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies