实现jqgrid单元格编辑datepicker

And*_*rea 5 php jqgrid

我知道使用datepicker进行单元格编辑是可能的,因为这里这里的引用.但是,当我单击单元格时,没有出现日期选择器.下面是相关列的colModel条目.我有datepicker UI可用.

在其他示例中,dataInit不包含引号.它在我的代码中,因为整个colModel是在AJAX请求期间由PHP动态创建的.我将它构建为一个数组,然后json_encode将它传递回jqGrid.PHP的json_encode创建有效的JSON,因此所有键都被引用为字符串.我必须删除引号才能使jqGrid正常工作吗?如果是这样,怎么样?

日期列的colModel条目:

{
 "editable":true,
 "name":"date",
 "index":"date",
 "sorttype":"date",
 "editrules":{"date":true},
 "editoptions":{
   "dataInit":"function(elem){
       setTimeout(function(){
          $(elem).datepicker();
       },100);
    }"
 }
}
Run Code Online (Sandbox Code Playgroud)

这是ajax请求的结构:

$(document).ready(function(){
  $.ajax({
   type: "GET",
   datatype: "json",
   success: function(result){
    try{
     //alert(result);
     result = jQuery.parseJSON(result);
    }catch(err){
     alert("error in success json " + err);
     return;
    }
    var colN = result.colNames;
    var colM = result.colModelList;
    var colD = result.colDataList;
    grid.jqGrid({
     datatype: 'local',
     colNames:colN,  //column names
     colModel:colM,  //column options
     data:colD,      //table data
     editurl: 'clientArray',//changes are not sent to server
     cellEdit: true,
     cellsubmit: 'clientArray',
    });
   }
  });
});
Run Code Online (Sandbox Code Playgroud)

另外,我正在使用jqGrid 4.0.0

Kee*_*ers 0

我在使用 PHP 的 json_encode 传递函数时遇到了同样的问题,这是不可能的,但如果您使用 Zend Framework,您可以使用 Zend_Json_Expr('function ...') 来使用函数,然后使用 Zend_Json::encode($var )。

但这仍然不能解决问题,因为如果您稍后通过 AJAX 插入事件,该事件将不会被触发。

您可以查看Pike_Grid以了解它是如何完成的。