Ich bin ein jQuery-Noob, also bin ich sicher, dass ich hier etwas Einfaches vermisse.JqGrid in ASP.NET MVC Client-Ansicht mit jQuery und LINQ-zu-Entitäten sortieren
Ich habe das jqGrid mit einer Aktion arbeiten, die JSON-Daten von einem LINQ-to-Entities-Vorgang erstellt. Aber wenn ich im Browser auf die Spaltenüberschriften klicke, werden die Zeilen nicht sortiert. Der aufsteigende/absteigende Indikator erscheint, aber nichts anderes passiert.
Die notwendige JavaScript und CSS-Links sind in dem Master-Seitenkopf:
<script src="/Scripts/jquery-1.3.2.min.js" type="text/javascript"></script> <!-- CSS and JavaScript files for jqGrid to display on Details pages --> <link rel="stylesheet" type="text/css" href="/scripts/jQuery/jqGrid-3.4.4/themes/green/grid.css" title="green" media="screen" /> <script src="/Scripts/jQuery/jqGrid-3.4.4/jquery.jqGrid.js" type="text/javascript"></script> <script src="/Scripts/jQuery/jqGrid-3.4.4/js/jqModal.js" type="text/javascript"></script> <script src="/Scripts/jQuery/jqGrid-3.4.4/js/jqDnR.js" type="text/javascript"></script>
Hier ist mein Code für die Initialisierung:
// jqGrid setup. $("#gridlist").jqGrid({ url: '/Contact/GridData', datatype: 'json', mtype: 'GET', colNames: ['ID', 'First Name', 'Last Name', 'Organization'], colModel: [ { name: 'id', index: 'id', width: 40, align: 'left', resizable: true }, { name: 'first_name', index: 'first_name', width: 200, align: 'left', resizable: true, sortable: true, sorttype: "text" }, { name: 'last_name', index: 'last_name', width: 200, align: 'left', resizable: true, sortable: true, sorttype: "text" }, { name: 'organization', index: 'organization', width: 300, align: 'left', resizable: true, sortable: true, sorttype: "text"}], pager: jQuery('#pager'), rowNum: 5, rowList: [5, 10, 20, 50], repeatitems: false, viewrecords: true, imgpath: '/scripts/jQuery/jqGrid-3.4.4/themes/green/images', caption: 'Contacts' });
Und hier ist der HTML:
<h3>My Grid Data</h3> <table id="gridlist" class="scroll" cellpadding="0" cellspacing="0"> </table> <div id="pager" class="scroll" style="text-align:center;"> </div>
Und, nur zur Vollständigkeit, die Aktionsmethode:
public ActionResult GridData() { var page = new { page = 1 }; IEnumerable contacts = _db.ContactSet; int i = 0; var rows = new object[contacts.Count()]; foreach (Contact contact in contacts) { rows[i] = new { id = contact.ID, cell = new[] { contact.ID.ToString(), contact.First_Name, contact.Last_Name, contact.Organization } }; i++; } var result = new JsonResult(); result.Data = new { page = 1, records = 2, rows, total = 1 }; return result; }
Irgendwelche Ideen, welche offensichtliche Einstellung ich hier vermisse?
Würden Sie in Betracht ziehen, alle Ihre Antworten aufzuräumen und nur die neuesten Informationen zur Verfügung zu stellen? Es ist das Ergebnis, das wichtig ist, nicht der Prozess. – Basic