用Flutter Intl 实现项目国际化

前言: 因为之前公司项目中做过iOS的国际化,学了Flutter之后也想试着做国际化相关的东西,这段时间闲在家里,就一边对之前的项目进行一个总结,一边研究一下之前想搞而没有时间搞的东西。其中Flutter的国际化就是其中之一

Flutter Intl 既支持Android Studio也支持VS Code,本文以Android Studio为例:

下载

步骤:Android Studio --->Settings --->Plugins ---> Marketplace ---> 搜索框输入Intl ---> Install

注:因为我已经下载过了,所以图中没有install按钮,如果没有下载过的同学在下图中用红框圈住的右下角会有Install按钮

WX20240904-145537@2x.png

项目国际化前期准备

下载完Flutter Intl 之后在Android Studio顶部菜单栏Tool下就会出现Flutter Intl选项,如下图中的2、


WX20240905-082951@2x.png

点击图中3、之后项目中lib文件夹下就会多出两个文件夹:


WX20240904-150856@2x.png

这里把重要文件说明一下

  • I10n.dart: S对象,代码中国际的时候需要用到的主要对象
  • intl_en.arb: 存放的就是我们英文文案需要国际化的字段。以json的形式存放

打开intl_en.arb文件,里面目前是空的,这里面存放的就是我们英文文案需要国际化的字段。以json的形式存放。如下图


WX20240904-151729@2x.png

把需要国际化的文案放如之后保存:command + s
Flutter Intl会帮我们把刚才的字段自动动的生成get方法。

添加新的国际化语言

如果要添加新的需要国际化的语言(以中文为例):步骤 Tool ---> Flutter Intl ---> Add Locale

WX20240905-082004@2x.png

这个时候项目中会多出两个文件
WX20240905-082326@2x.png

之后和上面添加英语国际化字段一样,把需要中文翻译的字段以json的形式放入intl_zh.arb中然后command + s。这样中文国际化就完成了
到这里前期的准备也就做完了

项目中使用

  • 1、在项目的main函数中找到MaterialApp
  • 2、supportedLocales添加S.delegate.supportedLocales
  • 3、在localizationsDelegates中添加S.delegate
    具体代码如下
class GHJApp extends StatelessWidget {
  const GHJApp({super.key});
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: GHJHomePage(),
      theme: ThemeData(
        highlightColor: Colors.transparent
      ),
      // 国际化需要支持的语言
      supportedLocales: S.delegate.supportedLocales, // 从S对象中获取
      // 设置widgets需要国际化
      localizationsDelegates: const [
        S.delegate,// 添加S的delegate
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
        GlobalCupertinoLocalizations.delegate,
        // GHJLocalizationsDelegate.delegate,
      ],
    );
  }
}
  • 4、在需要使用的时候直接用S.of(context).例如
Text(S.of(context).home_page_hello)
到此国际化基本操作就完成了
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 通过命令行创建项目flutter create YYFood; 用Android Studio 打开新建项目YYF...
    YanZi_33阅读 595评论 0 0
  • 概述 国际化的认识 国际化的适配 国际化的工具 一、国际化的认识 开发一个App,如果我们的App需要面向不同的语...
    IIronMan阅读 759评论 0 2
  • 一. 国际化的认识 开发一个App,如果我们的App需要面向不同的语种(比如中文、英文、繁体等),那么我们需要对齐...
    AlanGe阅读 497评论 0 0
  • 一. 国际化的认识 开发一个App,如果我们的App需要面向不同的语种(比如中文、英文、繁体等),那么我们需要对齐...
    Imkata阅读 975评论 0 0
  • 前言 如果APP有需要支持多种语言,就需要支持国际化,无论是android和ios,现在针对flutter的国际化...
    lebonbill阅读 10,791评论 4 6