JQGRID не должен обновляться после публикации обратно - PullRequest
0 голосов
/ 29 февраля 2012

Я создаю JQGRID в Code Behind и пытаюсь вызвать WebMethod с именем «GetUsersFromSP», и он отлично работает для меня.Я получаю текст "loading ..." и получаю данные.и когда я нажимаю кнопку «Load Grid», она возвращает сообщение и перезагружает данные снова из веб-службы. Можно ли сохранить прежние данные после публикации, и они не должны попадать в службу we. Ниже приведен код, который япытался.Пожалуйста, помогите мне в этом.

protected void Page_Load(object sender, EventArgs e)
    {
            string myString = "";
            myString = "window.onload = function() { ";
            myString += "jQuery(document).ready(function() {";

            myString += "        $('#list').jqGrid({";

            myString += "       url: 'WebService1.asmx/GetUsersFromSP',";
            myString += "       data: {},";
            myString += "       datatype: 'json',";
            myString += "       mtype: 'POST',";
            myString += "       ajaxGridOptions: { contentType: 'application/json; charset=utf-8' },";
            myString += "       serializeGridData: function(postData) {";
            myString += "       if (postData.filters === undefined) postData.filters = null;";
            myString += "       if (postData.searchField === undefined) postData.searchField = null;";
            myString += "       if (postData.searchOper === undefined) postData.searchOper = null;";
            myString += "       if (postData.searchString === undefined) postData.searchString = null;";
            myString += "       return JSON.stringify(postData);";
            myString += "       },";
            myString += "       jsonReader: {";
            myString += "       root: function(obj) { return obj.d.rows; },";
            myString += "       page: function(obj) { return obj.d.page; },";
            myString += "       total: function(obj) { return obj.d.total; },";
            myString += "       records: function(obj) { return obj.d.records; }";
            myString += "       },";

            myString += "            colNames: ['UserID', 'UserName'],";
            myString += "            colModel: [";
            myString += "  { name: 'UserID', index: 'UserID', width: 80, align: 'left', editable: true },";
            myString += "  { name: 'UserName', index: 'UserName', width: 80, align: 'left', editable: true }],";
            myString += "            pager: jQuery('#pager'),";
            myString += "            rowList: [10, 20, 300],";
            myString += "            rowNum: 10,";
            myString += "            sortname: 'UserID',";
            myString += "            sortorder: 'asc',";
            myString += "            width: 400,";
            myString += "            viewrecords: true,";
            myString += "editurl:  'WebService1.asmx/ModifyData',";
            myString += "caption:  'My first grid'";
            myString += "        }).navGrid('#pager', { edit: true, add: true, del: true, search: true }";

            //myString += "        { editData: { TableName: Inp1, ColumnValue: myArray} },";
            //myString += "        { editData: { TableName: Inp1, ColumnValue: myArray} });";
            myString += "        );";

            myString += "        jQuery.extend(jQuery.jgrid.edit, {";
            myString += "            ajaxEditOptions: { contentType: 'application/json' },";
            myString += "            recreateForm: true,";
            myString += "            serializeEditData: function(postData) {";
            myString += "                if (postData.Col1 === undefined) { postData.Col1 = null; }";
            myString += "                myArray[0] = postData.Col1;";
            myString += "                myArray[1] = postData.Col2;";
            myString += "                myArray[2] = postData.Col3;";
            myString += "                return JSON.stringify(postData);";
            myString += "            }";
            myString += "        });";

            myString += "        jQuery.extend(jQuery.jgrid.del, {";
            myString += "            ajaxDelOptions: { contentType: 'application/json' },";
            myString += "            serializeDelData: function(postData) {";
            myString += "                if (postData.Col1 === undefined) { postData.Col1 = null; }";
            myString += "                return JSON.stringify(postData);";
            myString += "            }";
            myString += "        });";

            myString += "    });";

            myString += "}";

            ScriptManager.RegisterClientScriptBlock(Page, Page.GetType(), Guid.NewGuid().ToString(), myString, true);

    }

CS FILE

