Flutter 多语言国际化配置 -- 使用Intl插件

安装插件
  • Android Studio -> File -> Setting -> Plugins -> 搜索Flutter Intl
  • 在这里插入图片描述
配置项目
首先在项目pubspec.yaml中添加如下语句并执行 package get
dev_dependencies:
...
  flutter_localizations:
    sdk: flutter
在菜单栏的Tool下找到Flutter Intl 并选择Initalize for the project, 配置结束后效果如下:
1. 会在 pubspec.yaml中增加以下字段
flutter_intl:  
    enabled: true
2. 会在lib目录下增加 generated 和 l10n两个包
  • 在这里插入图片描述
  • generated包下的intl包默认存在一个messages_all.dartmessages_en.dart文件,messages开头的文件会在添加语言后自动生成
  • l10n包下存在一个intl_en.arb文件
添加语言
Tool下找到Flutter Intl 并选择Add Locale, 并输入语言类型(eg: zh),配置结束后会生成如下文件
1. lib目录下l10n包下会生成一个 intl_zh.arb
2. generated包下的intl包中生成messages_zh.dart文件
初始化Flutter国际化
在主页面build中加入

return MaterialApp(
  ...
    localizationsDelegates: const [
      S.delegate,
      GlobalMaterialLocalizations.delegate,
      GlobalCupertinoLocalizations.delegate,
      GlobalWidgetsLocalizations.delegate
    ],
    // 设置中文为首选项
    supportedLocales: [const Locale('zh', ''), ...S.delegate.supportedLocales],
  ...
);
配置多语言
  • 分别在 intl_en.arb 和 intl_zh.arb下添加字符串
  • 在需要配置国际化的地方调用S.of(context).字符串即可
示例效果

完整项目
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wjxbless

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值