[英]Unable to get row to edit mode in jqgrid
我用了以下
ondblClickRow: function(){ var row_id = $("#grid").getGridParam('selrow'); jQuery('#grid').editRow(row_id, true); }
从:
双击我可以得到警报,但是EditRow函数根本不起作用。
-------更新-----------
这是我在客户端使用的以下代码:-
function setJqGridParameters(parsedResult) { var lastSel; $('#list').jqGrid('GridUnload'); $("#list").jqGrid({ colModel: JSON.parse(parsedResult.colModel), colNames: JSON.parse(parsedResult.col), datatype: "jsonstring", datastr: JSON.parse(parsedResult.rows), jsonReader: { repeatitems: false }, gridview: true, rowNum: 10, cmTemplate: { title: false }, //, sortable: false }, viewrecords: false, loadonce: true, loadui: 'block', height: 'auto', autowidth: true, loadtext: "Loading....", pgbuttons: false, pginput: false, pgtext: "", shrinkToFit: false, hoverrows: false, ondblClickRow: function (rowid) { if (rowid && rowid !== lastSel) { $('#list').restoreRow(lastSel); lastSel = rowid; } $(this).jqGrid("editGridRow", rowid, { keys: true, addCaption: "Add Record", editCaption: "Edit Record", bSubmit: "Submit", bCancel: "Cancel", bClose: "Close", saveData: "Data has been changed! Save changes?", bYes: "Yes", bNo: "No", bExit: "Cancel", width: window.screen.width / 3, top: window.screen.height / 4, left: window.screen.availWidth / 3, editUrl: 'TypicalVolume.aspx/UpdateVolumeData', beforeSubmit: function (postData, formid) { //alert(JSON.stringify(postData)); PostDataToServer(postData); $(".ui-widget-overlay").trigger('click'); $('#list').trigger('reloadGrid'); return false; }, afterShowForm: function (formid) { $("#COl1").focus(); //var cm = $(this).jqGrid('getColProp', 'Specialty'); //debugger; } }); // debugger; // var grid = $('#list'); // var myRowData = grid.getRowData(rowid); // grid.editRow(rowid, true); //alert(myRowData['Specialty'] + ' ' + myRowData['SpecialtyName']); }, loadComplete: function () { fixPositionsOfFrozenDivs.call(this); }, onSortCol: function (index, icol, sortorder) { sortColumns(index, icol, sortorder); return 'stop'; } }); resizeColumnHeader.call($("#list")[0]); $("#list").parents('div.ui-jqgrid-bdiv').css("max-height", $(window).height() - $('#pivotGridDiv').offset().top - 60); $("#list").jqGrid('setFrozenColumns'); $("#list").triggerHandler("jqGridAfterGridComplete"); fixPositionsOfFrozenDivs.call($("#list")[0]); $(".s-ico").hide(); var cm = $("#list")[0].p.colModel; $.each($("#list")[0].grid.headers, function (index, value) { var cmi = cm[index], colName = cmi.name; if (cmi.sortable) { $('div.ui-jqgrid-sortable', value.el).css({ cursor: "pointer" }); } }); } function PostDataToServer(Data) { $.ajax({ type: "POST", data: "{" + "Data" + ":" + JSON.stringify(Data) + "}", url: "TypicalVolume.aspx/UpdateVolumeData", //data: JSON.stringify(obj), contentType: "application/json; charset=utf-8", dataType: "json", success: function (result) { if (result.d == "null") { RedirectToLogin(); } else { SetValues(result); } }, error: function (result) { $('#loadingIndicator').hide(); alert("getPageLoadData: " + result.responseText); //RedirectToErrorPage(); } }); }
在页面加载时调用SetJqGridParameters()函数,该函数设置Jqgrid的所有参数。 我使用PostDataToServer()函数将数据发送到服务器并编写了Db更改。 注意:-如果删除功能,则jqgrid.min.js中会出现空引用错误。
----服务器代码----
[System.Web.Services.WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public static string UpdateVolumeData(object Data)
{
string WhereCondition1 = "",WhereCondition2="";
List<string> UpdateStatements = new List<string>();
Dictionary<string, string> data = new Dictionary<string, string>();
data = ToDictionary(Data);
foreach(KeyValuePair<string,string> entry in data)
{
if (entry.Key.ToString() == "MainCol1")
{
if (WhereCondition1 == "")
{
WhereCondition1 = WhereCondition1 + entry.Key.ToString() + "=" +"'"+ entry.Value.ToString()+"'";
}
else
{
WhereCondition1 = WhereCondition1 + "," + entry.Key.ToString() + "=" + "'"+entry.Value.ToString()+"'";
}
}
else if (entry.Key.ToString() == "MainCol2")
{
if (WhereCondition2 == "")
{
WhereCondition2 = WhereCondition2 + entry.Key.ToString() + "=" +"'"+ entry.Value.ToString()+"'";
}
else
{
WhereCondition2 = WhereCondition2 + "," + entry.Key.ToString() + "=" +"'"+ entry.Value.ToString()+"'";
}
}
}
foreach (KeyValuePair<string, string> entry in data)
{
if (entry.Key.ToString() != "MainCol1" && entry.Key.ToString() != "MainCol2")
{
UpdateStatements.Add("Update TypicalVolume set TypicalVolume = " + entry.Value + " where Modality = '" + entry.Key + "' and " + WhereCondition1 + " and " + WhereCondition2);
}
}
//JavaScriptSerializer serializer = new JavaScriptSerializer();
//var data = serializer.Serialize(Data);
string sqlstatements = string.Join(" ", UpdateStatements);
SqlConnection conn = new SqlConnection(sqlConnectionString);
conn.Open();
SqlCommand cmd = new SqlCommand(sqlstatements, conn);
cmd.ExecuteNonQuery();
conn.Close();
GridData gd = new GridData();
gd = GetGridData();
JavaScriptSerializer serializer = new JavaScriptSerializer();
return serializer.Serialize(gd);
}
[System.Web.Services.WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public static string GetDataBySearchCriteria()
{
try
{
HttpContext.Current.Session["RoleID"] = 4;
if (HttpContext.Current.Session["RoleID"] != null)
{
if (!CheckAuthorization()) // Redirect to error page if not authorized
{
throw new Exception("Un Authorized Acess");
}
else
{
HttpContext.Current.Session["TypicalVolumeSession"] = null;
if (HttpContext.Current.Session["TypicalVolumeSession"] != null)
{
GridData gd = new GridData();
gd = HttpContext.Current.Session["TypicalVolumeSession"] as GridData;
JavaScriptSerializer serializer = new JavaScriptSerializer();
GridData gd1 = GetGridData();
return serializer.Serialize(gd1);
}
else
{
HttpContext.Current.Session["TypicalVolumeSession"] = null;
GridData gridData = new GridData();
DataSet ds = SqlHelper.ExecuteDataset(sqlConnectionString, CommandType.StoredProcedure, "GetTypicalVolumes");
DataTable Datadt = ds.Tables[0];
//create col model for jqgrid
StringBuilder sbcol = new StringBuilder();
sbcol.Append("[");
foreach (DataColumn column in Datadt.Columns)
{
sbcol.Append("\"").Append(column.ColumnName).Append("\",");
}
sbcol.Remove(sbcol.Length - 1, 1).Append("]");
StringBuilder sbcolModel = new StringBuilder();
sbcolModel.Append("[");
string[] rowAreaFields = "MainCol1,MainCol2".Split(',');
//create rowdata for jqgrid
foreach (DataColumn column in Datadt.Columns)
{
if (rowAreaFields.Contains(column.ColumnName.Trim()))//apply style for row area fields
{
sbcolModel.Append("{\"name\":\"").Append(column.ColumnName.Trim()).Append("\",\"index\":\"").Append(column.ColumnName.Trim()).Append("\",\"classes\":\"colstyle\",\"align\":\"left\",\"editable\":true,\"editoptions\": { \"disabled\": \"disabled\" },\"sortable\":true,\"frozen\":true},");
}
else
{
sbcolModel.Append("{\"name\":\"").Append(column.ColumnName.Trim()).Append("\",\"index\":\"").Append(column.ColumnName.Trim()).Append("\",\"align\":\"right\",\"sortable\":false,\"editable\":true,\"width\":\"60px\"},");
}
}
sbcolModel.Remove(sbcolModel.Length - 1, 1);
sbcolModel.Append("]");
JavaScriptSerializer serializer = new JavaScriptSerializer();
List<Dictionary<string, object>> rows = new List<Dictionary<string, object>>();
Dictionary<string, object> drow;
foreach (DataRow dr in Datadt.Rows)
{
drow = new Dictionary<string, object>();
foreach (DataColumn col in Datadt.Columns)
{
drow.Add(col.ColumnName, dr[col]);
}
rows.Add(drow);
}
StringBuilder sbjsonRows = new StringBuilder();
sbjsonRows.Append(serializer.Serialize(rows));
StringBuilder json = new StringBuilder();
json.Append("{").Append("\"rows\":").Append(sbjsonRows.ToString().Trim()).Append("}");
json.ToString();
gridData.col = sbcol.ToString();
gridData.colModel = sbcolModel.ToString();
gridData.rows = sbjsonRows.ToString().Trim();
return serializer.Serialize(gridData);//serialize and return to ajax method
}
}
}
else
{
return "null";//if session expired
}
}
catch (Exception ex)
{
LogError(ex);
throw;
}
}
该代码处于测试模式,目前仍在开发中,该代码是我开发的其他页面的模板,因此它已使用会话,但到目前为止尚未真正需要。
要求:-我有很多数据。 所以我想更新数据库并显示数据库中的真实数据。 因为其他用户可能已更新它。 因此,如果可能的话,我可能希望以一种懒惰的方式加载数据,在这种方式下,我可以加载例如3页的数据,然后继续在后台加载(jqgrid中是否有这样的选项)。 如果无法加载整个数据,则可以。
我也想用C#编写示例,并以尽可能多的方式为其他新用户提供示例,以便用户可以在一处找到所有文档和帮助。 请提出我也可以这样做。
对于那些引用此内容的人:-这个问题最初是针对可编辑的行开始的。 我从@Oleg得到的第一个建议就足够了。 后来他发现我的代码不一致,因为我们使用了来自不同jqgrid的代码,并且服务器代码也不是标准的(请不要使用这些技术)。
初学者使用jqgrid
请确保使用相同的jqgrid,这将帮助您保持代码的一致性。 在互联网上,您可以找到jqgrid的不同版本,因此请首先确定要使用免费版本还是商业版本,然后再获取最新版本。
您的代码中有很多奇怪的东西(在服务器端和客户端)。 我不想重写您的代码。 在客户端,您只需将相同的postdata
发送到服务器。 您只需将数据包装在Data
参数中,然后转换为JSON。
我只是在您的代码中提到了一些明显的问题:
editUrl
放在错误的位置,并且使用了错误的选项名称。 editGridRow
的选项应为url
。 editUrl
的选项是editurl
参数的正确位置(!!!不是editUrl
!!!)(位于colModel
, colModel
和其他位置的同一位置)。 editRow
(请参见原始文本),则应使用serializeRowData
回调和ajaxRowOptions
选项。 如果要改用editGridRow
方法(请参见问题的UPDATED部分),则需要使用serializeEditData
而不是serializeRowData
。 editGridRow
情况下,在ondblClickRow
回调内部调用内联编辑方法restoreRow
没有意义。 $('#list').trigger('reloadGrid');
表单编辑的回调beforeSubmit
内部没有任何意义,因为jqGrid在编辑后会自动重新加载数据。 另一方面,重新加载本地数据 (您使用datatype: "jsonstring"
)也没有感觉。 fixPositionsOfFrozenDivs
方法,该方法仅在免费的jqGrid中存在。 您应该确定要使用哪个jqGrid分支,并使用相应的选项。 在免费使用jqGrid的情况下,您可以使用新样式的表单编辑和内联编辑选项(请参阅wiki文章 ),这可以使您的代码更短,更易读。 另一方面,这些选项仅适用于免费的jqGrid。 因此,重要的是要知道使用哪个jqGrid分支以及哪个版本 。 SqlCommand
参数 ,并且不要直接将SQL语句构造为字符串(请参见代码中WhereCondition2
构建)。 这是非常肮脏的。 JavaScriptSerializer serializer = new JavaScriptSerializer(); return serializer.Serialize(gd);
JavaScriptSerializer serializer = new JavaScriptSerializer(); return serializer.Serialize(gd);
。 这是不对的! ASP.NET根据HTTP请求的Content-Type
标头自动进行JSON / XML序列化。 返回的数据类型应该是object
而不是string(需要将public static string GetDataBySearchCriteria()
替换为public static object GetDataBySearchCriteria()
)。 您应该使用return gd;
而不是return serializer.Serialize(gd);
。 您当前的服务器方法两次序列化为JSON。 由GetDataBySearchCriteria
或UpdateVolumeData
返回的字符串将再次进行序列化。 因此,服务器返回的内容类似于{"d": "{..., \\"some string\\"...}"}
而不是{"d": {..., "some string"...}}
。 sbcolModel.Append("{\\"name\\":\\"")
和json.Append("{").Append("\\"rows\\":")
也很糟糕。正确的代码应该只能工作带对象的对象 ,不需要手动进行JSON转换,仅因为这个原因,您需要包括JSON.parse
或$.parseJSON
附加调用。典型的$.ajax
调用将JSON数据内部转换为对象,而您可以直接使用object进行操作 。不使用datatype: "json"
原因datatype: "json"
和jsonReader: {repeatitems: false}, ajaxGridOptions: { contentType: "application/json" }, serializeGridData: function (postData) { return JSON.stringify(postData); }
和以此类推。 我可以继续...
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.