我有以下列使用jqgrid(简化)
{ name: "PMOPerson",index: "PMOPerson",width: 250,editable: true,edittype: "select",editoptions: { dataUrl: "/Person/GetSelectData" },editrules: { required: false} },{ name: "HeaddisplayName",index: "HeaddisplayName",width: 150,editable: false },

当我通过调出编辑对话框来编辑一行时,需要10秒才能填充PMOPerson下拉列表.甚至在我之前已经加载过一次之后就是这种情况,我认为这是因为我在下面重新创建了一个形式:true

addButton({
    caption: "",title: "Edit Selected Team",buttonicon: 'ui-icon-pencil',onClickButton: function () {
        var id = $("#grid").getGridParam("selrow");
        if (id) {

            jQuery("#grid").jqgrid('editGridRow',id,{ url: '/OrganisationalUnit/Update',afterSubmit: function (response,postdata) {
                        var responseJson = $.parseJSON(response.responseText);
                        return HandleJqgridResponse(responseJson);
                    },height: 380,width: "auto",recreateForm: true,closeAfterEdit: true,cloSEOnescape: true,reloadAfterSubmit: true
                    });
        }
    },position: "second"
});

我试图找出是否有一种方法可以同时使用recreateform:true但仍然缓存dataUrl中的项目列表,以避免每次编辑行时都返回到服务器.

解决方法

我回答了非常接近的问题 here和 here.换句话说,您可以使用HTTP标头的缓存选项或使用editoptions.value而不是editoptions.dataUrl.

我在the answer和前两个(this和this)中描述了如何在beforeProcessing回调中动态设置editoptions.value.需要扩展来自用于填充网格的服务器的响应以及其他信息(使用从editoptions.dataUrl返回的数据等数据).在我看来,它实现了editoptions.dataUrl数据缓存和重新加载网格刷新数据之间的最佳折衷.仍然可以在服务器端保存缓存的editoptions.dataUrl数据.

或者,可以使用更简单的方法,在创建网格后对createoptions.dataUrl进行一次手动Ajax请求,并且可以在Ajax请求的成功(完成)回调中设置editoptions.value.代码将涉及以下内容

// create grid
$("#grid").jqgrid({
    colModel: [
        { name: "PMOPerson" },...
    ],...
});

// make separate asynchronous Ajax request to the server and set 
//  edittype: "select",editoptions: { value: ... }
setSelectOptionValues("/Person/GetSelectData",$("#grid"),"PMOPerson");

setSelectOptionValues的代码取决于您用来与URL进行通信的JSON数据的格式,如“/ Person / GetSelectData”.例如,如果服务器只返回字符串数组,则应该是< select>的文本和选项的值.然后可能是以下

var setSelectOptionValues = function (getJsonUrl,myGrid,colModelColumnName) {
    $.getJSON(
        getJsonUrl,function (data) {
            var i,selectedOptions = '',datai,dn,colModelColumn;

            for (i = 0; i < data.length; i += 1) {
                if (i > 0) {
                    selectedOptions += ';';
                }
                else {
                    selectedOptions = "";
                }
                datai = data[i];

                if (typeof datai === 'string') {
                    selectedOptions += datai;
                    selectedOptions += ':';
                    selectedOptions += datai;
                }
            }
            myGrid.jqgrid("setColProp",colModelColumnName,{
                edittype: "select",editoptions: { value: selectedOptions }
            });
        }
    );
};

editoptions.value的设置将在setSelectOptionValues内异步完成.因此,可以在editoptions.value设置之前填充网格.另一方面,editoptions.value仅在编辑期间使用.来自“/ Person / GetSelectData”的响应时间通常足够快,并且在用户开始编辑之前将设置值editoptions.value.如果你想绝对确定你仍然可以举行editoptions.dataUrl.在editoptions.dataUrl的情况下,只有当用户快速作为响应“/ Person / GetSelectData”的服务器时才会使用.您可以更改显式调用

setSelectOptionValues("/Person/GetSelectData","PMOPerson");

使用getGridParam获取colModel,循环遍历所有colModel项,并为具有editoptions.dataUrl的所有项调用setSelectOptionValues.

最后一种方法的主要限制:你不能使用formatter:“select”(只是edittype:“select”).如果使用ids填充网格数据并且editoptions.value或formatoptions.value提供了id到文本的映射,那么我建议你使用beforeProcessing回调的第一种方法.

