【发布时间】:2014-11-04 10:08:37
【问题描述】:
我有一个在弹出窗口中使用的 asp.net 页面。这个弹出窗口基本上包含两个图像控件,并且标记包含 JCrop 插件。从页面中,弹出窗口打开,因此页面加载。我正在以字节为单位读取图像,转换为 base64 并将其设置为两个图像控件的 src 属性(两者都有 runat='server')。该页面中有2个按钮。但是点击这些按钮并没有触发任何事件处理程序,如 page_load、button_clicked 等。
<img id="target" runat="server" alt="Main Image" />
<img id="imgCropped" runat="server" alt="Preview Image" class="jcrop-preview" style="border-color:gray" />
protected void Page_Load(object sender, EventArgs e)
{
strMIMEType = Session["MIMEType"].ToString();
strImageData = Session["ImageData"].ToString();
strImageName = Session["ImageName"].ToString();
if (!IsPostBack)
{
string sTemp = "data:" + strMIMEType + ";base64," + strImageData;
target.Src = sTemp;
imgCropped.Src = sTemp;
}
}
下面的代码是当用户选择一个图像文件并点击 UploadClick 按钮时。
protected void btnUploadclick(object sender, EventArgs e)
{
HttpPostedFile objfile = AsyncUpload.PostedFile;
if (AsyncUpload.HasFile)
{
if (!IsImageValid(objfile))
ClientScript.RegisterClientScriptBlock(this.GetType(), "ImageNotValid", "alert('Image format is wrong. Please upload JPEG, PNG or GIF images.')");
else
{
Session["ImageData"] = Convert.ToBase64String(System.IO.File.ReadAllBytes(objfile.FileName), 0, System.IO.File.ReadAllBytes(objfile.FileName).Length);
Session["MIMEType"] = objfile.ContentType;
Session["ImageName"] = AsyncUpload.FileName;
ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "OpenPopUp", "window.open('ImageCropPopup.aspx', 'CropImage', 'height=450,width=700,left=350,top=170,resizable=no,scrollbars=no,toolbar=no,status=no');", true);
}
}
else
ClientScript.RegisterClientScriptBlock(this.GetType(), "ImageNotUploaded", "alert('Please select an Image.')");
}
当我单击任何按钮时,它根本不会点击 page_load。请帮忙。
【问题讨论】:
-
弹出窗口中的 .aspx 页面是否引用了正确的代码隐藏文件?
-
如果您直接加载页面(即不是通过弹出窗口),提交点击时会触发事件吗?您应该为容器页面和弹出窗口页面提供标记
-
@Dennis R,是的,它指的是背后的正确代码。正如我所说,从容器页面中,当我调用 window.open 时,弹出页面第一次正确打开,事件背后的所有代码都命中了它们各自的处理程序。但之后我裁剪图像并点击保存(其中一个按钮),然后它说页面无法显示。
-
那么这完全是一个不同的问题。您必须检查
Save按钮的代码为什么它会导致page can not be displayed -
@Jonathan 即使我直接加载页面,同样的事情。添加更多描述: 在容器页面中,我有一个 FileUpload 控件。用户正在那里选择一个文件。我将文件转换为 base64 字符串并分配给 Session 并打开弹出窗口,我正在访问它并分配给 img 选项卡的 src 属性。编辑问题并包含更多代码。
标签: c# jquery asp.net image jcrop