[WebMethod] public JQGridResults GetUsersFromSP (строка searchField, строка searchOper, строка searchString, строковые фильтры, строка _search, строка nd, строки строки, строковая страница, строковый sidx, строковый sord) {int totalRecords = 0;string strSearchCondition = null;Пользователи коллекции = новая коллекция ();Hashtable getoperator = new Hashtable ();

        Hashtable inParams = new Hashtable();
        inParams.Add("@CONDITION", strSearchCondition);
        inParams.Add("@SORTCONDITION", " order by " + sidx + " " + sord);
        inParams.Add("@PAGE", page);
        inParams.Add("@ROWS", rows);
        inParams.Add("@RECORDCOUNT", totalRecords);

        Hashtable outParams = new Hashtable();
        outParams.Add("@RECORDCOUNT", totalRecords);
        DataSet ds = new DataSet();
        int rVal;
        ds = GetDataSet(vzaiConn, "SPNAME", out rVal, inParams, out outParams);
        totalRecords = (int)outParams["@RECORDCOUNT"];
        JQGridResults result = new JQGridResults();
        List<JQGridRow> rows1 = new List<JQGridRow>();
        if (ds.Tables.Count > 0)
        {
            foreach (DataRow user in ds.Tables[0].Rows)
            {
                JQGridRow row = new JQGridRow();
                row.id = (int)user["UserID"];
                row.cell = new string[6];
                row.cell[0] = user["UserID"].ToString();
                row.cell[1] = user["UserName"].ToString();
                row.cell[2] = user["FirstName"].ToString();
                row.cell[3] = user["MiddleName"].ToString();
                row.cell[4] = user["LastName"].ToString();
                row.cell[5] = user["EmailID"].ToString();
                rows1.Add(row);
            }
            result.rows = rows1.ToArray();
            result.page = Convert.ToInt32(page);
            result.total = (int)Math.Ceiling((decimal)totalRecords / (decimal)Convert.ToDecimal(rows));
            result.records = Convert.ToInt32(totalRecords);
        }
        return result;
    }

1 Ответ

0 голосов
/ 01 марта 2012

Привет, друг, попробуй это: -

protected void Page_Load(object sender, EventArgs e)
  {
    if (!IsPostBack) {
        string myString = "";
        myString = "window.onload = function() { ";
        myString += "jQuery(document).ready(function() {";

        myString += "        $('#list').jqGrid({";

        myString += "       url: 'WebService1.asmx/GetUsersFromSP',";
        myString += "       data: {},";
        myString += "       datatype: 'json',";
        myString += "       mtype: 'POST',";
        myString += "       ajaxGridOptions: { contentType: 'application/json; charset=utf-8' },";
        myString += "       serializeGridData: function(postData) {";
        myString += "       if (postData.filters === undefined) postData.filters = null;";
        myString += "       if (postData.searchField === undefined) postData.searchField = null;";
        myString += "       if (postData.searchOper === undefined) postData.searchOper = null;";
        myString += "       if (postData.searchString === undefined) postData.searchString = null;";
        myString += "       return JSON.stringify(postData);";
        myString += "       },";
        myString += "       jsonReader: {";
        myString += "       root: function(obj) { return obj.d.rows; },";
        myString += "       page: function(obj) { return obj.d.page; },";
        myString += "       total: function(obj) { return obj.d.total; },";
        myString += "       records: function(obj) { return obj.d.records; }";
        myString += "       },";

        myString += "            colNames: ['UserID', 'UserName'],";
        myString += "            colModel: [";
        myString += "  { name: 'UserID', index: 'UserID', width: 80, align: 'left', editable: true },";
        myString += "  { name: 'UserName', index: 'UserName', width: 80, align: 'left', editable: true }],";
        myString += "            pager: jQuery('#pager'),";
        myString += "            rowList: [10, 20, 300],";
        myString += "            rowNum: 10,";
        myString += "            sortname: 'UserID',";
        myString += "            sortorder: 'asc',";
        myString += "            width: 400,";
        myString += "            viewrecords: true,";
        myString += "editurl:  'WebService1.asmx/ModifyData',";
        myString += "caption:  'My first grid'";
        myString += "        }).navGrid('#pager', { edit: true, add: true, del: true, search: true }";

        //myString += "        { editData: { TableName: Inp1, ColumnValue: myArray} },";
        //myString += "        { editData: { TableName: Inp1, ColumnValue: myArray} });";
        myString += "        );";

        myString += "        jQuery.extend(jQuery.jgrid.edit, {";
        myString += "            ajaxEditOptions: { contentType: 'application/json' },";
        myString += "            recreateForm: true,";
        myString += "            serializeEditData: function(postData) {";
        myString += "                if (postData.Col1 === undefined) { postData.Col1 = null; }";
        myString += "                myArray[0] = postData.Col1;";
        myString += "                myArray[1] = postData.Col2;";
        myString += "                myArray[2] = postData.Col3;";
        myString += "                return JSON.stringify(postData);";
        myString += "            }";
        myString += "        });";

        myString += "        jQuery.extend(jQuery.jgrid.del, {";
        myString += "            ajaxDelOptions: { contentType: 'application/json' },";
        myString += "            serializeDelData: function(postData) {";
        myString += "                if (postData.Col1 === undefined) { postData.Col1 = null; }";
        myString += "                return JSON.stringify(postData);";
        myString += "            }";
        myString += "        });";

        myString += "    });";

        myString += "}";

        ScriptManager.RegisterClientScriptBlock(Page, Page.GetType(), Guid.NewGuid().ToString(), myString, true);
 }
}

Это не поможет, пожалуйста, пришлите Очистить описание

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...