下面是一个场景:
_________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列中。
我希望编辑器保持不变--但无法找到如何在单元格级而不是列级别上执行此操作。谢谢
发布于 2015-01-07 17:47:58
浏览来源 (getEditor第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()<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>
https://stackoverflow.com/questions/27818057
复制相似问题