Slickgrid - 单个单元格的更改编辑器,而不是整个列

时间:2015-01-07 11:06:25

标签: javascript jquery slickgrid

以下是该方案:

  • 有多行可选数据
  • 一列(#1)有下拉编辑器,有两个选项
  • 下一列(#2)可以有文本编辑器或下拉菜单编辑器 - 具体取决于在第一个下拉列表中选择的选项,请参阅示例:

    _________Column #1_________|_________Column #2_________

    1     select opt 1      |      *dropdown editor*    

    2     select opt 1      |      *dropdown editor*    

    3     select opt 1      |      *dropdown editor*    

    4     select opt 2      |      *text editor*        < ---这可能吗?

    5     select opt 1      |      *dropdown editor*    

    6     select opt 1      |      *dropdown editor*    

是否可以根据另一个单元格的输入/更改来更改单个单元格的编辑器?您似乎无法在单元格级别更改编辑器,但只能在列级别更改。

非常感谢任何帮助,已经花费了很多时间;并且没有找到解决方案甚至类似的问题。感谢

更新

这或许正在接近:

var currentRowIndex = object.grid.getActiveCell().row,
    nextCellIndex = object.grid.getActiveCell().cell + 1;
object.grid.setActiveCell(currentRowIndex, nextCellIndex);
object.grid.editActiveCell(this.editors.textEditor);

但这并不能确保编辑保持不变;例如^文本编辑器。更改第一列(#1)中的值,并在上面的第2列中启用文本编辑器时 - 在进行此编辑后 - 原始编辑器仍在第2列中。

我希望编辑器保持不变 - 但无法在单元级别而不是列级别上找到如何执行此操作。感谢

1 个答案:

答案 0 :(得分:1)

浏览与编辑器检索相关的the sourcegetEditor 第1381行)会显示一些不同的选项。

鉴于您需要行中的不同列值,我会使用列元数据来处理问题,因为它接收rowIndex作为参数。



var viewModel = {options: ['LongText', 'Text', 'Checkbox']}
 
function apply() {
    var grid, data = [];
        
    var options = {
        editable: true,
        enableCellNavigation: true,
        asyncEditorLoading: false,
        autoEdit: true,
        forcefitColumns: false
         
    };

    var columns = [{
        id: "data",
        name: "Editor Type",
        field: "type",
        width: 120,
        cssClass: "cell-title" ,
        formatter: function(row){ 
            var key = 'input'+row;
            
            if(!viewModel[key]){
              viewModel[key] = ko.observable();
              viewModel[key].subscribe(function(nv){
              
              data[row].type = nv
            })
           }
             
            setTimeout(function(){ ko.applyBindings(viewModel, document.getElementById(key))  }, 250);
            return '<select id="'+key+'", data-bind="options: options, value: '+key+'"></select>'
        }
       },
       {
        id: "other",
        name: "Other",
        field: "other",
        width: 120,
        cssClass: "cell-title",
         
    }];

    for (var i = 0; i < 5; i++) {
        var d = (data[i] = {});

        d["type"] =  "";
        d["other"] = "Default " + i;
    }

    grid = new Slick.Grid("#myGrid", data, columns, options);
    //ko.applyBindings(viewModel)

    data.getItemMetadata=function(row){
    
        var rowData = data[row]
        //console.log(rowData)
        var metaData = {columns:{other: {}}}
        metaData.columns.other.editor = Slick.Editors[rowData.type]
         
        return metaData
    }
   
}

apply()
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<link rel="stylesheet" type="text/css" href="http://JLynch7.github.io/SlickGrid/slick.grid.css">
<script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
<script src="http://code.jquery.com/ui/1.11.0/jquery-ui.min.js"></script>
<script src="http://JLynch7.github.io/SlickGrid/slick.dataview.js"></script>
<script src='http://mleibman.github.io/SlickGrid/lib/jquery.event.drag-2.2.js'></script>
<script src='http://JLynch7.github.io/SlickGrid/slick.core.js'></script>
<script src='http://JLynch7.github.io/SlickGrid/slick.grid.js'></script>
<script src='http://JLynch7.github.io/SlickGrid/slick.formatters.js'></script>
<script src='http://JLynch7.github.io/SlickGrid/slick.editors.js'></script>

<div id='container'>
    <div id="myGrid" style="width:600px;height:300px;"></div>
</div>
&#13;
&#13;
&#13;