通过静态方法获取控件的 HTML
我正在尝试以下操作:
public partial class PopUps : System.Web.UI.Page {
public string GetContentFromPlaceHolder(string strContentId) {
HtmlTextWriter writer = new HtmlTextWriter(new System.IO.StringWriter());
plcPlaceHolderToGet.RenderControl(writer);
string strHtml = writer.InnerWriter.ToString();
return strHtml;
}
public static string GetContent() {
PopUps puToUse = new PopUps();
string strHtml = puToUse.GetContentFromPlaceHolder();
return strHtml;
}
}
但是,当我从另一个页面运行静态方法 GetContent
时,我收到此错误:
未将对象引用设置为对象的实例
对象引用未设置为线上
plcPlaceHolderToGet.RenderControl(writer);
的 ID 是正确的,似乎我需要在页面上运行某种控件的实例化,然后才能获取其中一个控件的 HTML 。
我缺少什么?
页面的设计视图看起来像这样,
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="PopUps.aspx.cs" Inherits="PopUps" %>
<asp:PlaceHolder runat="server" id="plcPlaceHolderToGet">
<div>
Some more HTML...
</div>
</asp:PlaceHolder>
<asp:PlaceHolder runat="server" id="plcAnotherPlaceHolder">
<div>
Some more HTML...
</div>
</asp:PlaceHolder>
我试图这样做是为了有一个地方来保存我的所有 HTML。 HTML,有时需要从其他 C# 代码中获取,有时需要通过 AJAX 调用获取。
I am trying the following:
public partial class PopUps : System.Web.UI.Page {
public string GetContentFromPlaceHolder(string strContentId) {
HtmlTextWriter writer = new HtmlTextWriter(new System.IO.StringWriter());
plcPlaceHolderToGet.RenderControl(writer);
string strHtml = writer.InnerWriter.ToString();
return strHtml;
}
public static string GetContent() {
PopUps puToUse = new PopUps();
string strHtml = puToUse.GetContentFromPlaceHolder();
return strHtml;
}
}
However, when I run the static method GetContent
from another page I get this error:
object reference not set to an instance of an object
on the line
plcPlaceHolderToGet.RenderControl(writer);
The ID of the control is correct, it just seems like I need to run some kind of instantiation of the controls on the Page before I can get the HTML of one of the controls.
What am I missing?
The design view of the page looks like this
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="PopUps.aspx.cs" Inherits="PopUps" %>
<asp:PlaceHolder runat="server" id="plcPlaceHolderToGet">
<div>
Some more HTML...
</div>
</asp:PlaceHolder>
<asp:PlaceHolder runat="server" id="plcAnotherPlaceHolder">
<div>
Some more HTML...
</div>
</asp:PlaceHolder>
I am trying to do this to have one place to hold all my HTML. HTML, that sometimes needs to be fetched from other C# code and sometimes through an AJAX call.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我这样解决了它:
HtmlBits.aspx:
HtmlBits.aspx.cs 的两个唯一方法:
HtmlBitsContent.ascx:
HtmlBitsContent.ascx 的后端:
现在可以通过其他随机 .cs 文件中的代码调用不同的 HTML 位:
或者
然而,HTML 位也可以通过 AJAX 在一些随机 JavaScript 文件中获取(此处使用 jQuery 显示):
请注意,上面的所有代码只是大致了解我所做的事情。
它不是即插即用的,但如果其他人需要维护一些小的 HTML 片段并从几个不同的地方获取它们,那么它绝对有用。
甚至可以通过 GetArg 方法输入一些参数以在 HTML 中显示。
享受 :)
I solved it like this:
HtmlBits.aspx:
The two only methods of HtmlBits.aspx.cs:
HtmlBitsContent.ascx:
The backend of HtmlBitsContent.ascx:
Now the different HTML bits can be called via code in some other random .cs file:
or
However the HTML bits can also be fetched via AJAX in some random JavaScript-file (here shown with jQuery):
Please note that all of the code above is only to give a general idea of what I did.
It's not plug n' play but definitely useful if someone else needs to maintain some small HTML snippets and fetch them from several different places.
It's even possible to input some arguments to show in the HTML through the GetArg method.
Enjoy :)
由于您想在应用程序的各个位置重用 html,我建议创建一个 用户控制。
ASP.NET Web 表单中的每个请求都必须针对页面(或 HttpHandler)。因此,为了通过 ajax 访问您的控件,您需要将其添加到页面,然后从 javascript 请求它。
您可以使用 jQuery 的
$.get()
方法:Since you want to reuse html in various places in your app, I would recommend creating a User Control.
Every request in ASP.NET web forms must be to a page (or an HttpHandler). So in order to access your control via ajax, you'll need to add it to a page and then request it from javascript.
You could use jQuery's
$.get()
method: