C# 动态添加控件时代码的优化程度
在我设计的网站中,我需要显示使用asp:FileUpload控件上传的图像。所以在上传之后,我使用字符串生成器添加div、img和textarea,然后将其加载到我已经创建的面板中。因此,使用Stringbuilder加载内部HTML更好,还是使用HtmlgenericControls添加图像和文本区域等控件更好。我用的是C#。我目前的编码方式如下:C# 动态添加控件时代码的优化程度,c#,asp.net,optimization,html,C#,Asp.net,Optimization,Html,在我设计的网站中,我需要显示使用asp:FileUpload控件上传的图像。所以在上传之后,我使用字符串生成器添加div、img和textarea,然后将其加载到我已经创建的面板中。因此,使用Stringbuilder加载内部HTML更好,还是使用HtmlgenericControls添加图像和文本区域等控件更好。我用的是C#。我目前的编码方式如下: protected void uploadFile_Click(object sender, EventArgs e) { if (Upl
protected void uploadFile_Click(object sender, EventArgs e)
{
if (UploadImages.HasFiles)
{
int tid = 0;
string fileExt = Path.GetExtension(UploadImages.FileName).ToLower();
if (fileExt == ".jpeg" || fileExt == ".png" || fileExt == ".jpg" || fileExt == ".bmp")
{
HtmlGenericControl d = new HtmlGenericControl("div");
Button btnsave = new Button();
btnsave.Text = "Save";
sb.Append("<div class=" + "\"savback\"" + ">");
sb.Append("<div class=" + "\"head\"" + ">Write Description</div>");
foreach (HttpPostedFile uploadedFile in UploadImages.PostedFiles)
{
id += 1;
tid = tid + 1;
string textid = "txt" + tid;
filepath = Server.MapPath("~/Images/Gallery/" + uploadedFile.FileName);
uploadedFile.SaveAs(filepath);
newpath = "../Images/Gallery/" + uploadedFile.FileName;
try
{
updtpanel.Visible = true;
sb.Append("<div class=" + "\"dataload\"" + ">");
sb.Append("<img class=" + "\"loadimg\"" + "src=" + "\"" + newpath.ToString() + "\"" + " />");
sb.Append("<textarea class=" + "\"txtdes\"" + "id=" + "\"" + textid + "\"" + "></textarea>");
sb.Append("</div>");
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
sb.Append("</div>");
d.InnerHtml = sb.ToString();
updtpanel.Controls.Add(d);
updtpanel.Controls.Add(btnsave);
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select only Image Files!!');", true);
}
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select a File First!!');", true);
}
}
前端:
<form id="form1" runat="server">
<div class="transbox" id="mainbk" runat="server" style="position:absolute; top:0px; left:0px; width: 100%; height: 100%;" >
<asp:FileUpload runat="server" ID="UploadImages" style="background-color:white; position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 350px; right: 251px;" Width="500px" AllowMultiple="true"/>
<asp:Button runat="server" ID="uploadedFile" style="position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 870px; width: 112px; height: 29px;" Text="Upload" OnClick="uploadFile_Click" />
<asp:Panel ID="updtpanel" runat="server" CssClass="transbox" style="width:100%;height:100%;left:0px;top:0px;position:absolute" Visible="false">
</asp:Panel>
</div>
</form>
其后端如下所示:
protected void uploadFile_Click(object sender, EventArgs e)
{
if (UploadImages.HasFiles)
{
int tid = 0;
string fileExt = Path.GetExtension(UploadImages.FileName).ToLower();
if (fileExt == ".jpeg" || fileExt == ".png" || fileExt == ".jpg" || fileExt == ".bmp")
{
HtmlGenericControl d = new HtmlGenericControl("div");
Button btnsave = new Button();
btnsave.Text = "Save";
sb.Append("<div class=" + "\"savback\"" + ">");
sb.Append("<div class=" + "\"head\"" + ">Write Description</div>");
foreach (HttpPostedFile uploadedFile in UploadImages.PostedFiles)
{
id += 1;
tid = tid + 1;
string textid = "txt" + tid;
filepath = Server.MapPath("~/Images/Gallery/" + uploadedFile.FileName);
uploadedFile.SaveAs(filepath);
newpath = "../Images/Gallery/" + uploadedFile.FileName;
try
{
updtpanel.Visible = true;
sb.Append("<div class=" + "\"dataload\"" + ">");
sb.Append("<img class=" + "\"loadimg\"" + "src=" + "\"" + newpath.ToString() + "\"" + " />");
sb.Append("<textarea class=" + "\"txtdes\"" + "id=" + "\"" + textid + "\"" + "></textarea>");
sb.Append("</div>");
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
sb.Append("</div>");
d.InnerHtml = sb.ToString();
updtpanel.Controls.Add(d);
updtpanel.Controls.Add(btnsave);
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select only Image Files!!');", true);
}
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select a File First!!');", true);
}
}
受保护的无效上载文件\u单击(对象发送方,事件参数e)
{
if(上传images.HasFiles)
{
int-tid=0;
字符串fileExt=Path.GetExtension(UploadImages.FileName.ToLower();
如果(fileExt==“.jpeg”| | fileExt==”.png“| | fileExt==”.jpg“| | fileExt==”.bmp”)
{
HtmlGenericControl d=新的HtmlGenericControl(“div”);
按钮btnsave=新按钮();
btnsave.Text=“保存”;
某人加上(“”);
某人附加(“写描述”);
foreach(UploadImages.PostedFiles中的HttpPostedFile uploadedFile)
{
id+=1;
tid=tid+1;
字符串textid=“txt”+tid;
filepath=Server.MapPath(“~/Images/Gallery/”+uploadedFile.FileName);
uploadedFile.SaveAs(文件路径);
newpath=“../Images/Gallery/”+uploadedFile.FileName;
尝试
{
updtpanel.Visible=true;
某人加上(“”);
某人加上(“”);
某人加上(“”);
某人加上(“”);
}
捕获(例外情况除外)
{
响应。写入(例如消息);
}
}
某人加上(“”);
d、 InnerHtml=sb.ToString();
updtpanel.Controls.Add(d);
updtpanel.Controls.Add(btnsave);
}
其他的
{
Page.ClientScript.RegisterStartupScript(GetType(),“msgbox”,“警报('请仅选择图像文件!!');”,true);
}
}
其他的
{
Page.ClientScript.RegisterStartupScript(GetType(),“msgbox”,“警报('请先选择一个文件!!');”,true);
}
}
请告诉我哪种方法是创建动态控件的好方法???最佳代码:
- 不包含超过50行难以阅读的代码(同意,它不是不可读的,但小的重构会有所帮助)
- 不会将CSS与HTML以及与演示文稿相关的HTML属性(如
)混合使用width
StringBuilder
还是HtmlGenericControl
作为一个非常模糊的术语,让我们回答一些稍微不同的问题:
StringBuilder
,因为这无关紧要。完全与下载图像所花费的时间(例如两秒钟,即2000毫秒)相比,StringBuilder
和HtmlGenericControl
之间的性能比较很可能不到一毫秒。在一个需要2000毫秒的过程中浪费1毫秒是否重要sb.Append("<div class=\"illustration\"><span-class=\"contents\">")
.Append("<img class=" + "\"loadimg\"" + "srv=" + "\"" + newpath + "\"" + ">")
.Append("/div></span>");
sb.追加(“”)
.Append(“写为srv
span class
应该是span class
src
(srv
)前面没有空格StringBuilder
的情况下,您很难对代码进行单元测试。让.NET Framework代替您生成HTML意味着您可以更专注于您所操作的实际对象,并且测试它们稍微容易一些HtmlGenericControl
将是一个负担,您必须选择字符串连接或一些模板系统。ASP.NET控件因生成不太好的HTML代码而闻名。鉴于您所问的HTML代码,此限制不适用于您的case.最佳代码:
- 不包含超过50行难以阅读的代码(同意,它不是不可读的,但小的重构会有所帮助)
- 不会将CSS与HTML以及与演示文稿相关的HTML属性(如
)混合使用width
StringBuilder
还是HtmlGenericControl
作为一个非常模糊的术语,让我们回答一些稍微不同的问题: