问题描述
AjaxFileUpload适用于可见的TabContainer控件TabPanel,但不适用于最初不可见然后设置为可见的TabPanel。
我相信,如果TabPanels的可见性属性是通过JavaScript而不是通过服务器设置的,但不知道如何实现,则可以解决该问题。 请帮助我解决此问题。谢谢。
ASPX代码:
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="AjaxFileUpload.aspx.vb" Inherits="_Default" %>
<%@ 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></title>
</head>
<body>
<form id="form1" runat="server">
<asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server" EnablePageMethods="true"></asp:ToolkitScriptManager>
<p>AjaxFileUpload works on visible TabContainer control TabPanels yet not on ones that are initially invisible and then set to visible.</p>
<p>I believe the issue would be resolved if the visibility property of the TabPanels is set by JavaScript rather than from the server.</p>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
<ContentTemplate>
<asp:TabContainer ID="TabContainer1" runat="server" ActiveTabIndex="0">
<asp:TabPanel ID="TabPanel1" runat="server" HeaderText="TabPanel 1">
<ContentTemplate>
<asp:Button ID="btnShow" runat="server" Text="Show"></asp:Button>
</ContentTemplate>
</asp:TabPanel>
<asp:TabPanel ID="TabPanel2" runat="server" HeaderText="TabPanel 2" Visible="false">
<ContentTemplate>
<asp:Button ID="btnHide" runat="server" Text="Hide"></asp:Button>
<asp:AjaxFileUpload ID="AjaxFileUpload1" runat="server" AllowedFileTypes="txt,xls,xlsx,doc,docx,msg,pdf,bmp,gif,jpg,jpeg,png" MaximumNumberOfFiles="5" Width="500px" OnUploadComplete="AjaxFileUpload1_OnUploadComplete"></asp:AjaxFileUpload>
</ContentTemplate>
</asp:TabPanel>
</asp:TabContainer>
</ContentTemplate>
</asp:UpdatePanel>
</form>
</body>
</html>
后端VB.Net代码:
Imports System.IO
Imports AjaxControlToolkit
Partial Class _Default
Inherits System.Web.UI.Page
Protected Sub btnShow_Click(sender As Object,e As System.EventArgs) Handles btnShow.Click
If TabPanel2.Visible = False Then TabPanel2.Visible = True
TabContainer1.ActiveTabIndex = 1
AjaxFileUpload1.Visible = True
End Sub
Protected Sub btnHide_Click(sender As Object,e As System.EventArgs) Handles btnHide.Click
If TabPanel2.Visible = True Then TabPanel2.Visible = False
End Sub
Protected Sub AjaxFileUpload1_OnUploadComplete(ByVal sender As Object,ByVal e As AjaxFileUploadEventArgs)
Dim strPath As String = Server.MapPath("~/Uploads")
If Not Directory.Exists(strPath) Then Directory.CreateDirectory(strPath)
Dim sFilename As String = System.IO.Path.GetFileName(e.FileName)
Dim suploadpath As String = "~/Uploads/"
AjaxFileUpload1.SaveAs(Server.MapPath(suploadpath) + sFilename)
Dim filePath As String = Server.MapPath("~/Uploads/" & e.FileName)
Dim filename As String = Path.GetFileName(filePath)
End Sub
End Class
解决方法
实际上,即使将文本框设置为visible = false,该控件也不会向下发送到网页。因此,客户端甚至无法打开该简单文本框即可看到。
使用样式,不显示任何样式。
第一次初始化页面,其中包括js编写ajax上载程序。
因此,将混乱放入div(使用控件以及您需要隐藏/显示的其他任何内容) ,这样说:
<div id="uploader" runat="server" style="display:none;width:50%">
<ajaxToolkit:AjaxFileUpload ID="AjaxFileUpload1" runat="server"
ChunkSize="8192"
ClientIDMode="Static"
ViewStateMode="Enabled" />
</div>
因此,如果您使用的是服务器端代码(某些按钮回发),则可以显示“ div”,如下所示:
Protected Sub Button1_Click(sender As Object,e As EventArgs) Handles Button1.Click
Me.uploader.Style("display") = "inline"
End Sub
并隐藏:
Me.uploader.Style("display") = "none"
请记住,当我们发回邮件时,所有“爵士” JavaScript仍然需要在第一个页面加载时进行跳舞。 (因此,我们不能在首页加载时(针对控件或div)使用visible = false)。您需要加载整个页面-包括仅在ajaxupload控件第一次加载时运行的代码加载。如果不是第一页加载-控件将无法正确设置和初始化。
因此,通过使用样式,控件将在首次加载页面时呈现。这个概念不仅适用于Ajax,还适用于隐藏的文本框,或者什么呢?再次,使用不显示任何样式。
实际上,在用户选择文件并使用该控件上载过程中吗?好吧,你不想回帖。但是,当整个加载完成时?和服务器端事件(例如保存文件)一样,那么我经常想要一些最终代码,甚至是继续进行浏览的网页。我确实希望最后的回发继续进行。但是,我需要回发客户端!
代替使用JaveScript _dopostback? (这会迫使您在服务器端页面加载事件中编写参数代码?我只是在窗体上的某个位置放了一个ASP按钮,然后隐藏了它(当然使用style =“ display:none”)。
现在,我可以使用客户端js来“单击”该隐藏的按钮。这样的好处在于,用于单个按钮代码运行的服务器端事件代码存根,而我没有在加载事件中使用_doPostBack +代码编写事件代码来让代码存根服务器端运行!
现在,在上面,我在服务器端的代码后面显示了上载程序。
但是,您也可以很容易地使用客户端代码来隐藏或显示该div。
如果您使用jQuery()?
好吧,jQuery具有.hide()和.show()(猜猜是什么!-.hide()/。show()实际上为您设置了样式!!!-甚至jQuery都假定您隐藏或显示具有样式的控件,因为使用“ SomeControl.visible”几乎是无用的(因为任何设置为visible = false的内容都不会在客户端呈现-因此,无论如何您都无法隐藏/显示!!)。>
因此,要使用jQuery隐藏/显示它,可以使用以下客户端:
function show() {
$('#uploader').show();
}
function hide() {
$('#uploader').hide();
}
并且,如果您不使用jQuery,并且想要隐藏/显示div,那么? (javascript)。
这将起作用:
function showl2() {
var mydiv2 = document.getElementById('<%=uploader.ClientID%>');
mydiv2.style.display = "inline";
}
function hidel2() {
var mydiv = document.getElementById('<%=uploader.ClientID%>');
mydiv.style.display = "none";
}
因此,这里的简单概念是控件必须在页面加载时呈现,并且必须在第一次执行。因此,它必须落到浏览器端。任何不可见的控件都不会向下发送到客户端。但是,使用css意味着控件在所有情况下都是从客户端发送的。
现在,上传之后,我想在页面的背面发表完整的文章吗?好吧,请注意,这可能很困难,因为在运行ajax服务器端事件(例如保存文件)之后,当一切都说完之后,您不会得到最终的回复。
因此,我为ajax上载程序设置了一个客户端事件,如下所示:
<ajaxToolkit:AjaxFileUpload ID="AjaxFileUpload1" runat="server"
AllowedFileTypes="pdf,zip"
ChunkSize="8192"
OnClientUploadCompleteAll="UpLoadDone"
/>
因此,请注意上述客户端事件-所有代码(服务器和客户端均已完成)。但是我们现在希望从客户端进行回发。
那么,在UpLoadDone例程中?
我有这个:
function uploaddone() {
document.getElementById('<%= btnProof.ClientID %>').click();
}
因此,我得到了回复,并且按钮存根服务器端的代码也运行了。那个btProof隐藏了样式。但是,这是一个常规的asp.net按钮。我只是希望在ajax文件上传完成后单击它。但是,实际上并没有一种方法可以使ajax上载并触发所有内容。但是,再次: 使用带有样式的隐藏控件的概念-因为如果我使用.visible = false来隐藏该按钮,则实际上该按钮将不存在于客户端,并且永远不会呈现或放置到浏览器客户端。