JQuery和.NET如何结合工作

关于JQ+NET 结合的方法有以下(2009-07-24)

 

1 (网上搜索的) 使用WebService        感觉麻烦了。要建立WebService

 

2 使用PageMethod ,例子如下(网上搜索的例子)

我在使用过程中发现,必须设置contentType才可以,请注意

contentType: "application/json; charset=utf-8"//调用PageMethod必须设置此项

C#代码

[System.Web.Services.WebMethod]  
    public static string GetDate()
    {
        return DateTime.Now.ToString();
    }

 

JS代码

$.ajax({
      type: "POST",
      url: "Default.aspx/GetDate",
      data: "{}",
      contentType: "application/json; charset=utf-8",
      dataType: "json",
      success: function(msg) {
        // 使用 Page Method 的返回值来替代 div 的内容
        $("#Result").text(msg.d);
      }

 

以上方法经过验证.必须在NET3.5的环境下才能正确运行

 

3 使用__EVENTTARGET和__EVENTARGUMENT
如果不清楚这2个东西是什么,请网友搜索一下相关资料,看看。NET是如何提交服务器的
如果有能否支持自动回发的控件在页面中,。NET会自动生成一段设置__EVENTTARGET和__EVENTARGUMENT值的代码,
但是由于使用了JQ,我们就不再需要使用NET控件的自动回发功能,页面就不会再自动生成设置__EVENTTARGET和__EVENTARGUMENT值的代码
所以我们首先需要自己写一段赋值的代码

 

JS代码
function SetSubmitHiddenField(target, argument, formObj) {
    var _form = formObj == undefined ? document.forms[0] : formObj;
    if ($("#__EVENTTARGET").length == 0) {
                $(_form).append("<input type=/"hidden/" name=/"__EVENTTARGET/" id=/"__EVENTTARGET/" />"); //value=/"/"
    }
    if ($("#__EVENTARGUMENT").length == 0) {
                $(_form).append("<input type=/"hidden/" name=/"__EVENTARGUMENT/" id=/"__EVENTARGUMENT/"  />"); //value=/"/"
    }

    _form.__EVENTTARGET.value = target;
    _form.__EVENTARGUMENT.value = argument;
}

这样做有什么用呢,就是因为我们在点下了button1之后,提交到服务端时,后台能够知道要调用button1_onclick事件
执行完了button1_onclick事件之后,会返回数据,在这里,你可以选择返回HTML还是返回JSON格式。。
至于如何刷新页面,就由待各位写JS去更新页面了。

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
ASP.NET jQuery进度条上传是一种常见的网页上传文件功能。通过前端jQuery插件和后端ASP.NET技术,实现了文件上传过程的进度条展示,提高了用户体验和操作效率。具体实现方式如下: 1. 前端实现 使用jQuery的ajaxForm插件,结合jQueryUI的progressbar插件,进行文件上传进度条的展示。在HTML页面上添加上传表单和进度条,通过ajaxForm设置表单提交事件,实现文件上传过程进度条的实时更新。代码如下: ``` <form id="uploadForm" enctype="multipart/form-data" method="post" action="UploadFile.ashx"> <input type="file" name="fileUpload" /> <input type="submit" value="上传" /> </form> <div id="progressBar"></div> ``` ``` $("#uploadForm").ajaxForm({ beforeSend: function() { $("#progressBar").progressbar({ value: 0 }); }, uploadProgress: function(event, position, total, percentComplete) { $("#progressBar").progressbar({ value: percentComplete }); }, success: function() { $("#progressBar").progressbar({ value: 100 }); alert("上传成功!"); }, error: function() { alert("上传失败!"); } }); ``` 2. 后端实现 在ASP.NET,通过HttpHandler实现文件上传处理,从request对象获取上传的文件信息,根据文件大小和上传进度,实时更新进度条的值。代码如下: ``` <%@ WebHandler Language="C#" Class="UploadFile" %> using System; using System.Web; public class UploadFile : IHttpHandler { public void ProcessRequest (HttpContext context) { context.Response.ContentType = "text/plain"; HttpPostedFile file = context.Request.Files["fileUpload"]; int fileSize = file.ContentLength; int bytesRead = 0; byte[] buffer = new byte[8192]; using (System.IO.Stream stream = file.InputStream) using (System.IO.BinaryReader reader = new System.IO.BinaryReader(stream)) using (System.IO.MemoryStream ms = new System.IO.MemoryStream()) { double percentComplete = 0; int totalRead = 0; while ((bytesRead = reader.Read(buffer, 0, buffer.Length)) > 0) { ms.Write(buffer, 0, bytesRead); totalRead += bytesRead; percentComplete = (double)totalRead / fileSize * 100; context.Response.Write(percentComplete.ToString()); } } } public bool IsReusable { get { return false; } } } ``` 综上,ASP.NET jQuery进度条上传,通过前后端技术的组合应用,在网页上传过程有效展示文件上传进度和结果,提升了用户的体验感和操作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胖胖的洋葱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值