更新面板刷新C# - Ajax中函数调用后面的代码

时间:2011-11-05 08:09:23

标签: asp.net ajax c#-4.0 partial-page-refresh partial-postback

我正在使用Uploadify v2.1.4使用ASP.Net C#FM 4.0上传图像。

在这个页面中,我还有其他控件,但我想要一种功能,当我上传图像时,它应该自动刷新UpdatePanel1以显示上传的图像

Default.aspx文件

<asp:UpdatePanel ID="UpdatePanel1" runat="server" >
   <ContentTemplate>                                 
        <asp:DataList ID="DataList1" runat="server" DataSourceID="SqlDataSource1" RepeatDirection="Horizontal" >
            <ItemTemplate>
                <br /><img src='http://test.kashmirsouq.com/ImageUploads/<%# Eval("ImageID") %>' width="100px" height="100px"   vspace="2" hspace="2" border="1" />
                <br /><asp:LinkButton ID="lnkBtnDeleteImage" CommandArgument='<%# Eval("sno") %>' CommandName="Delete" runat="server">
         Delete</asp:LinkButton>
        <br />
            </ItemTemplate>
        </asp:DataList>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
            ConnectionString="<%$ ConnectionStrings:SQLConnectionString %>" 
            SelectCommand="SELECT [sno], [ImageID] FROM [User_Images]">
        </asp:SqlDataSource>
 </ContentTemplate>
</asp:UpdatePanel>

页面示例在这里test.kashmirSouq.com

我正在使用jQuery调用FileUplaad.aspx文件上传图片

<script type="text/javascript">
        $(document).ready(function () {
            $('#fuFiles').uploadify({
                'uploader': 'Scripts/uploadify.swf',
                'script': 'FileUploads.aspx',
                'cancelImg': 'Scripts/cancel.png',
                'auto': 'true',
                'multi': 'true',
                'fileExt': '*.jpg;*.gif;*.png',
                'buttonText': 'Browse...',
                'queueSizeLimit': 5,
                'simUploadLimit': 2
            });
        });

</script>

并在FileUpload.aspx.cs文件中将文件保存在服务器和数据库中, 我需要一种方法,以便我可以从FileUpload.aspx.cs中的函数saveData()刷新updatepanel1

protected int saveData()
{
            String strSql = "INSERT INTO HMS_User_Images(ImageID,UserID,ImageCreationDate) ";
            strSql += " VALUES ('" + filename + "','123456789', '" + DateTime.Now + "')";
            int result = DataProvider.intConnect_Select(strSql);
}

因此,当我上传图片时,应该刷新网格的部分页面更新。请举例说明我如何使用C#

来做到这一点

请建议我如何做这个代码示例将受到高度赞赏。

此致

2 个答案:

答案 0 :(得分:2)

如果您要刷新“更新”面板,请尝试此操作...

UpdatePanel1.Update();
  

如果页面启用了部分页面呈现,则在您调用时   更新方法,UpdatePanel控件的内容在更新中   浏览器。如果您具有必须的服务器代码,请调用Update方法   执行以确定是否应更新UpdatePanel控件。   如果您计划使用Update方法,请将UpdateMode属性设置为   有条件的。如果您想要更新面板的决定   在服务器逻辑中确定,确保ChildrenAsTriggers   property为false,并且没有为其定义显式触发器   面板。

     

在典型的页面开发方案中,如果您定义触发器或if   对于UpdatePanel控件,ChildrenAsTriggers属性为true,   在页面生命周期中自动调用Update方法。

     

如果没有为UpdatePanel定义ContentTemplate属性   控制,不会发生面板更新。

答案 1 :(得分:1)

尝试在Onupload完成事件后使用响应显示图像。因此,当用户上传后,您将立即找到该图像。

这是剧本:

<script type="text/javascript">
    $(window).load(
function () {
    $("#fileInput1").uploadify({
        'uploader': 'scripts/uploadify.swf',
        'cancelImg': 'images/cancel.png',
        'buttonText': 'Browse Files',
        'script': 'Upload.aspx',
         'folder': 'uploads',
        'fileDesc': 'Image Files',
        'fileExt': '*.jpg;*.jpeg;*.gif;*.png',
        'queueSizeLimit': 9999,
        'simUploadLimit': 2,
        'sizeLimit': 4000000,
        'multi': true,
        'auto': true,
        'onComplete': function (event, queueID, fileObj, response, data) {
            $("#thumbnail").append(response)
        },

        'onError': function (event, ID, fileObj, errorObj) {
            alert(errorObj.type + ' Error: ' + errorObj.info);
        }


    });
    }
    );

</script>

这是处理程序:

<%@ WebHandler Language="VB" Class="UploadVB" %>

Imports System
Imports System.Web
Imports System.IO
Imports System.Drawing
Public Class UploadVB : Implements IHttpHandler

    Public Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest

        Dim postedFile As HttpPostedFile = context.Request.Files("Filedata")

        Dim savepath As String = ""
        Dim tempPath As String = ""
        tempPath = System.Configuration.ConfigurationManager.AppSettings("FolderPath")
        savepath = context.Server.MapPath(tempPath)
        Dim filename As String = postedFile.FileName
        If Not Directory.Exists(savepath) Then
            Directory.CreateDirectory(savepath)
        End If
        If Not Directory.Exists(savepath + "\thumbs") Then
            Directory.CreateDirectory(savepath + "\thumbs")
        End If


        postedFile.SaveAs((savepath & "\") + filename)
        Dim fullImage As System.Drawing.Image = New System.Drawing.Bitmap((savepath & "\") + filename)

        Dim newWidth As Integer = 100
        Dim newHeight As Integer = 80

        Dim temp As New Bitmap(newWidth, newHeight)
        Dim newImage As Graphics = Graphics.FromImage(temp)
        newImage.DrawImage(fullImage, 0, 0, newWidth, newHeight)
        temp.Save((savepath + "\thumbs" & "\") + "t_" + filename)

        context.Response.Write("<a href='" + (tempPath & "/") + filename + "'><img src='" + tempPath + "/thumbs" & "/" + "t_" + filename + "'/></a>")
        context.Response.StatusCode = 200
        'context.Response.Write("OK")

    End Sub

    Public ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable
        Get
            Return False
        End Get


       End Property

End Class

在上面的代码中,您可以在用户上传后立即找到缩略图,找到图片的缩略图。

相关问题