繁体   English   中英

AjaxFileUpload 在 ASP.NET VB.Net 中不起作用

[英]AjaxFileUpload does not work in ASP.NET VB.Net

AjaxFileUpload 适用于可见的 TabContainer 控件 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 的文本框,也不会将控件发送到 web 页面。 因此,您甚至无法将那个简单的文本框变为可见的客户端。

使用样式,不显示。

页面第一次被初始化,其中包括 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 仍然需要在第一个页面加载时跳舞。 (因此,我们不能在第一页加载时使用 visible = false)(以及针对控件或 div)。 您需要加载整个页面 - 包括仅在 ajaxupload 控件加载的第一次运行的大量代码。 如果它不是第一页加载 - 控件将无法正确设置和初始化。

因此,通过使用样式,控件会在页面首次加载时呈现。 而且这个概念不仅适用于 ajax,还适用于隐藏文本框或其他什么? 同样,使用不显示的样式。

事实上,在用户选择文件并使用该控件上传的过程中? 好吧,你不想回帖。 但是当整个上传完成时? 和服务器端事件(例如保存文件),然后我经常想要一些最终代码,甚至 web 页面继续前进。 我确实想要一个最后的回传继续前进。 但是,我需要一个回发客户端!

代替使用 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 隐藏该按钮,那么实际上该按钮将不存在客户端,并且永远不会呈现或放置到浏览器客户端.

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM