当前位置: 首页 > news >正文

Flutter 国际化(i18n)全指南:一键切换中/英/日多语言

一、为什么需要国际化?

如果你的应用面向全球用户,多语言支持是基本要求。Flutter 官方提供了强大的flutter_localizations包,配合intl工具,可轻松实现多语言切换。


二、快速上手:三步实现中英文切换

步骤 1:添加依赖

yaml

编辑

# pubspec.yaml dependencies: flutter: sdk: flutter flutter_localizations: sdk: flutter intl: ^0.19.0

步骤 2:配置 MaterialApp

dart

编辑

import 'package:flutter_localizations/flutter_localizations.dart'; void main() => runApp(const MyApp()); class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( localizationsDelegates: const [ GlobalMaterialLocalizations.delegate, GlobalWidgetsLocalizations.delegate, GlobalCupertinoLocalizations.delegate, ], supportedLocales: const [ Locale('en', ''), // 英语 Locale('zh', ''), // 中文 Locale('ja', ''), // 日语 ], home: HomePage(), ); } }

步骤 3:使用AppLocalizations

dart

编辑

// 获取当前语言文本 Text(AppLocalizations.of(context)!.helloWorld)

⚠️ 但此时会报错:缺少AppLocalizations类!


三、生成多语言资源文件(关键步骤)

1. 创建l10n.yaml文件(项目根目录)

yaml

编辑

arb-dir: lib/l10n template-arb-file: app_en.arb output-localization-file: app_localizations.dart

2. 创建语言文件

  • lib/l10n/app_en.arb

    json

    编辑

    { "helloWorld": "Hello World", "welcomeMessage": "Welcome, {name}!" }
  • lib/l10n/app_zh.arb

    json

    编辑

    { "helloWorld": "你好,世界", "welcomeMessage": "欢迎,{name}!" }
  • lib/l10n/app_ja.arb

    json

    编辑

    { "helloWorld": "こんにちは、世界", "welcomeMessage": "ようこそ、{name}さん!" }

3. 生成代码

bash

编辑

flutter gen-l10n

✅ 自动生成app_localizations.dart,无需手动编写!


四、动态切换语言(带保存)

dart

编辑

// 切换语言并重启应用 void changeLanguage(BuildContext context, String locale) { final MyAppState? state = context.findAncestorStateOfType<MyAppState>(); if (state != null) { state.setLocale(Locale(locale)); } } // 在 MyApp 中管理状态 class MyApp extends StatefulWidget { const MyApp({super.key}); @override State<MyApp> createState() => MyAppState(); } class MyAppState extends State<MyApp> { late Locale _locale; @override void initState() { super.initState(); _locale = const Locale('zh'); // 默认中文 } void setLocale(Locale locale) { setState(() { _locale = locale; }); } @override Widget build(BuildContext context) { return MaterialApp( locale: _locale, // ...其他配置同上 ); } }

💡 可结合shared_preferences保存用户选择。


五、实际效果展示

语言截图
中文
English
日本語

📌 支持参数化文本:AppLocalizations.of(context)!.welcomeMessage('张三')


六、高级技巧

  1. 复数形式(如 “1 item” vs “2 items”):

    arb

    编辑

    "itemCount": "{count, plural, =0{无项目} =1{1个项目} other{{count}个项目}}"
  2. 日期/数字本地化

    dart

    编辑

    DateFormat.yMMMd().format(DateTime.now()); // 自动适配语言格式
  3. RTL 语言支持(如阿拉伯语):

    dart

    编辑

    MaterialApp( supportedLocales: [Locale('ar')], localizationsDelegates: [...], theme: ThemeData(useMaterial3: true), )

    Flutter 会自动镜像布局!


七、结语

国际化不再是“附加功能”,而是产品出海的必备能力。Flutter 的gen-l10n工具链让多语言开发变得简单高效。

完整示例代码:github.com/yourname/flutter-i18n-demo

如果你正在做全球化 App,不妨现在就集成 i18n!


http://www.jsqmd.com/news/100885/

相关文章:

  • java计算机毕业设计手机仓库管理系统 移动端库存智能管理平台的设计与实现 基于手机的仓储作业协同系统开发
  • 永磁同步电机谐波注入与5/7次谐波抑制——基于MATLAB Simulink仿真模型操作教程
  • 降本增效利器!这款洗车小程序源码助您轻松搭建管理平台
  • 基于CNN多变量时间序列预测的MATLAB程序(含清晰注释与测试数据集)
  • 三相锁相环(SRF-PLL)并网逆变器 Matlab Simulink仿真
  • MSWOA算法,基于多策略混合改进鲸鱼算法 Matlab语言 改进后测试函数结果显示,相较与W...
  • 调研分享 | 面向异构集群环境的分布式训练并行方案调研
  • 【青岛理工】25年计网期末A卷回忆版
  • Memgraph 全新 AI 图工具包:一键构建 GraphRAG 聊天机器人,实现快速上下文感知响应
  • 数字卡尺与几何魔法:聊聊那些藏在代码里的测量艺术
  • 创业与拓展必备!支持无限开号的洗车小程序系统源码
  • 艾默生EV2000变频器源代码:算法特色显著
  • 主动配电网故障恢复的重构与孤岛划分模型 关键词:分布式电源 故障网络重构 主动配电网 孤岛划分...
  • 数字人平台选型指南:四大维度全面解析
  • [特殊字符]名企研学|走进比亚迪!解锁新能源汽车的未来密码[特殊字符][特殊字符]
  • 51单片机数字电压表
  • COMSOL的多物理场仿真工具箱里藏着电池工程师的快乐密码。今天咱们不聊虚的,直接看几个实操案例。比如锂离子电池的热失控模拟,这个参数设置界面里藏着魔鬼细节
  • 快速上线的二手车小程序源码系统,助力车商降本增效
  • 开源替代SaaS:一次部署长期受益,多维表格自建方案全解析
  • 【光学】基于九个光谱波段多光谱成像系统食品质量评估(范围为400nm-1000nm)附Matlab代码
  • STL中容器适配器:stack,queue,priority_queue 的介绍与简单模拟实现
  • (一)系统介绍及后端框架构建
  • 【源码开源】基于STM32的应急救援仓系统 | 救援效率和实时监控
  • ESP32模组买四博智联的
  • 电影解说文案:LobeChat写出爆款短视频脚本
  • 【开源源码】基于 STM32智能温度监控系统 | 一个支持远程监控与告警的嵌入式实践项目
  • springboot数据上链FISCO BCOS
  • Modbus TCP关键知识点回顾
  • 考虑寿命损耗的微网电池储能容量优化配置 关键词:两阶段鲁棒优化 KKT条件 CCG算法 寿命损耗
  • nVisual模块之间关系