父页面包括带有AsyncFileUpload的iframe表单。上传并点击“发送”后重定向到“_top”

时间:2011-05-10 16:17:00

标签: c# asp.net asp.net-ajax ajaxcontroltoolkit asyncfileupload

我有一个包含iframe的父网页(testFrame.aspx)

iframe是带有AsyncFileUpload控件(ajaxcontroltoolkit)的aspx格式(form.aspx)
表单包含一个文本框和一个必填字段验证器 在bt_Send Codebehind中,我检查用户是否在文本框中输入了文本,如果没有,则显示错误消息。

现在,如果我测试我的父表单并输入文本并单击“发送”,我会看到我的反馈信息(我在文本框中输入的文字)。
如果我没有输入文本,然后单击“发送”,则会收到错误消息。

现在发生了奇怪的事情:如果我没有输入文本,但我上传了一个带有AsyncFileUpload的文件。
我点击“发送”而不是收到错误消息,我被重定向到我的父页面之外的form.aspx(如target =“_ top”),没有错误消息。我只是在iframe中看到了干净的表单。

我不想那样。我希望表单留在我的父页面

testForm.aspx看起来像这样:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    This is a container page. The following is inside an iframe:
    <br />

    <iframe src="form.aspx" width="800px" height="400px"></iframe>
    </div>
    </form>
</body>
</html>

form.aspx看起来像这样:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="form.aspx.cs" Inherits="TestToolkit.form" %>

<%@ Register assembly="AjaxControlToolkit" namespace="AjaxControlToolkit" tagprefix="asp" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title>Test Form</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:Label ID="lblFirstName" runat="server" Text="First Name"></asp:Label>&nbsp;&nbsp;
        <asp:TextBox ID="txtFirstName" runat="server"></asp:TextBox>

        <br /><br />
        <asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server">
        </asp:ToolkitScriptManager>
        Upload picture: <asp:AsyncFileUpload ID="AsyncFileUpload1" runat="server" ClientIDMode="AutoID" />

            <div id="uploadOk" style="position: relative; left: 330px; bottom: 40px; width:0px; height:0px; display: none;"><asp:Image ID="imgOk" ImageUrl="_img/check-mark-40.png" runat="server" style="" AlternateText="Erledigt!" /></div>

        <br /><br />
        <asp:Button ID="btSend" runat="server" onclick="btSend_Click" Text="Send" />
        <br /><br />
        <asp:Label ID="lblFeedback" runat="server"></asp:Label>
&nbsp;<asp:RequiredFieldValidator runat="server" ID="rfvFirstName" ControlToValidate="txtFirstName" Display="None" EnableClientScript="false" />
    </div>
    </form>
</body>
</html>

和form.aspx.cs背后的代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace TestToolkit
{
    public partial class form : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
        }

        protected void btSend_Click(object sender, EventArgs e)
        {
            //ShowOrRemoveErrors();

            if (IsValid)
            {
                lblFeedback.Text = txtFirstName.Text;
            }
            else
            {
                lblFeedback.Text = "Please enter your name";
            }
        }
    }
}

1 个答案:

答案 0 :(得分:1)

嗯,我想我找到了问题的答案。

如果上传文件且字段无效(或必填字段没有文字),则会出现问题。

问题来自回发。所以我所做的是使用EnableClientScript="true"实现客户端验证:

<asp:RequiredFieldValidator runat="server" ID="rfvFirstName" ControlToValidate="txtFirstName" Display="None" EnableClientScript="true" />

使用客户端验证时,除非正确填写所有必填字段,否则不会回发。

希望这有助于解决同样问题的人。