Flutter Map 常用操作方法概述

Flutter 中的 Map 是一种键值对的集合,可以存储任意类型的数据,并且可以通过键来访问和操作对应的值。

1. 创建 Map:

可以使用 {} 或者 Map.from() 方法来创建 Map。例如:

dart 复制代码
// 使用 {} 创建 Map
var myMap = {
  'key1': 'value1',
  'key2': 'value2',
  'key3': 'value3',
};

// 使用 Map.from() 创建 Map
var myMap = Map.from([
  ['key1', 'value1'],
  ['key2', 'value2'],
  ['key3', 'value3'],
]);
2. 添加元素:

可以使用 map[key] = value 或者 map.put(key, value) 方法来添加元素。例如:

dart 复制代码
myMap['key4'] = 'value4';
myMap.put('key5', 'value5');
3. 获取元素:

可以使用 map[key] 方法来获取元素。如果键不存在,会返回 null。例如:

dart 复制代码
var value = myMap['key1']; // value = 'value1'
4. 删除元素:

可以使用 map.remove(key) 或者 map.clear() 方法来删除元素。例如:

dart 复制代码
myMap.remove('key2'); // 删除键为 'key2' 的元素
myMap.clear(); // 清空所有元素
5. 遍历元素:

使用键来获取值:通过使用键作为索引,可以获取到与之对应的值。例如,map'key'可以获取到键为'key'的元素的值。

可以使用 for..in 循环或者 map.keysmap.values 方法来遍历元素。

5.1 使用keys方法获取所有的键:

map.keys可以获取到Map中所有的键,返回的也是一个Iterable对象

dart 复制代码
for (var key in myMap.keys) {
  print('${key}: ${myMap[key]}');
}

或者:

dart 复制代码
for (var key in myMap.keys) {
  print('${key}: ${myMap.values.firstWhere((value) => value == myMap[key])}');
   // 使用 values 遍历找到对应的值并输出,可能会效率低下,不建议频繁使用此操作。
}

或者

dart 复制代码
void main() {  
  var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};  
    
  for (var entry in map.entries) {  
    print('Key: ${entry.key}, Value: ${entry.value}');  
  }  
}
5.2 Map.Entry
  • firstEntry是Map类的一个方法,用于获取Map中的第一个元素。返回的是一个MapEntry对象,可以通过entry.key和entry.value来获取键和值。
dart 复制代码
var entry = map.firstEntry; // 获取第一个元素  
print('Key: ${entry.key}, Value: ${entry.value}');
  • lastEntry方法返回Map中的最后一个元素
dart 复制代码
var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};
var lastEntry = map.lastEntry;
print('Key: ${lastEntry.key}, Value: ${lastEntry.value}');

输出结果为:Key: key3, Value: value3

  • singleEntry方法返回Map中的唯一个元素,如果Map中只有一个元素,则返回该元素;如果Map中没有元素或者有多个元素,则返回null。
dart 复制代码
var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};
var singleEntry = map.singleEntry;
if (singleEntry != null) {
  print('Key: ${singleEntry.key}, Value: ${singleEntry.value}');
} else {
  print('Map is empty or contains multiple entries.');
}

输出结果为:Key: key3, Value: value3

如果Map中没有元素或者有多个元素,使用singleEntry方法会返回null,需要进行空判断或者异常处理。

5.3 forEach方法对Map中的每个键值对进行遍历
dart 复制代码
void main() {  
  var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};  
    
  map.forEach((key, value) {  
    print('Key: $key, Value: $value');  
  });  
}
5.4 使用for循环遍历Map中的键值对
dart 复制代码
void main() {  
  var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};  
    
  for (var entry in map.entries) {  
    print('Key: ${entry.key}, Value: ${entry.value}');  
  }  
}
5.5 使用entries方法遍历Map中的所有键值对
dart 复制代码
void main() {  
  var map = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'};  
    
  for (var entry in map.entries) {  
    print('Key: ${entry.key}, Value: ${entry.value}');  
  }  
}
相关推荐
愚者Pro5 小时前
切换本地 Flutter SDK 版本
flutter
TT_Close5 小时前
别再复制旧 Flutter 工程了,真正拖慢你的不是业务代码
flutter·npm·visual studio code
光影少年7 小时前
懒加载与分包:React.lazy + Suspense
前端·react.js·掘金·金石计划
风华圆舞7 小时前
鸿蒙 + Flutter 下 AI 助手为什么要支持流式输出
人工智能·flutter·harmonyos
风华圆舞11 小时前
鸿蒙 + Flutter 下 AI 页面的状态协同设计
人工智能·flutter·harmonyos
风华圆舞13 小时前
鸿蒙语音播报功能 的 Flutter 侧封装思路
flutter·华为·harmonyos
brycegao32113 小时前
Flutter 国际化富文本解决方案:基于双层占位符的轻量化图文混排方案
flutter·国际化·i18n·富文本·rtl·移动端工程架构
风华圆舞13 小时前
鸿蒙 + Flutter 下美食探索场景为什么 AI 推荐比传统搜索更自然
flutter·harmonyos·美食
MemoriKu13 小时前
Flutter 相册 APP 收尾优化实战:未分析任务横幅持久隐藏与标签回归测试补强
大数据·人工智能·flutter·elasticsearch·机器学习·搜索引擎·重构
风华圆舞15 小时前
鸿蒙 + Flutter 如何把 AI 助手嵌进应用页面里——以食界探味为
人工智能·flutter·harmonyos