在我的網站中,我已經使用asp文件上傳控件來上傳文件,onclick上傳按鈕將顯示一個面板,其中上傳的圖像將隨着textarea一起顯示編寫圖像的描述。寫完描述後,我必須將圖像保存到數據庫中,同時單擊動態創建的保存按鈕。請給出一些關於如何做到這一點的想法。我的前端代碼如下:如何通過動態加載的控件將數據保存到數據庫
<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);
}
}
,這是它的外觀上傳之前:
並上傳後,它看起來像這
請讓我知道如何將它保存到數據庫後,在下面的文本框中輸入說明t他上傳了照片。
我知道大家都知道facebook如何上傳專輯圖片。同樣,我想在上傳圖片後再將其保存在數據庫中。在Facebook中,描述文本框將被動態創建,如果我沒有錯的話。他們將如何引用每個描述文本框的內容並將其保存在數據庫中。希望我能說清楚。
動態創建保存按鈕的任何特定原因?不會切換可見性工作? – Karthik
http://forums.asp.net/p/1895457/5353700.aspx/1?Re+dynamically+created+link+button+s+click+event+not+firing – Karthik
@Karthik ..你看我已經創建在設計時只有一個面板,而我在運行時添加的所有其他內容。沒有具體的原因,但由於我遵循的設計,我必須這樣做。嗯會考慮它,是否如果我可以改變設計。 :) –