Реализация jqgrid с использованием JSOn и asp.net - PullRequest
1 голос
/ 19 сентября 2011

В прошлый раз я задавал похожий вопрос. Теперь я попытался соединить jqgrid для работы. Тем не менее, я пытался принести сетку, но данные не загружаются.

вот два файла GetData.aspx

<%@ Page Language="C#" %>
<%@ Import Namespace="System.Web.Script.Serialization"%>
<%@ Import Namespace="System.Collections.ObjectModel"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<script runat="server">
    protected void Page_Load(object sender, EventArgs e)
    {

        Response.Write(GetData());
        Response.End();
        //Response.Write ("Data is being loaded");
    }

    protected string GetData()
    {
                 var list = new Collection<People>
                              {
                                  new People {Id = 1, Name = "John", Gender = 1, IsClosed = false},
                                  new People {Id = 2, Name = "Abel", Gender = 1, IsClosed = false},
                                  new People {Id = 3, Name = "Aaron", Gender = 1, IsClosed = true},
                                  new People {Id = 4, Name = "Tsion", Gender = 2, IsClosed = true},
                                  new People {Id = 5, Name = "Mussie", Gender = 2, IsClosed = true}
                              };

                   return GridData(1, 1, list.Count, list);
    }

    public string GridData(int noOfPages, int startPage, int noOfRecords, Collection<People> list)
    {
        var gridData = new
                           {
                               total = noOfPages,
                               page = startPage,
                               records = noOfRecords,
                               rows = list,
                           };

        var jsonSerializer = new JavaScriptSerializer();
        return jsonSerializer.Serialize(gridData);

    }



    public class People
    {
        public People()
        {
            Name = string.Empty;
            Id = 0;
            Gender = 0;
            IsClosed = false;
        }



        public string Name { get; set; }
        public int Id { get; set; }
        public int Gender { get; set; }
        public bool IsClosed { get; set; }
    }

    public enum Oper
    {
        edit=1,
        del=2,
        add=3
    }



</script>
</html>

JQExample.aspx

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head id="Head1" runat="server">
    <title>JqGrid</title>
    <link href="themes/redmond/jquery-ui-1.8.2.custom.css" rel="stylesheet" type="text/css" />
    <link href="themes/ui.jqgrid.css" rel="stylesheet" type="text/css" />    
    <script src="Scripts/jquery-1.4.2.min.js" type="text/javascript"></script>
    <script src="Scripts/jquery.jqGrid.js" type="text/javascript"></script>

</head>
<body>
   <%-- <form id="form1">--%>
    <table id="jsonmap">
    </table>
    <div id="pjmap">
    </div>


    <script type="text/javascript">

        jQuery("#jsonmap").jqGrid({
            url: 'GetData.aspx',
            datatype: 'json',
            colNames: ['ID', 'Name','Active','Gender'],
            colModel: [{
                    name: 'id',
                    index: 'id',
                    width: 35,
                    editable: false,
                    editoptions: {
                    readonly: true,
                    size: 10
                }},                
                {
                    name: 'name',
                    index: 'name',
                    width: 150,
                    align: "left",
                    editable: true,
                    size: 100
                  },
                {
                    name: 'isClosed',
                    index: 'isClosed',
                    width: 100,
                    align: 'left',
                    editable: true,
                    edittype: "checkbox",
                    editoptions: {
                    value: "true:false",
                    formatter: "checkbox"
                }},
                {
                    name: 'gender',
                    index: 'gender',
                    width: 100,
                    formatter:'select',
                    editable: true,
                    edittype: "select", 
                    editoptions: {value: "0:select;1:male;2:female"}
                }],
                rowNum: 10,
                rowList: [2, 5, 10, 15],
                pager: '#pjmap',
                sortname: 'id',
                sortorder: "desc",
                viewrecords: true, 
                jsonReader: {
                    repeatitems: false
                },
                width: 600,
                caption: 'First jqGrid',
                height: '100%',
                editurl: 'GetData.aspx'
            });


            jQuery("#jsonmap").navGrid("#pjmap", {
                    edit: true,
                    add: true,
                    del: true
                },
                {
                    closeAfterEdit: true,
                    reloadAfterSubmit: false
                },
                {
                    closeAfterAdd: true,
                    reloadAfterSubmit: false
                },
                {
                    reloadAfterSubmit: false
                });



    </script>
      <table id="Jqgrid" width="100%">
    </table>
    <div id="pager"></div> 
    </form>
</body>
</html>

Теперь я хотел бы изменить данные для динамического отображения с помощью ADO.net.

Спасибо, сэр. Это сработало сейчас.

Я хочу изменить, чтобы получить данные динамически, то есть изменить источник данных в GetData.aspx и отформатировать colNames и ColModel в файле JQExample.aspx:

 $(document).ready(function () {
           $.ajax({
                            type: 'POST',
                            contentType: "application/json; charset=utf-8",
                           //url: "GetData.aspx", 
                            datatype: 'json',
                            success: function (result) {

//                                colD = result.colData;
//                                colN = result.colNames;
                                var colM = result.colModel;
                                 //alert(result.colModel);
                                jQuery("#jsonmap").jqGrid
                                      (
                                        {
                                      jsonReader: { repeatitems: false, cell: "",id: "0" },
                                            //url: "GetData.aspx", 
                                            datatype: 'json',
                                            mtype: 'POST',
                                            colModel: colM,

                                            data: colD.rootVar,
                                            ColNames: colN,
                                            ColModel: ColM,
                                            height: "auto",
                                            gridview: true,
                                            pager: '#pager',
                                            rowNum: 5,
                                            rowList: [5, 10, 20, 50],
                                            viewrecords: true,
                                            loadComplete: function (data) {
                                                alert('loaded completely'); 
                                             },
                                            loadError: function () {
                                                alert('error'); 
                                             }
                                        });
                            },
                            error: function (x, e) {
                                alert(x.readyState + ' ' + x.status + e.msg);
                            }
                        });

Следующий код должен быть заменен соединением ADO.Net в GetData.aspx

var list = new Collection<People>
                              {
                     new People {Id = 1, Name = "John", Gender = 1, IsClosed = false},
                     new People {Id = 2, Name = "Abel", Gender = 1, IsClosed = false},
                     new People {Id = 3, Name = "Aaron", Gender = 1, IsClosed = true},
                     new People {Id = 4, Name = "Tsion", Gender = 2, IsClosed = true},
                     new People {Id = 5, Name = "Mussie", Gender = 2, IsClosed = true}
                              }; 

Не могли бы вы сказать мне, что делать на следующем шаге? У меня есть источник данных конца сервера (сервер SQL). поэтому я должен написать оператор выбора, чтобы получить общее количество записей, страниц и порядок (сортировка) страховок для отображения в сетке? Если да, то не могли бы вы дать пример кода, который имеет top, limit и order?

Чего не хватает в приведенных выше кодах для динамического получения данных?

1 Ответ

0 голосов
/ 20 сентября 2011

В вашей реализации есть несколько ошибок, особенно если вы хотите, чтобы она была редактируемой, а просто для загрузки данных вам нужно исправить сопоставления столбцов.Они не совпадают.Кроме того, я считаю, что он чувствителен к регистру, поэтому вам нужно изменить colNames ниже и обновить colModel для соответствия этим именам / регистру:

colNames: ['Id', 'Name','IsClosed','Gender']
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...