jquery – 当使用jqgrid时,无论如何都有recreateForm:true但是还缓存dataUrl?的更多相关文章

  1. 详解使用双缓存解决Canvas clearRect引起的闪屏问题

    这篇文章主要介绍了详解使用双缓存解决Canvas clearRect引起的闪屏问题的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. 利用Node实现HTML5离线存储的方法

    这篇文章主要介绍了利用Node实现HTML5离线存储的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. HTML5 Web缓存和运用程序缓存(cookie,session)

    这篇文章主要介绍了HTML5 Web缓存和运用程序缓存(cookie,session),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. HTML5、Select下拉框右边加图标的实现代码(增进用户体验)

    这篇文章主要介绍了HTML5、Select下拉框右边加图标的实现代码,深度美化页面增进用户体验效果,需要的朋友可以参考下

  6. 详解前端HTML5几种存储方式的总结

    本篇文章主要介绍了前端HTML5几种存储方式的总结 ,主要包括本地存储localstorage,本地存储sessionstorage,离线缓存(application cache),Web SQL,IndexedDB。有兴趣的可以了解一下。

  7. 在iOS上,缓存绘制的屏幕图像并显示它的最快方法是什么?

    我没有让drawRect每次重绘数千个点,我认为有几种方法可以“在屏幕上缓存图像”和任何其他绘图,我们将添加到该图像,并在drawRect时显示该图像:>使用BitmapContext并绘制到位图,并在drawRect中绘制此位图.>使用CGLayer并在drawRect中绘制CGLayer,这可能比方法1快,因为此图像缓存在图形卡中(并且它不会计入iOS上“内存警告”的RAM使用情况?

  8. 在Sierra上,Brew安装错误单独使用Xcode是不够的

    我正在尝试使用HomeBrewv1.3.8在运行xCodev9.1的MacOSXSerrav10.12.6上安装软件包.安装和错误是然后我运行命令表示软件更新服务器无法使用命令行工具包.我进入xCode,它表明安装了命令行工具.任何帮助将非常感激.西奥解决方法我去了AppleDeveloper网站并直接下载了命令行工具dmg.首先需要设置Apple帐户.命令行工具可在以下位置找到–https://

  9. ios – NSURLCache和数据保护

    我正在尝试保护存储在NSURLCache中的敏感数据.我的应用程序文件和CoreDatasqlite文件设置为NSFileProtectionComplete.但是,我无法将NSURLCache文件数据保护级别更改为NSFileProtectionCompleteUntilFirstUserAuthentication以外的任何其他级别.这会在设备锁定时暴露缓存中的任何敏感数据.我需要缓存响应,以

  10. iOS 10 Safari问题在DOM中不再包含元素

    使用此链接,您可以重现该错误.https://jsfiddle.net/pw7e2j3q/如果您点击元素并从dom中删除它,然后单击链接测试.你应该看到旧的元素弹出选择.是否有一些黑客来解决这个问题?解决方法我能够重现这个问题.问题是,每当您尝试删除其更改事件上的选择框时,iOS10都无法正确解除对选择框的绑定.要解决此问题,您需要将代码更改事件代码放在具有一些超时

随机推荐

  1. jquery-plugins – 是否可以使用猫头鹰旋转木马实现循环/无限轮播?

    我正在使用猫头鹰旋转木马,它的工作完美,除了它不支持循环/无限滚动.我没有搜索google和stackoverflow的想法,没有运气.有没有人在猫头鹰旋转木马上实现圆形/无限滚动?

  2. jQuery动态输入字段焦点

    我想使用以下jQuery向我的页面动态添加一个输入字段:在这样做之后,我希望输入字段具有闪烁的文本光标的焦点,所以我想在创建后立即输入.有人可以告诉我我该怎么办?

  3. jquery – 为什么$(window).height()这样错了?

    我试图获取当前浏览器的视口高度,使用但我得到的价值观太低了.当视口高度高达850px时,我从height()获取大约350或400像素的值.这是怎么回事?

  4. jquery – 如果在此div之外和其他draggables内部(使用无效和有效的还原选项),则可拖动恢复

    例如这样但是由于明显的原因,这不行.我可以说这个吗?

  5. 创建一个jQueryUI 1.8按钮菜单

    现在jQueryUI1.8已经出来了,我正在浏览更新,并且遇到了新的Buttonwidget,特别是SplitButtonwithadropdown的演示之一.这个演示似乎表明Buttonwidget可以在这里创建一个下拉菜单.作为讨论的问题,我想知道使用这个新的Button小部件来创建一个下拉菜单有什么方法.干杯.解决方法您必须在按钮下方列出一个列表,方式类似于此处为自动完成提供的演示:http

  6. 灰色divs使用JQuery

    我试图使用这个代码:为了淡出一大堆名为MySelectorDiv的div,唯一的是,它只会淡出第一个而不是所有的div,为什么呢?

  7. 使用jQuery动态插入到列表中

    我有两个订单列表在彼此旁边.当我从一个列表中选出一个节点时,我想按照字母顺序插入到另一个列表中.抓住的是我想要把一个元素放在另一个列表中,而不刷新整个列表.奇怪的是,当我插入到右边的列表中,它工作正常,但是当我插入到左边的列表中时,顺序永远不会出来.我也尝试将所有内容读入数组,并将其排序在一起,以防止children()方法没有按照显示顺序返回任何东西,但是我仍然得到相同的结果.这是我的jQuer

  8. 没有回应MediaWiki API使用jQuery

    我试图从维基百科获取一些内容作为JSON:但我没有回应.如果我粘贴到浏览器的地址栏,就像我得到预期的内容.怎么了?解决方法您需要通过添加&callback=?来触发具有$.getJSON()的JSONP行为?在querystring上,像这样:Youcantestithere.没有使用JSONP,你正在击中same-originpolicy,阻止XmlHttpRequest获取任何数据.

  9. jQuery Ajax请求每30秒

    我有这段代码,但是有些人在我的网站上的值可能会改变.我需要每30秒钟更新一次#financediv.这可以做吗解决方法您可以将代码放在单独的函数中,如下所示:然后每30秒建立一个定时器调用该函数:祝你好运!总结以上是DEVMAX为你收集整理的jQueryAjax请求每30秒全部内容。如果觉得DEVMAX网站内容还不错,欢迎将DEVMAX网站推荐给好友。

  10. jquery – keypress事件在IE和Chrome中不工作,但在FF工作

    任何想法为什么会这样发生?我通常认为Chrome会更加宽容代码?这是我的按键键.我错过了什么吗?右图();和leftimage();是应该工作的功能,因为我在其他地方使用这些功能谢谢您的帮助!

返回
顶部