44

Mind you, I am using master pages, but can I locate a div within the page and throw some html in there? Thanks.

Joel Coehoorn
  • 399,467
  • 113
  • 570
  • 794
Sara Chipps
  • 9,322
  • 11
  • 58
  • 103
  • Are you talking about within a page or control and of which on the server or client side? There are a few different sides to this, I think but generally the answer is yes though YMMV. – JB King Jan 21 '09 at 21:19

5 Answers5

84

You can add a div with runat="server" to the page:

<div runat="server" id="myDiv">
</div>

and then set its InnerHtml property from the code-behind:

myDiv.InnerHtml = "your html here";

If you want to modify the DIV's contents on the client side, then you can use javascript code similar to this:

<script type="text/javascript">
    Sys.Application.add_load(MyLoad);
    function MyLoad(sender) {
        $get('<%= div.ClientID %>').innerHTML += " - text added on client";
    }
</script>
M4N
  • 94,805
  • 45
  • 217
  • 260
  • 1
    Thanks a ton. Deadline of app moved up, really needed this code. thanks again – Eon Jun 30 '14 at 07:50
  • I used your approach and used it quite well with a `stringbuilder` and returning a serialized string to js side. Do you mind if I add it into your answer. Because without the serialization certain double quoted strings will not be properly transferred from C# to js. – aspiring Jun 05 '15 at 06:13
  • Does this still works ? I tired and it doesn't work for me. – Sandip Subedi Dec 29 '16 at 18:58
15

Use asp:Panel for that. It translates into a div.

Otávio Décio
  • 73,752
  • 17
  • 161
  • 228
5

Remember using

myDiv.InnerHtml = "something";

will replace all HTML elements in myDIV. you need to append text to avoid that.In that this may help

myDiv.InnerHtml = "something" + myDiv.InnerText;

any html control in myDiv but not ASP html controls(as they are not rendered yet).

Vivek Raj
  • 459
  • 5
  • 16
3

You could reference controls inside the master page this way:

void Page_Load()
{
    ContentPlaceHolder cph;
    Literal lit;

    cph = (ContentPlaceHolder)Master.FindControl("ContentPlaceHolder1");

    if (cph != null) {
        lit = (Literal) cph.FindControl("Literal1");
        if (lit != null) {
            lit.Text = "Some <b>HTML</b>";
        }
    }

}

In this example you have to put a Literal control in your ContentPlaceholder.

splattne
  • 102,760
  • 52
  • 202
  • 249
1

You want to put code in the master page code behind that inserts HTML into the contents of a page that is using that master page?

I would not search for the control via FindControl as this is a fragile solution that could easily be broken if the name of the control changed.

Your best bet is to declare an event in the master page that any child page could handle. The event could pass the HTML as an EventArg.

Jim Petkus
  • 4,500
  • 25
  • 19