- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 MVC 和 Web Api 构建应用程序。在一个 View 上,我正在使用 JqGrid。以前我们曾经将本地数据分配给工作正常的 JqGrid。现在由于逻辑上的一些变化,我们使用 WebApi 从服务器获取数据,这是一个 Json 数据,我们将它存储在变量中,然后我们将这个数据对象分配给 JqGrid,但数据没有显示。当我给出 web api 的“url”而不是数据选项时,一切正常,但是一旦我们使用“data”选项,jqgrid 就不起作用。可能的原因是什么?这样做的原因是我想在本地添加、编辑、更新数据,然后在按下最终保存按钮时,数据返回到服务器。
$().ready(function () {
//{"total":1,"page":1,"records":3,"rows":[{"id":"1","cell":["1","Tomato
//Soup","db@db.com","db@db.com","Groceries"]},{"id":"2","cell":["2","Yo-
//yo","db@db.com","db@db.com","Toys"]},{"id":"3","cell":
//["3","Hammer","db@db.com","db@db.com","Hardware"]}]}
//
$.getJSON("api/userwebapi/",
function (data) {
//userDataFromApi = jQuery.parseJSON(data);
userDataFromApi =data;
//alert(userDataFromApi[0].ID);
ConfigureUserGrid(userDataFromApi);
});
});
function ConfigureUserGrid(userDataFromApi) {
var grdUsers = $("#grdUsers");
var lastsel = 0;
$("#grdUsers").jqGrid({
datatype: "json"
, data: userDataFromApi
//, url: "api/userwebapi"
,colNames: ['ID', 'Name', 'User Role', 'Email', 'Address']
,colModel: [
{ name: 'ID', index: 'ID', width: 80, hidden: true }
, { name: 'Name', index: 'Name', width: 150 }
, { name: 'UserRole', index: 'UserRole', width: 150 }
, { name: 'Email', index: 'Email', width: 200, sortable: true }
, { name: 'Address', index: 'Address', width: 200, sortable: true }]
, viewrecords: true
, pager: '#pager1'
, mtype: 'GET'
,rowNum:true
,caption: 'My first grid'
}); //close of jQuery("#grdUsers").jqGrid({
$("#grdUsers").jqGrid('navGrid', '#pager1',
{ add: false, del: false, edit: false, search: false, refresh: false });
}
最佳答案
问题的原因是 jqGrid 参数(选项)的错误使用。确切地说,您使用了jqGrid 选项的错误组合。 Tony Tomov(jqGrid 的开发者)在每个新版本中都在 jqGrid 中添加了许多功能。如果可能的话,他想保持向后兼容性。结果,有很多选项没有明确的名称转换。许多选项只有在设置了一些其他选项时才有效。与 jQuery 或 jQuery UI 完全一样,不验证输入参数。开始使用 jqGrid 的人会遇到很多问题。
您的问题是 data
的使用参数连同 datatype: "json"
.这是错误的参数组合。问题是 jqGrid 支持两种远程数据类型和一些本地数据类型。
如果您使用 datatype: "json"
或 datatype: "xml"
然后 jqGrid 为您获取 AJAX 请求,用于初始填充网格以及每次排序、分页和(可选)过滤。以任何方式请求 url
将被寄出。一个使用由 mtype
指定的 HTTP 命令范围。数据的分页和排序必须在服务器端实现。请求中包含请求的页码、页的长度、用于排序的列的索引和排序的方向。从服务器返回的数据应采用描述的格式 here .如果您有非标准数据格式,您可以使用 jsonReader
jqGrid 和 jsonmap
的选项( xmlmap
) 在 colModel
指定应如何使用服务器响应来填充网格。
如果您不想实现服务器端的数据分页、排序和过滤,您可以使用loadonce: true
。选项。在这种情况下,服务器应立即返回所有数据。数据应根据初始排序列(基于您使用的 sortname
和 sortorder
)进行一次排序。 jqGrid 会变datatype
自动转"local"
在第一次加载数据之后。
所有其他数据类型将被解释为本地 数据类型。 data
参数将仅在 datatype: "local"
的情况下使用.在这种情况下,应该使用另一种格式的数据。可以使用 localReader
(参见 here )更改从 data
读取数据的方式参数。
有特例datatype: "jsonstring"
您可以在其中以 datatype: "json"
关闭的方式填充网格,而是使用对象或 JSON 字符串作为输入。在这种情况下应该使用 datastr
(不是 data
!!!)作为数据的输入。先填完datatype
将由 jqGrid 从 datatype: "jsonstring"
更改至 datatype: "local"
.
所以你有一些解决问题的方法:
url
和 loadonce: true
如果您不想实现数据分页,请选择选项。datatype: "jsonstring"
和 datastr
而不是 data
.datatype: "local"
和 data
填充为命名项目的数组(项目的属性应与列的 name
属性的值相同)。关于asp.net-mvc - 使用 WebApi 在 JqGrid 中分配 JSon 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12562872/
我想为我的 ABP 项目中的特定应用程序服务关闭自动 WebAPI 生成服务。 最佳答案 RemoteService 属性可用于将类标记为远程服务或禁用固有地实现 IRemoteService 接口(
我无法从 postman 访问 webapi 错误是下一个: 如您所见,没有授权。 valuescontroller.cs 是: namespace CVService.Controllers {
我无法从 postman 访问 webapi 错误是下一个: 如您所见,没有授权。 valuescontroller.cs 是: namespace CVService.Controllers {
我有以下 Controller ,它应该接受用户名和密码作为 POST 中的有效负载。如果我将其更改为 HttpGet 就可以了。 [RoutePrefix("api")] public class
使用以下路线: routes.MapHttpRoute( name: "Set", routeTemplate: "api/set/{id}",
我正在使用 AngularJS,我正在尝试将 json 从我的服务发送到 webAPI Controller 。当我通过发送时,我在 webApi 函数的参数中收到 null。 我的功能服务是: an
据我了解,如果我有一个 ASP.NET WebApi 方法,其签名如下所示...... public HttpResponseMessage PostCustomer(Customer custome
我遇到了一个解决方案问题,我使用 Visual Studio SPA 模板中的部分在具有 Oauth 身份验证的 WebApi 中拥有帐户 Controller 。 app.UseOAuthBea
我按照此处的说明将 webApi.HelpPage 区域和 View 添加到使用 structureMap 的现有项目中 - 但是在访问/Help url 时: StructureMap Except
我有一个 WebAPI。如何返回并打开网页。例如,我想打开 CNN.com 页面。 [HttpGet] public HttpResponseMessage Get()
我想知道是否有人可以澄清这一点。我发现用法令人困惑。 链接和视频都没有回答我的问题 我知道像这样的链接 asp.net core middleware vs filters 甚至还有关于它的视频 但是
运行以下最新版本(在撰写本文时): Visual Studio 2019 16.4.5 .NET 核心 SDK 3.1.102 x64 测试的浏览器: 谷歌浏览器 80.0.3987.122 火狐 7
想法是,将有一个外部实体 (SharePoint) 调用我的 WebAPI 并传入 PDF 文件以及有关该 PDF 文件的一些额外元数据信息。我被困在如何构造 Web API 方法的签名上。这是我到目
我有一个 WebApi 服务处理来自简单表单的上传,如下所示: 但是,我不知道如何使用 HttpClient API 模拟同一
嗨,我是 Angular 的新手,现在我从一个示例登录页面开始,该页面传递包含用户名和密码的 userEntity。userEntity 是一个对象/实体是 webapi。 问题:当我为登录按钮单击
我有一个 AngularJS + MVC + WebAPI,我正在尝试:- 使用标准(个人账户)进行MVC认证;- 使用相同的用户和密码进行基于 WebAPI 的身份验证。 问题,AngularJS
Web API 的版本存在一些混淆。看看这个 Web API at NuGet , Microsoft ASP.NET Web API 2.2 5.2.3 什么?这里是没有提到 2.2 的描述 我的猜
我正在开发一个 Web 应用程序,该应用程序将 Owin 托管用于 MVC 和 WebApi 2。 我最近将 Microsoft Mvc/WebApi 包从 5.2.2 版升级到 5.2.3 版,将
随着Web技术的发展,现在各种框架,前端的,后端的,数不胜数。全栈工程师的压力越来越大。 现在的前端的框架,既可以做各种Web,又可以做各种APP,前端框架更新换代越来越快,越来越多。 传统的模
1. WebAPI 背景知识 1.1 什么是 WebAPI JS 分成三个大的部分: ECMAScript: 基础语法部分 DOM API: 操作页面结构 BOM API: 操作浏览器 WebAPI
我是一名优秀的程序员,十分优秀!