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


Template checkbox i gridview

Postades av 2010-03-24 16:11:23 - Anders Persson, i forum c# (c-sharp), Tråden har 1 Kommentarer och lästs av 2020 personer

Hej

Har stött på ett problem när jag försöker loopa alla checkbox som finns i en gridview.
Detta är koden:
<asp:GridView ID="gvCustomer" runat="server" AutoGenerateColumns="False" GridLines="None"
CssClass="mGrid" PagerStyle-CssClass="pgr" AlternatingRowStyle-CssClass="alt"
AllowSorting="True" OnSorting="gvCustomer_Sorting">
<Columns>
<asp:TemplateField>
<ItemTemplate>
<asp:CheckBox ID="chkSelected" runat="server" />
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="Name" HeaderText="Namn" SortExpression="Name" />
<asp:BoundField DataField="Zipcode" HeaderText="Postnr" SortExpression="Zipcode" />
<asp:BoundField DataField="State" HeaderText="Ort" SortExpression="State" />
<asp:BoundField DataField="RowCreated" HeaderText="Inkom" SortExpression="RowCreated" />
</Columns>
<PagerStyle CssClass="pgr" />
<AlternatingRowStyle CssClass="alt" />
</asp:GridView>
<hr />
<asp:Button ID="btnDelete" runat="server" Text="Radera" CssClass="btn" />
<asp:Button ID="btnProcess" runat="server" Text="Bearbeta" CssClass="btn" OnClick="btnProcess_Click" />

Checkbox ligger som en template i Gridview och sidan använder MasterPage.
Problemet är att jag testat att loopa alla kontroller och i loopen köra en FindControll, men den lyckas alltså inte hitta något.

Jag vill alltså kolla vilka CheckBox som är ikryssade t.ex

if(chkSelected.Checked)
Response.Write("Checked");

Någon som har en bra idé om detta?


MVH
Anders


Svara

Sv: Template checkbox i gridview

Postades av 2010-03-29 15:46:18 - Anders Persson

Hej igen.

Löste detta på egen hand och delar även med mig av koden ifall andra stöter på liknande problem.

Detta min gridview:

    <asp:GridView ID="gvCustomer" runat="server" AutoGenerateColumns="False" GridLines="None"
        CssClass="mGrid" PagerStyle-CssClass="pgr" AlternatingRowStyle-CssClass="alt"
        AllowSorting="True" OnSorting="gvCustomer_Sorting">
        <Columns>
            <asp:TemplateField>
                <ItemTemplate>
                    <asp:CheckBox ID="chkSelected" runat="server" EnableViewState="true" />&nbsp;
                    <asp:HiddenField ID="hfdID" runat="server" Value='<%# Eval("CRM_InboxId") %>' />
                </ItemTemplate>
            </asp:TemplateField>
            <asp:BoundField DataField="Name" HeaderText="Namn" SortExpression="Name" />
            <asp:BoundField DataField="Zipcode" HeaderText="Postnr" SortExpression="Zipcode" />
            <asp:BoundField DataField="State" HeaderText="Ort" SortExpression="State" />
            <asp:BoundField DataField="RowCreated" HeaderText="Inkom" SortExpression="RowCreated" />
        </Columns>
        <PagerStyle CssClass="pgr" />
        <AlternatingRowStyle CssClass="alt" />
    </asp:GridView>

Som ni ser så har jag lagt en HiddenField som är mappad till "CRM_InboxId"
Denna kolumn finns även i den DataTable som jag senare kommer att hämta datat ifrån.

Jag hämtar värden från en datatable
    private void loadCustomers()
    {
      gvCustomer.DataSource = _ccd.GetCustomer(0);
      gvCustomer.DataBind();

      if (gvCustomer.Rows.Count <= 0)
      {
        btnDelete.Enabled = false;
        btnProcess.Enabled = false;
      }
    }

Ovanstående kod förutsätter att du laddar datatable från t.ex en databas.


Sen loopar jag igenom hela gridview och slår samman alla IDnummer.
    private string getIdFromGridView()
    {
      string value = "";
      foreach (GridViewRow gvr in gvCustomer.Rows)
      {
        CheckBox c = gvr.FindControl("chkSelected") as CheckBox;
        HiddenField h = gvr.FindControl("hfdID") as HiddenField;
        if (c.Checked)
        {
          value = value + h.Value + ";";
        }
      }
      return value.Remove(value.Length - 1);
    }

Ovanstående kommer alltså bygga ihop samtliga markerade id nummer. Så strängen som returneras kan alltså se ut så här: 25;105;106;124;
Sedan slittar jag strängen till en array där jag kan hantera idnumren en i taget.
Det sista den gör "value.remove(value.Lengt - 1) är helt engelt att ta bort det senaste semicolonet för att få en riktig split på det. Glöm inte att lägga någon som hanterar ifall inga rader har markerats.

Om någon ser hur man kan optimera ovanstående kod så är jag intresserad av det.


MVH
Anders


Svara

Nyligen

  • 18:42 Hvor finder man håndlavede lamper
  • 18:41 Hvor finder man håndlavede lamper
  • 16:36 Allt du behöver veta om keramiskt
  • 16:14 Vem anlitar man egentligen när tak
  • 16:14 Vem anlitar man egentligen när tak
  • 16:13 Vem anlitar man egentligen när tak
  • 11:52 Noen erfaring med uttak hos Mostbe
  • 11:51 Noen erfaring med uttak hos Mostbe

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 570 585
27 958
271 741
6 200
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