44

I am using master pages. Can I locate a div within the page and throw some HTML in there?

1
  • 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. Commented Jan 21, 2009 at 21:19

5 Answers 5

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>
Sign up to request clarification or add additional context in comments.

3 Comments

Thanks a ton. Deadline of app moved up, really needed this code. thanks again
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.
Does this still works ? I tired and it doesn't work for me.
15

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

Comments

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).

Comments

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.

Comments

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.

1 Comment

Can give an example?

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.