9

我想为选择单元格进行动态填充的 html 选择。我从每个行项目都不同的数据库中提取一些信息。问题是编辑器丢失了初始数据,我不知道如何为特定单元格保留一些数据。以前有人做过吗?

function StandardSelectCellEditor($container, columnDef, value, dataContext) {
var $input;
var $select;
var defaultValue = value;
var scope = this;

this.init = function() {
    $input = $("<INPUT type=hidden />");
    $input.val(value); 
    }

    $input.appendTo($container);

    $select = $("<SELECT tabIndex='0' class='editor-yesno'>");
    jQuery.each(value, function() {
      $select.append("<OPTION value='" + this + "'>" + this + "</OPTION></SELECT>");
    });
    $select.append("</SELECT>");

    $select.appendTo($container);

    $select.focus();
};


this.destroy = function() {
    //$input.remove();
    $select.remove();
};


this.focus = function() {
    $select.focus();
};

this.setValue = function(value) {
    $select.val(value);
    defaultValue = value;
};

this.getValue = function() {
    return $select.val();
};

this.isValueChanged = function() {
    return ($select.val() != defaultValue);
};

this.validate = function() {
    return {
        valid: true,
        msg: null
    };
};

this.init();
};
4

5 回答 5

16

此处提出了类似的问题(但是,此问题没有标记为 slickgrid)。

我确实制作了一个 SelectEditor,根据我们所在的列提供灵活的选项范围。这里考虑的原因是您在列中编辑的值的数据类型将决定该字段的有效选择。

为此,您可以在列定义中添加一个额外的选项(例如,称为选项),如下所示:

 var columns = [
  {id:"color", name:"Color", field:"color",  options: "Red,Green,Blue,Black,White", editor: SelectCellEditor}
  {id:"lock", name:"Lock", field:"lock",  options: "Locked,Unlocked", editor: SelectCellEditor},

]

并在您自己的 SelectEditor 对象的 init 方法中使用args.column.options访问它,如下所示:

 SelectCellEditor : function(args) {
        var $select;
        var defaultValue;
        var scope = this;

        this.init = function() {

            if(args.column.options){
              opt_values = args.column.options.split(',');
            }else{
              opt_values ="yes,no".split(',');
            }
            option_str = ""
            for( i in opt_values ){
              v = opt_values[i];
              option_str += "<OPTION value='"+v+"'>"+v+"</OPTION>";
            }
            $select = $("<SELECT tabIndex='0' class='editor-select'>"+ option_str +"</SELECT>");
            $select.appendTo(args.container);
            $select.focus();
        };

        this.destroy = function() {
            $select.remove();
        };

        this.focus = function() {
            $select.focus();
        };

        this.loadValue = function(item) {
            defaultValue = item[args.column.field];
            $select.val(defaultValue);
        };

        this.serializeValue = function() {
            if(args.column.options){
              return $select.val();
            }else{
              return ($select.val() == "yes");
            }
        };

        this.applyValue = function(item,state) {
            item[args.column.field] = state;
        };

        this.isValueChanged = function() {
            return ($select.val() != defaultValue);
        };

        this.validate = function() {
            return {
                valid: true,
                msg: null
            };
        };

        this.init();
    }
于 2010-10-28T08:33:42.333 回答
1

您可以稍微修改上面的 SelectCellEditor 为每个单元格创建不同的选择选项。

function SelectCellEditor(args) {

   .....

   // just to get the DOM element
   this.getInputEl = function() {
      return $input;
   };
}

现在很容易创建一个动态下拉编辑器。

function DynamicSelectCellEditor(args) {
   // 1: if you already have a select list for individual cells
   args.columns.options = optionsList[args.item.id] // or any custom logic
   return new Slick.Editors.SelectCellEditor(args);

   /*              OR                */

   // 2: if data needs to be fetched from the server
   var editor = new Slick.Editors.SelectCellEditor(args),
       $select = editor.getInputEl();

   $select.html("<option>Loading...</option>");
   $.ajax({ }).done(function(list) {
       // Update select list
       $select.html(newHtml);
   });

   return editor;
}
于 2013-04-08T21:09:30.763 回答
0

代替

for( i in opt_values ){
          v = opt_values[i];
          option_str += "<OPTION value='"+v+"'>"+v+"</OPTION>";
}

$.each(opt_values , function( index, value ) {
    option_str += "<OPTION value='"+value+"'>"+value+"</OPTION>";
});

如果它不适合你

于 2014-01-17T21:41:23.003 回答
0

我还不能添加评论,但我需要在 HeiN 的回答中添加一些内容。

HeiN 的回答效果很好,但是我输入的数据与我的选择选项不匹配,我仍然需要显示该数据......所以我不得不在选项中修改 dataItemColumnValueExtractor。如果列表中没有要匹配的选项,这将允许显示我的原始数据。

        dataItemColumnValueExtractor: function(item, columnDef) {
            if(columnDef.editor == Slick.Editors.SelectOption){
                return eval(columnDef.options)[item[columnDef.field]] != null ? eval(columnDef.options)[item[columnDef.field]] : item[columnDef.field];
            }else{
                return item[columnDef.field];
            }
        }

希望这对以后的人有所帮助。

于 2015-03-05T20:17:33.577 回答
0

请尝试以下代码。

在 slick.editors.js 中,定义一个新的编辑器。

$.extend(true, window, {
    "Slick": {
      "Editors": {
       "SelectOption": SelectCellEditor,
       .....
      }
    }
  });
function SelectCellEditor(args) {
    var $select;
    var defaultValue;
    var scope = this;
    var s;
    this.init = function() {
        opt_values = eval(args.column.options);
        option_str = "";
        var tuples = [];
        for (var key in opt_values) tuples.push([key, opt_values[key]]);
        tuples.sort(function(a, b) { return a[1] < b[1] ? 1 : a[1] > b[1] ? -1 : 0 });
        var length = tuples.length;
        while (length--) option_str += "<OPTION value='"+tuples[length][0]+"'>"+tuples[length][1]+"</OPTION>";

        $select = $("<SELECT tabIndex='0' class='editor-select'>"+ option_str +"</SELECT>");
        $select.appendTo(args.container);
        $select.focus();
    };

    this.destroy = function() {
        $select.remove();
    };

    this.focus = function() {
        $select.focus();
    };

    this.loadValue = function(item) {
        defaultValue = item[args.column.field];
        $select.val(defaultValue);
    };

    this.serializeValue = function() {
          return $select.val();
    };

    this.applyValue = function(item,selectedIndex) {
        if($.isNumeric(selectedIndex))
            item[args.column.field] = parseInt(selectedIndex);
        else
            item[args.column.field] = selectedIndex;
    };

    this.isValueChanged = function() {
        return ($select.val() != defaultValue);
    };

    this.validate = function() {
        return {
            valid: true,
            msg: null
        };
    };

    this.init();
}

然后,修改您的网格选项

var grid_options = {
editable:             true,
enableAddRow:       false,
multiColumnSort:    true,
explicitInitialization: true,
 dataItemColumnValueExtractor: function(item, columnDef) {
 if(columnDef.editor == Slick.Editors.SelectOption){
    return eval(columnDef.options)[item[columnDef.field]];
  }else{
    return item[columnDef.field];
  }
}

};

并在列初始化时使用编辑器。

{id: "currency_id", name: "Currency *", field: "currency_id", editor: Slick.Editors.SelectOption, options: { 1: 'Dollar', 2: 'Yen', 3: 'Rupiah' }, sortable: true,width: 234}
于 2014-02-13T04:02:45.113 回答