Flutter - International 国际化,Localization 本地化, 使用字符串Map

简介: 记录一种简单的方式实现字符串的国际化。这里没有用到Intl包,而是将所需的字符串存放在一个map中。步骤:MaterialApp中添加本地化代理和语言类型创建文字资源文件新建一个类继承LocalizationsDelegate,和文字资源文件联系起来使用代理获取想要的文字资源新建项目international_demo,得到一个带按钮示例工程。

记录一种简单的方式实现字符串的国际化。
这里没有用到Intl包,而是将所需的字符串存放在一个map中。

步骤:

  • MaterialApp中添加本地化代理和语言类型
  • 创建文字资源文件
  • 新建一个类继承LocalizationsDelegate,和文字资源文件联系起来
  • 使用代理获取想要的文字资源

新建项目international_demo,得到一个带按钮示例工程。改造一下MaterialApp

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        primarySwatch: Colors.blue,
      ),
      localizationsDelegates: [// 添加区域
        // 准备在这里添加我们自己创建的代理
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
      ],
      supportedLocales: [ // 添加区域
        const Locale('en', 'US'), // English
        const Locale('he', 'IL'), // Hebrew
        // 可以继续添加我们想要支持的语言类型
      ],
      home: new MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

创建资源文件

新建localization_src.dart,将字符串存入一个map中。

import 'package:flutter/material.dart';

class DemoLocalizations {
  DemoLocalizations(this.locale);

  final Locale locale;

  static DemoLocalizations of(BuildContext context) {
    return Localizations.of<DemoLocalizations>(context, DemoLocalizations);
  }

  static Map<String, Map<String, String>> _localizedValues = {
    'en': {
      'title': 'Hello World',
    },
    'es': {
      'title': 'Hola Mundo',
    },
    'zh': {
      'title': '你好呀',
    },
  };

  String get title {
    return _localizedValues[locale.languageCode]['title'];
  }
}

这里仅以title为例,有英语、西班牙语和中文三种。

创建代理

新建一个类继承LocalizationsDelegate,复写3个方法。

import 'dart:async';

import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:international_demo/localization_src.dart';

class DemoLocalizationsDelegate
    extends LocalizationsDelegate<DemoLocalizations> {
  const DemoLocalizationsDelegate();

  @override
  bool isSupported(Locale locale) =>
      ['en', 'es', 'zh'].contains(locale.languageCode);

  @override
  Future<DemoLocalizations> load(Locale locale) {
    return SynchronousFuture<DemoLocalizations>(DemoLocalizations(locale));
  }

  @override
  bool shouldReload(DemoLocalizationsDelegate old) => false;
}

复写的load方法中,使用了SynchronousFuture

使用代理

回到main.dart

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        primarySwatch: Colors.blue,
      ),
      localizationsDelegates: [
        DemoLocalizationsDelegate(),// 这是我们新建的代理
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
      ],
      supportedLocales: [
        const Locale('en', 'US'), // English
        const Locale('he', 'IL'), // Hebrew
        const Locale('zh', ''),   // 新添中文,后面的countryCode暂时不指定
      ],
      home: new MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

_MyHomePageState中调用DemoLocalizations

    DemoLocalizations localizations = DemoLocalizations.of(context);
    print(localizations); // 打印出 I/flutter (25535): Instance of 'DemoLocalizations'

观察logcat,可知我们获得了DemoLocalizations的实例。

获取title

DemoLocalizations.of(context).title

如果需要更多的字符串,需要我们手动在资源文件的map中添加。
这里仅以title为例。

文件

参考:

  • 官方文档 https://flutter.io/tutorials/internationalization/
目录
相关文章
|
JSON Dart IDE
Flutter实现国际化
开发一个App,如果我们的App需要面向不同的语种(比如中文、英文、繁体等),那么我们需要对齐进行国际化开发
905 0
Flutter实现国际化
|
3天前
|
自然语言处理 前端开发 开发者
【Flutter前端技术开发专栏】Flutter中的国际化与本地化支持
【4月更文挑战第30天】Flutter支持国际化与本地化,借助`Intl`包和`Localizations`类,帮助开发者实现多语言应用。`Intl`提供日期、时间格式化,而`Localizations`管理不同语言环境的资源。在`pubspec.yaml`添加`intl`依赖,创建本地化资源文件并定义`LocalizationsDelegate`。通过`Localizations.of()`获取本地化资源,实现应用适应不同语言环境。
【Flutter前端技术开发专栏】Flutter中的国际化与本地化支持
|
3天前
|
存储 自然语言处理 API
Flutter应用的国际化支持:实现多语言环境的优雅策略
【4月更文挑战第26天】Flutter提供强大的国际化(i18n)和本地化(l10n)支持,使开发者能轻松实现应用多语言特性。通过定义`.arb`文件来管理字符串资源,使用`LocalizationsDelegate`加载资源,设置应用语言环境,以及在UI中使用`S.of(context).someString`访问字符串。进阶技巧包括字符串格式化、复数形式、双向文本和Unicode支持。充分测试确保所有语言正确显示。随着全球化需求增长,Flutter的国际化支持成为应用开发关键。
|
3天前
|
存储 容器
Flutter 应用服务:主题、暗黑、国际化、本地化-app_service库
Flutter 应用服务:主题、暗黑、国际化、本地化-app_service库
101 0
|
Dart 索引
[Flutter]足够入门的Dart语言系列之变量的类型:bool、String、num、List、Set和Map
变量的类型指的是变量的特性或特征,比如表示数字类型、文本类型、集合类型等,表示的是一类数据。 Dart提供以下类型:int, double、String、List、Set、Map、null...
560 0
[Flutter]足够入门的Dart语言系列之变量的类型:bool、String、num、List、Set和Map
|
Dart 程序员 开发者
Flutter开发: 将本地相册图片转换成Base64字符串
在Flutter开发中,关于图片上传和展示也是常用必用的操作,尤其是在设置APP用户的头像信息,以及上传背景图的操作。关于Flutter开发中图片的上传和展示也是比较常用的操作,也有对应的组件和插件,但是关于一些引申的需求操作,常规的操作是满足不了需要的,那么本文就来分享一下在实际业务需求中常用的需求:把从相册选中的图片转换成Base64之后再显示,或者展示获取到的Base64的图片。接下来就来分享一下关于相关的操作方法,方便查阅使用。
445 0
|
JSON Dart IDE
Day18 - Flutter - 国际化(下)
Day18 - Flutter - 国际化(下)
523 0
Day18 - Flutter - 国际化(下)
|
JSON Android开发 iOS开发
Day18 - Flutter - 国际化(上)
Day18 - Flutter - 国际化(上)
254 0
Day18 - Flutter - 国际化(上)
|
3天前
|
缓存 监控 前端开发
【Flutter 前端技术开发专栏】Flutter 应用的启动优化策略
【4月更文挑战第30天】本文探讨了Flutter应用启动优化策略,包括理解启动过程、资源加载优化、减少初始化工作、界面布局简化、异步初始化、预加载关键数据、性能监控分析以及案例和未来优化方向。通过这些方法,可以缩短启动时间,提升用户体验。使用Flutter DevTools等工具可助于识别和解决性能瓶颈,实现持续优化。
【Flutter 前端技术开发专栏】Flutter 应用的启动优化策略
|
1天前
|
前端开发 C++ 容器
Flutter-完整开发实战详解(一、Dart-语言和-Flutter-基础)(1)
Flutter-完整开发实战详解(一、Dart-语言和-Flutter-基础)(1)