json - 使用 json 文件中的动态字符串进行颤振国际化
问题描述
到目前为止,我使用的是动态字符串,如这篇文章的解决方案所示: Flutter internationalization - Dynamic strings
这是一个例子:
AppLocalizations.of(context).userAge(18)
在 AppLocalizations.dart 上:
userAge(age) => Intl.message(
"My age is $age",
name: "userAge",
args: [age]);
// Return "My age is 18"
但后来我读了这篇关于颤振国际化的文章:https ://medium.com/flutter-community/flutter-internationalization-the-easy-way-using-provider-and-json-c47caa4212b2 其中显示了如何使用 json 文件进行本地化字符串的资源文件。它看起来更方便,所以我更喜欢使用这种方法,但不知道如何从 json 文件中获取具有动态值的字符串。
有什么解决办法吗?
解决方案
要从 JSON 文件中获取具有动态值的字符串,您可以使用
final age = 18 //user input.
final ageString = 'user_age'
.localisedString()
.replaceAll(new RegExp(r'\${age}'), age)
en.json
{
"user_age": "My age is ${age}",
"user_name_age": "My name is ${name} and age is ${age}"
}
string_extension.dart
extension Localisation on String {
String localisedString() {
return stringBy(this) ?? '';
}
}
另外,你可以做类似的事情,
String localisedString(Map<String, String> args) {
String str = localisedString();
args.forEach((key, value) {
str = str.replaceAll(new RegExp(r'\${'+key+'}'), value);
});
return str;
}
//usecase
final userName = 'Spider Man'
final age = '18'
final nameAgeString = 'user_name_age'.localisedString({'name': userName, 'age': age})
app_localisation.dart
Map<String, dynamic> _language;
String stringBy(String key) => _language[key] as String ?? 'null';
class AppLocalisationDelegate extends LocalizationsDelegate {
const AppLocalisationDelegate();
// override the following method if you want to specify the locale you are supporting.
final _supportedLocale = ['en'];
@override
bool isSupported(Locale locale) => _supportedLocale.contains(locale.languageCode);
@override
Future load(Locale locale) async {
String jsonString = await rootBundle
.loadString("assets/strings/${locale.languageCode}.json");
_language = jsonDecode(jsonString) as Map<String, dynamic>;
print(_language.toString());
return SynchronousFuture<AppLocalisationDelegate>(
AppLocalisationDelegate());
}
@override
bool shouldReload(AppLocalisationDelegate old) => false;
}
推荐阅读
- javascript - chrome devtools 显示 react__WEBPACK_IMPORTED_MODULE 而不是组件名称
- r - 在给定数据框的情况下生成单个值的频率表的函数,该数据框在 R 中有一列以逗号分隔的值
- python - 我不断收到此错误“ValueError:检查输入时出错:预期dense_8_input有2维,但得到的数组形状为(705、66、1)”
- c# - C# UWP 从拖动的文件中读取
- python - 计算最近邻时循环卡住
- java - 删除 Cookie Spring Boot
- python - Python“语音识别”在 Mac m1 上不起作用
- python - Windows 上的 ImportError
- python - 从 if 语句调用的函数不起作用
- r - R install.package 在未找到数据原始文件时失败