UpdatePanel with HTML problems

               <tr>
                    <td align="right" valign="top">
                        <asp:label id="CurrentCourses" runat="server"></asp:label>
                    </td>
                    <asp:updatepanel id="CurrentCoursesUpdatePanel" runat="server">
                        <contenttemplate>
                            <td valign="top">
                                <asp:listbox id="CurrentCoursesList" runat="server" height="66px" width="214px" />
                                <br />
                                <asp:button id="AddCurrentCourse" runat="server" width="63px" />
                                <asp:button id="RemoveCurrentCourse" runat="server" width="83px" />
                            </td>
                        </contenttemplate>
                    </asp:updatepanel>
                </tr>
LVL 1
dba123Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

mzalewskiCommented:
Hi
Not sure what your problem is (you didnt post a description :)) - but I'm pretty sure that the ASP:UpdatePanel uses a DIV tag to wrap it's contents.
This would translate into invalid HTML:
<tr>
                    <td align="right" valign="top">
                        <asp:label id="CurrentCourses" runat="server"></asp:label>
                    </td>
                    <div id="CurrentCoursesUpdatePanel" >
                            <td valign="top">
                                <asp:listbox id="CurrentCoursesList" runat="server" height="66px" width="214px" />
                                <br />
                                <asp:button id="AddCurrentCourse" runat="server" width="63px" />
                                <asp:button id="RemoveCurrentCourse" runat="server" width="83px" />
                            </td>
                        </div>
                </tr>

Try this instead:
      <tr>
                    <td align="right" valign="top">
                        <asp:label id="CurrentCourses" runat="server"></asp:label>
                    </td>
                    <td valign="top">
                         <asp:updatepanel id="CurrentCoursesUpdatePanel" runat="server">
                             <contenttemplate>
                                   <asp:listbox id="CurrentCoursesList" runat="server" height="66px" width="214px" />
                                <br />
                                <asp:button id="AddCurrentCourse" runat="server" width="63px" />
                                <asp:button id="RemoveCurrentCourse" runat="server" width="83px" />
                             </contenttemplate>
                         </asp:updatepanel>
                      </td>
                </tr>
0
dba123Author Commented:
ahh, thanks! will try the div.  Not sure why DIV is so special in this case though.
0
jinn_hnnlCommented:
Lol... what is your problem...

Well I guess, some compile errors ?... I think it should be:

<tr>
    <td align="right" valign="top">
      <asp:label id="CurrentCourses" runat="server"></asp:label>
    </td>
   
    <td valign="top">
      <asp:updatepanel id="CurrentCoursesUpdatePanel" runat="server">
            <contenttemplate>
                  <asp:listbox id="CurrentCoursesList" runat="server" height="66px" width="214px" />
                  <br />
                  <asp:button id="AddCurrentCourse" runat="server" width="63px" />
                  <asp:button id="RemoveCurrentCourse" runat="server" width="83px" />
            </contenttemplate>
      </asp:updatepanel>
    </td>
</tr>

Normally what I do is put asp:UpdatePanel out of the scope of the table... It doesn't really matter you clearly specify which part of the page should only be post back... put the whole table or the div contains that table are not very different from only a column.

Hope this help

JINN ^^
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
Cloud Class® Course: Microsoft Windows 7 Basic

This introductory course to Windows 7 environment will teach you about working with the Windows operating system. You will learn about basic functions including start menu; the desktop; managing files, folders, and libraries.

jinn_hnnlCommented:
OMG... I had commented and forgot to post it >.< when I do... there were already 2 .... sorry I didn't mean to spam this way
0
dba123Author Commented:
no, no problem.  I'm just wondering why a div is needed at all in this case...seems like overkill.
0
dba123Author Commented:
I think I just had some other issues.  I cleaned up my html.  I don't see a need for a div.  This works just fine now.  He're an example now of one of my table rows:

                <tr>
                    <td align="right" valign="top">
                        <asp:label id="Highest" runat="server"></asp:label>
                    </td>
                    <td align="left" valign="top">
                        <asp:updatepanel id="HighestUpdatepanel" runat="server">
                            <contenttemplate>
                                <asp:listbox id="HighestList" runat="server" width="214px"/><br />
                                <asp:button id="AddHighest" runat="server" width="63px" />
                            </contenttemplate>
                        </asp:updatepanel>
                    </td>
                </tr>
0
mzalewskiCommented:
Well, the div is used as a placeholder for the content. The UpdatePanel is refreshed using javascript (AJAX) - once it has the new content, it needs somewhere to place it on the page. This can be done by finding the placeholder (the DIV element with the id 'CurrentCoursesUpdatePanel'), and replacing the old inner HTML with the new HTML.
Without this DIV element, it would not be possible to update it this way.
0
mzalewskiCommented:
Yes, thats what jinn_hnnl and I were pointing out - The UpdatePanel should be placed inside the TD element, not the TR.

I think you might have misunderstood my original post - The first html example I gave was what the output would look like (from your code).
The DIV element is rendered by the UpdatePanel control - All ASP.NET WebControls have a tag property that determines the HTML tag to use when rendering the control to the output page. This is set by the developers of the control. The UpdatePanel has it's tag set to DIV.
This means that whenever an UpdatePanel is rendered, its contents are in a DIV container.

This was where you were having the problem - in HTML, a TR element cannot contain a DIV child element. This would have caused problems when the browser tried to display it (it was probably out of place).
The UpdatePanel needed to be moved inside the TD element before it could produce valid HTML.
0
jinn_hnnlCommented:
yeahh after I posted (without knowing there were already one post with similar content), I said sorry for spaming. Because what I saw was the answer of first mzalewski is very similar with mine.

I meant the accepted answer should have belonged to him, and mine can be assisted. But thanks for the credit (and we will both happy if mzalewski can help some credit too ^^).

Well about updatePanel and the div. I am not sure whether it works without div or not (I think dba123 solution still works). But if you put it outside of the table, it looks nicer, and ... it might cover more part that needed. (you can apply this for more cases).
0
mzalewskiCommented:
It's ok - my original post was a bit confusing (I think he thought I was saying to place it inside a DIV element, which isn't what I meant :))

Next time, I'll be sure to explain things properly if I want the credit for it :)
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
ASP.NET

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.