如何像forEach一样遍历不可变列表?
How to loop through Immutable List like forEach?
我想循环遍历 Immutable List
,我用 List.map
来做,它可以工作,但不好。有没有更好的方法?因为我只是检查数组中的每个元素,如果元素符合我的规则,我会做一些事情,就像 Array.forEach
,我不想 return 任何东西,比如 Array.map
.
比如现在是我的作品:
let currentTheme = '';
let selectLayout = 'Layout1';
let layouts = List([{
name: 'Layout1',
currentTheme: 'theme1'
},{
name: 'Layout2',
currentTheme: 'theme2'
}])
layouts.map((layout) => {
if(layout.get('name') === selectLayout){
currentTheme = layout.get('currentTheme');
}
});
List.forEach
方法适用于 Immutable.js 个列表。
但是,更实用的方法是使用方法 List.find
,如下所示:
let selectLayoutName = 'Layout1';
let layouts = List([Map({
name: 'Layout1',
currentTheme: 'theme1'
}),Map({
name: 'Layout2',
currentTheme: 'theme2'
})])
selectLayout = layouts.find(layout => layout.get('name') === selectLayoutName);
currentTheme = selectLayout.get('currentTheme')
那么你的代码就没有副作用了。
我想循环遍历 Immutable List
,我用 List.map
来做,它可以工作,但不好。有没有更好的方法?因为我只是检查数组中的每个元素,如果元素符合我的规则,我会做一些事情,就像 Array.forEach
,我不想 return 任何东西,比如 Array.map
.
比如现在是我的作品:
let currentTheme = '';
let selectLayout = 'Layout1';
let layouts = List([{
name: 'Layout1',
currentTheme: 'theme1'
},{
name: 'Layout2',
currentTheme: 'theme2'
}])
layouts.map((layout) => {
if(layout.get('name') === selectLayout){
currentTheme = layout.get('currentTheme');
}
});
List.forEach
方法适用于 Immutable.js 个列表。
但是,更实用的方法是使用方法 List.find
,如下所示:
let selectLayoutName = 'Layout1';
let layouts = List([Map({
name: 'Layout1',
currentTheme: 'theme1'
}),Map({
name: 'Layout2',
currentTheme: 'theme2'
})])
selectLayout = layouts.find(layout => layout.get('name') === selectLayoutName);
currentTheme = selectLayout.get('currentTheme')
那么你的代码就没有副作用了。