Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Bubble Event for obtaining dropdownlist index change in a formview insert template

Posted on 2006-10-20
5
Medium Priority
?
535 Views
Last Modified: 2012-08-14
I have a FormView "FormView1" which contains a drop down list "dropdownlist1" in the insert template.  I need to be able to get the value when the selected index is changed in the drop down list.  I understand this is done using bubble events.  How do I do this in c#?
0
Comment
Question by:dodgybouy
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
5 Comments
 
LVL 7

Expert Comment

by:here4u247
ID: 17772370
you set the selected indexchanged event to the dropdown which calls an event handler everytime the selection change i.e.

                 <asp:DropDownList AutoPostBack="True" ID="DropDownList1" runat="server"
                         OnSelectedIndexChanged="DeliveryIDDropDownList_SelectedIndexChanged">
                         <asp:ListItem>1</asp:ListItem>
                         <asp:ListItem>2</asp:ListItem>
                    </asp:DropDownList

C# event handler:


    protected void DeliveryIDDropDownList_SelectedIndexChanged(object sender, EventArgs e)
    {
        DropDownList ddlDel = (DropDownList)sender;
//Do stuff
    }

Hope that helps
0
 

Author Comment

by:dodgybouy
ID: 17773438
This is helpful and has got me half way to solving the problem.  However when I use this code the action only triggers after the command event is triggered by the template (i.e. somebody clicking the update or cancel button).  what is require is for the event to trigger when the selected index changes on the drop down list.  

To do this I understand you have to use a bubble event to trigger the templates command event when the selected index change event fires within the template.  Do you know how to do this?
0
 
LVL 7

Expert Comment

by:here4u247
ID: 17774097
where did you put the dropdownlist, insertTemplate/EditTemplate or somewhere else? because i use formview with databound dropdownlist and i can fire selected index change event properly...

can you show us your code?
0
 

Author Comment

by:dodgybouy
ID: 17774131
I put the dropdownlist in an edit template,

aspx file

<asp:FormView ID="FormView1" runat="server" DataKeyNames="ID"
        DataSourceID="SqlDataSource2" DefaultMode="Edit" Visible="False"
        OnItemUpdated="FvComment_Updated" OnItemUpdating="FvComment_Updating" OnItemCommand="FvComment_Command">
            <HeaderTemplate>
                <strong>Comment</strong>
            </HeaderTemplate>
            <EditItemTemplate>
                <strong>Select Comment:</strong>
                <asp:DropDownList ID="DropDownList1" runat="server" DataSourceID="sqlDSGetComment"
                    DataTextField="Comment"  OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged"
                    DataValueField="CommentID" SelectedValue='<%# Bind("CommentID") %>'>
                </asp:DropDownList><asp:SqlDataSource ID="sqlDSGetComment" runat="server" ConnectionString="<%$ ConnectionStrings:AngusConnectionString %>"
                    SelectCommand="spGetCommentType" SelectCommandType="StoredProcedure"></asp:SqlDataSource>
                <br />
                <asp:LinkButton ID="UpdateButton" runat="server" CausesValidation="True" CommandName="Update"
                    Text="Update" OnClientClick="return confirm('Are you sure that you want to update this comment, all current data will be lost?');" >

                </asp:LinkButton>
                <asp:LinkButton ID="UpdateCancelButton" runat="server" CausesValidation="False" CommandName="Cancel"
                    Text="Cancel">
                </asp:LinkButton>
            </EditItemTemplate>

Code behind file

protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
        {
            DropDownList ddl1 = (DropDownList)sender;

            Response.Write(ddl1.SelectedValue.ToString());
        }
0
 
LVL 7

Accepted Solution

by:
here4u247 earned 2000 total points
ID: 17774268
ahaa i see, what you need is AutoPostBack="True" i.e.

<asp:DropDownList ID="DropDownList1" AutoPostBack="True"   runat="server" DataSourceID="sqlDSGetComment"
                    DataTextField="Comment"  OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged"
                    DataValueField="CommentID" SelectedValue='<%# Bind("CommentID") %>'>

0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I recently went through the process of creating a Calendar Control of events with the basis of using a database to keep track of the dates that are selectable, one requirement was to have the selected date pop-up in a simple lightbox.  At first this…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
In this video, Percona Solution Engineer Rick Golba discuss how (and why) you implement high availability in a database environment. To discuss how Percona Consulting can help with your design and architecture needs for your database and infrastr…
We’ve all felt that sense of false security before—locking down external access to a database or component and feeling like we’ve done all we need to do to secure company data. But that feeling is fleeting. Attacks these days can happen in many w…
Suggested Courses

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question