单元格编辑后的SlickGrid样式

时间:2013-01-07 14:20:05

标签: editor styling slickgrid

我正在使用SlickGrid(2.0)dataView和slick.editors。在网格中,用户可以编辑任意数量的单元格,然后修改底层网格数据,以便在网格滚动时保持编辑。这非常有效。但我也希望为所有编辑提供视觉反馈,因为在用户点击“保存编辑”按钮之前,这些编辑不会保存到数据库中。

问题是编辑器方法在读回更改的网格数据后重置单元格。我需要保持背景颜色更改以指示它已被编辑。有没有人能够做到这一点?

这是相关代码(简单的整数编辑器):

function IntegerCellEditor(args) {
    var $input;
    var defaultValue;
    var scope = this;
    this.init = function() {
        $input = $("<input type=text class='edited' type=text style='font:normal 12px arial; width:95px; text-align:right; border:none;' />");
        $input.bind("keydown.nav", function(e) {
            if (e.keyCode === $.ui.keyCode.LEFT || e.keyCode === $.ui.keyCode.RIGHT) {
                e.stopImmediatePropagation();
            }
        });
    $('#saveChanges').removeAttr("disabled");   // remove disabled attribute from "Save Changes" btn
        $input.appendTo(args.container);
        $input.focus().select();
    };
    this.destroy = function() {
        $input.remove();
    };
    this.focus = function() {
        $input.focus();
    };
    this.loadValue = function(item) {
        defaultValue = item[args.column.field];
        $input.val(defaultValue);
        $input[0].defaultValue = defaultValue;
        $input.select();
    };
    this.serializeValue = function() {
        return parseInt($input.val(),10) || 0;
    };
    this.applyValue = function(item,state) {
        item[args.column.field] = state;
    };
    this.isValueChanged = function() {
        return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue);
document.getElementsByClassName('ui-widget-content slick-row')[row].className += 'edited';
        };
        this.validate = function() {
            if (isNaN($input.val()))
                return {
                   valid: false,
                   msg: "Please enter a valid integer"
               };
            return {
                valid: true,
                msg: null
           };
        };
        this.init();
    }

此行没有任何作用,我无法弄清楚如何执行此操作:

document.getElementsByClassName('ui-widget-content slick-row')[row].className += 'edited';

由于

1 个答案:

答案 0 :(得分:2)

我不是SlickGrid的专家,但看看Example 14,我认为它有类似的信息可以帮助你。

我的想法是这样的:

  • 订阅grid.onCellChange事件
  • 存储对象中的更改
  • 使用grid.setCellCssStyles('highlight',更改)来更新CSS或grid.addCellCssStyles

希望至少有所帮助。