我正在尝试创建一个扩展ASP.NET面板的新服务控件。
无论何时我使用我的面板,div等渲染都是正确的。但框中的输入仅为: title
ie:如果我这样做了:
<cc1:RoundedCornerBox id="MyBox" BoxWidth="100" BoxHeight="200"> This is the content that should be displayeed </cc1:RoundedBox>所有显示的内容都是: MyBox
(在正确的框中)
这是我的代码:
[DefaultProperty("Text")]
[ToolboxData("<{0}:RoundedCornerBox runat=server></{0}:RoundedCornerBox>")]
public class RoundedCornerBox : System.Web.UI.WebControls.Panel
{
public int BoxWidth { get; set; }
public int BoxHeight { get; set; }
[Bindable(true)]
[Category("Appearance")]
[DefaultValue("")]
[Localizable(true)]
public string Text
{
get
{
String s = (String)ViewState["Text"];
return ((s == null) ? "[" + this.ID + "]" : s);
}
set
{
ViewState["Text"] = value;
}
}
protected override void Render(HtmlTextWriter writer)
{
base.Render(writer);
}
protected override void RenderContents(HtmlTextWriter output)
{
output.Write(Text);
}
public override void RenderBeginTag(HtmlTextWriter writer)
{
base.RenderBeginTag(writer);
writer.Write("<div class=\"roundedcornr_lt\"></div>\n");
writer.Write("<div class=\"roundedcornr_top\" style=\"width:" + BoxWidth.ToString() + "px\"></div>\n");
writer.Write("<div class=\"roundedcornr_rt\"></div>\n");
writer.Write("<div class=\"clear\"></div>\n");
writer.Write("<div class=\"roundedcornr_lside\" style=\"height:" + BoxHeight.ToString() + "px\"></div>\n");
writer.Write("<div style=\"width:" + BoxWidth.ToString() + "px; height:" + BoxHeight.ToString() + "px; background:white; float:left\">\n");
}
public override void RenderEndTag(HtmlTextWriter writer)
{
base.RenderEndTag(writer);
writer.Write("</div>\n");
writer.Write("<div class=\"roundedcornr_rside\" style=\"height:" + BoxHeight.ToString() + "px\"></div>\n");
writer.Write("<div class=\"clear\"></div>\n");
writer.Write("<div class=\"roundedcornr_bl\"></div>\n");
writer.Write("<div class=\"roundedcornr_btm\" style=\"width:" + BoxWidth.ToString() + "px\"></div>");
writer.Write("<div class=\"roundedcornr_br\"></div>");
writer.Write("<div class=\"clear\"></div>\n");
}发布于 2014-09-21 04:46:33
有一种更简单的方法可以做到这一点。
CSS
OnInit()方法中,将CssClass属性设置为roundedbox样式(或任何其他名称)。
border-radius.例如:
.roundedbox {
border-radius: 3px;
}https://stackoverflow.com/questions/7298130
复制相似问题