在 ASP.NET 中使用 AjaxControlToolkit 的异步 AJAXFileUpload 控件返回数据

2024-05-14

我正在使用上面的控件(注意它是 ASP.NET 控件。我似乎看到很多人使用用 javascript 编写的类似名称的控件)来允许使用进度条、拖放操作来上传多个文件,该部分一切正常,但我需要随文件返回两条数据。具体来说,用户从两个文本框中输入纬度和经度。由于上传控件是异步的,因此文本框的内容不会被发回,因此我无法访问它们。似乎有一个我可以挂钩的属性,ContextKeys,它将数据发送回服务器,但它是一个静态字段,我不知道如何动态操作它。我尝试从文本框中挂钩 ontextchanged 事件并使用它们来设置上下文键。回发有效并且似乎设置了该值,但是当用户按下上传按钮时,ContextKeys 值为空。

有人如何以编程方式设置上下文键属性,或者通过上传发送回数据的其他方式吗?

这是代码:

.ASPX

<div style="float:left; width: 325px;">
    <cc1:AjaxFileUpload ID="AjaxFileUpload1" runat="server" Width="325px" 
         onuploadcomplete="UploadComplete" ClientIDMode="Static" />
    <cc1:DynamicPopulateExtender ID="AjaxFileUpload1_DynamicPopulateExtender" 
        runat="server" Enabled="True" PopulateTriggerControlID="" 
        TargetControlID="AjaxFileUpload1">
    </cc1:DynamicPopulateExtender>
</div>
<div style="float:left">Latitude:
    <asp:TextBox ID="tbUploaderLat" runat="server" 
        ontextchanged="tbUploaderLat_TextChanged" AutoPostBack="True"></asp:TextBox><br />
    Longitude:
    <asp:TextBox ID="tbUploaderLon" runat="server"
        ontextchanged="tbUploaderLon_TextChanged" AutoPostBack="True"></asp:TextBox>
</div>

代码隐藏:

protected void UpdateLatLon() //this is called from the two events above
{
    AjaxFileUpload1.ContextKeys = tbUploaderLat.Text + "|" + tbUploaderLon.Text;
}

您可以按照描述自定义 AjaxFileUpload 控件here https://stackoverflow.com/a/13084169/360171 and here https://stackoverflow.com/a/11689062/360171并将文本框值传递给 UploadCompleted 事件处理程序,如下所示:

function uploadStarted(sender, args) {
     var latitude = $get("<%= tbUploaderLat.ClientID %>").value;
     var longitude = $get("<%= tbUploaderLon.ClientID %>").value;
     sender.contextKeys = { "latitude": latitude, "longitude": longitude };
}​

之后,您可以在 UploadComplete 处理程序中获取纬度和经度值:

protected void AjaxFileUpload1_OnUploadComplete(object sender, AjaxFileUploadEventArgs file)
{
    if (!string.IsNullOrEmpty(file.ContextKeys))
    {
        var longLat = new System.Web.Script.Serialization.JavaScriptSerializer().Deserialize<Dictionary<string, string>>(file.ContextKeys);
        var longitude = longLat["longitude"];
        var latitude = longLat["latitude"];
    }

    //code to save file

}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 ASP.NET 中使用 AjaxControlToolkit 的异步 AJAXFileUpload 控件返回数据 的相关文章

随机推荐