asp.net jquery 调用websercie填充GRID的问题


 先上代码,再指出要注意的地方,

  <script type="text/javascript" src="js/jquery/jquery.easyui.min.js"></script>
        <script type="text/javascript" src="js/locale/easyui-lang-zh_CN.js"></script>

        <script type="text/javascript">
            $(function () {
                $('#tabList').datagrid({
                    iconCls: 'icon-forward',
                 
                    border: true,
                    rownumbers: true,
                    striped: true,
                    pagination: true,
                    singleSelect: true,
                    url: "WebService.asmx/GetGrid",
                    idField: 'id',
                   
                   
 columns: [[
                  { title: '用户ID', field: 'id',  sortable: true },
                  { field: 'name', title: '用户名称',  sortable: true }
                    ]],
                    pagination: true,
                    rownumbers: true


                });
               
            });  
        
        
        </script>


websercie代码

 

  #region
   using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Script.Services;
using System.Data.SqlClient;
using System.Data;
using System.Text;
using System.Configuration;
using System.Runtime.Serialization;
using System.Xml.Serialization;
using System.Web.Script.Serialization;
using System.ServiceModel.Web;
     [WebMethod]
   [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    public string GetGrid() 
    {
        /*
        List<Person> UserList = new List<Person>();
        UserList.Add(new Person("a",2));
        UserList.Add(new Person("ab", 1));
        UserList.Add(new Person("dd", 3));
        return UserList;
     */

        Person[] plist = new Person[2];
        plist[0] = new Person();
        plist[0].name = "zwm";
        plist[0].id = 1;
        plist[1] = new Person();
        plist[1].name = "zwb";
        plist[1].id = 2;

        return "{\"total\":2,\"rows\":" + new JavaScriptSerializer().Serialize(plist) + "}";


    }

现在说要注意的问题了,直接这样调websercie是显示不出来的,任你再怎么设置JSON 格式什么的,返回给客户端的一直是一段XML字符串,,,但是

下面这段代码却能返回成功,

   $(function () {
                  $.ajax({
                      url: 'WebService.asmx/GetGrid', // WebService的地址 + 要调用的方法名
                      data: "{}", // 要发送的参数,JSON格式的字符串 '{"name":"admin", "age":30}',这些参数会被 CreatePerson(string name, int age)接收,注意格式要严格
                      type: 'post', // 这个你懂得
                      dataType: 'json', // 期望服务器端返回的数据格式
                      contentType: 'application/json; charset=utf-8', // 发送给服务器端的格式
                      success: function (data) {
                          data = (data && data.d) ? data.d : data;
                          // 这样写是为了兼容IIS7(以后再细说),data={"name":"admin", "age":30},注意在这里data是对象而不是字符串,可以这样使用:alert(data.name);
                      },
                      complete: function (data) {
                          data = (data && data.d) ? data.d : data;
                      },
                      error: function (exception) {
                          alert(exception);
                      }
                  });



              });


这就郁闷了,,,,,搜索了很多,就是没找到满意的答案,我就想,这个上面的能成功,为什么,绑定GRID就不能成功,他应该也是掉AJAX方法啊,

就去看easyui.min.js的代码,跟踪,结果,发现他返回的字符串,不是JSON对象,那怎么办啊,只能改这个脚本啦,把获取出来的Data.d 再转换成JSON对象,就可以了,

把这个源代码改一点点,就可以出来了,搞了一下午,都记录在这里,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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进度条上传,通过前后端技术的组合应用,在网页上传过程中有效展示文件上传进度和结果,提升了用户的体验感和操作效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值