繁体   English   中英

以编程方式将样式表和javascript引用添加到asp.net主页

[英]programmatically add stylesheet and javascript references to asp.net masterpage

我正在使用灯箱,但我只希望对样式表和javascript文件的引用在网站上一个页面(使用灯箱的页面)的主页标题中。 如何以编程方式在页面加载中添加对样式表和javascript文件的引用?

样式表是“ css”文件夹,三个javascript文件是“ js”文件夹

尝试...

Page.ClientScript.RegisterClientScriptInclude("JScripts", ResolveUrl("~/js/JScripts.js"));

将两个占位符(“ JsPlaceholder”和“ CSSPlaceholder”)添加到母版页眉上,并调用以下方法:

public void AddJavascriptFile(string path)
{
    PlaceHolder p = (PlaceHolder)Page.Header.FindControl("JsPlaceholder");
    p.Controls.Add(new LiteralControl(string.Concat("<script type='text/javascript' src='", path, "'></script>\n")));
}

public void AddCssFile(string urlPath)
{
    HtmlLink cssLink = new HtmlLink();
    cssLink.Href = path;
    cssLink.Attributes.Add("rel", "stylesheet");
    cssLink.Attributes.Add("type", "text/css");
    PlaceHolder p = (PlaceHolder)Page.Header.FindControl("CssPlaceholder");
    p.Controls.Add(cssLink);
}

你可以这样

将此添加到您的标头中:

  <asp:placeholder runat="server" id="lightbox" visible="false">

        <link rel="stylesheet" href="/css/style.css" />
        <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"</script>
        </asp:placeholder>

并从您的代码隐藏集

lightbox.visible=true;

您还应该注意,通常您希望在页面上保留尽可能多的html,而不是将其保留在代码中,因此设计人员可以轻松进行更改

尝试(在C#中,但您应该了解一下):

protected override void OnLoad(EventArgs e)
{
    base.OnLoad(e);
    HtmlLink cssLink = new HtmlLink();

    //Create and configure the CSS link.
    cssLink.Attributes.Add("rel", "Stylesheet");
    cssLink.Attributes.Add("type", "text/css");
    cssLink.Href = "~/Path/To/File.css";

    //Add the CSS link to the page header.
    this.Header.Controls.Add(cssLink);

    //Add a script include to the page's ClientScript.
    this.ClientScript.RegisterClientScriptInclude("NameOfScript", this.ResolveUrl("~/Path/To/File.js"));
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM