我很好奇为什么您认为 List of Lists 很难查询和更改。您可以使用长度为 2 的数组作为 [x, y] 对,并将其传递给 getIn、setIn 和 updateIn 方法。
let grid = Immutable.toJS([
['red', 'green'],
['blue', 'yellow']
]);
grid.getIn([0, 1]); // => 'green';
grid = grid.setIn([0, 1], 'purple');
grid.getIn([0, 1]); // => 'purple';
grid = grid.updateIn([0, 0], cell => cell.toUpperCase());
grid.getIn([0, 0]); // => 'RED';
使用map(...) 可以很容易地将某些功能应用于网格中的每个单元格:
grid.map((row, x) => row.map(cell, y) => x + cell + y);
grid.get([1, 1]); // => '1yellow1'
可能比使用 Map 更棘手的事情是尝试查找值的坐标。
const x = grid.findIndex(row => row.contains('blue')); // => 1
const y = grid.get(x).indexOf('blue'); // => 0
grid.get([x, y]); // => blue