JqSuite PHP:获取列名还是id?

时间:2013-12-17 12:23:46

标签: javascript jqgrid jqgrid-php jqgrid-formatter

如何在custom-format函数中获取列信息(名称或ID)?

grid.php中的一些代码:

$grid->dataType = 'json';
$grid->setColModel();

我的自定义格式功能

function formatPdfLink(cellValue, options, rowObject) {

var cellHtml = "<a href='" + cellValue + "' title='" + [show column Name here] + "' ><img src='../img/PDF_icon.png ' /></a> ";

return cellHtml; }

Javascript代码摘录,在生成的页面中找到(查看源代码):

jQuery(document).ready(function($) {
jQuery('#grid').jqGrid({

        "jsonReader": {
        "repeatitems": false,
        "subgrid": {
            "repeatitems": false
        }
    },
    "xmlReader": {
        "repeatitems": false,
        "subgrid": {
            "repeatitems": false
        }
    },

        "colModel": [{ {
        "name": "pdf_1",
        "index": "pdf_1",
        "sorttype": "string",
        "label": "C",
        "sortable": false,
        "width": 25,
        "align": "center",
        "search": false,
        "formatter": formatPdfLink,
        "unformat": unformatPdfLink,
        "editoptions": {
            "size": 100
        },
        "editable": true
    }
    }]

我尝试使用rowObject.columnName,但它不起作用!

注意:我没有使用loadonce: true

PS:如果需要更多细节,请告诉我。

1 个答案:

答案 0 :(得分:2)

因为您使用repeatitems: false格式的数据,所以网格的输入数据应该是具有命名属性的项目,这些属性的名称与namecolModel属性的值相同。因此,用作formatPdfLink的{​​{1}}函数将以与原始数据相同的简单格式获得第三个参数formatter。例如,可以使用rowObject。要访问其他列,您只需使用rowObject.pdf_1中使用的name属性值作为列。

更新:如果您多次使用相同的自定义格式化程序,则可能需要访问当前列的属性。 colModel参数可以为您提供帮助。

options

参数function formatPdfLink(cellValue, options, rowObject) { return "<a href='" + cellValue + "' title='" + options.colModel.name + "' ><img src='../img/PDF_icon.png ' /></a> "; } 包含属性optionsrowIdcolModelgid。自定义格式化程序内的pos被初始化为网格的DOM,因此您可以使用例如this$(this).jqGrid("getGridParam", "parameterName")来访问jqGrid的其他选项。属性this.p.parameterName仅包含当前列的列定义,而不包含完整的colModel参数。

例如,您可以在工具提示中重写上面的代码,从colModel而不是colNames属性设置下一个代码:

name