iOS多语言本地化流程的优化方案

 更新时间:2018年01月14日 15:43:43   作者:AntScript  
这篇文章主要给大家介绍了关于iOS多语言本地化流程的优化的相关资料,多语言本地化是我们大家在开发中经常会遇到的一个功能,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起看看吧。

前言

多语言本地化,是我们在做IOS项目的时候经常用的,下面根据自己的经验和使用场景,来全面的说说多语言本地化的解决方案。本文从提升效率和减少错误两方面对传统的多语言本地化方式进行了优化,虽然标题是iOS,但其实macOS也通用。下面话不多说了,来一起看看详细的介绍吧。

传统的方法

在 Localizable.strings 中写入多种语言的版本,然后使用 NSLocalizedString 进行本地化:

# en.lproj/Localizable.strings
"login" = "Login";
"logout" = "Logout";
# zh-Hans.lproj/Localizable.strings
"login" = "登录";
"logout" = "退出";
# usage
loginButton.title = NSLocalizedString("login", comment: "login")
logoutButton.title = NSLocalizedString("logout", comment: "logout")

这有什么问题呢?

繁琐!每次都要写 NSLocalizedString(“xxx”, comment: “xxx”) ,虽然有代码补全,但依然很费时。

提升点效率

直接上代码:

extension String {
 var localized: String {
 return NSLocalizedString(self, comment: self)
 }
}

于是现在的使用方式就变成了:

loginButton.title = "login".localized
logoutButton.title = "logout".localized

这样代码简洁多了,也保留了代码的自解释。

但,依然还有问题,如果我不小心写成了:

loginButton.title = "login".localized
logoutButton.title = "loguot".localized

编译不会报错,但logoutButton的title却出不来(注意 “loguot”.localized),写错一个字母,抓bug抓好长时间的经历相信很多人都遇到过吧。

这里涉及到编码中的一个小技巧:不要徒手写同一个需要多次使用的字符串,尽量定义成常量进行调用。

减少些错误

还是直接上代码:

extension String {
 static var localized_login: String { return "login".localized }
 static var localized_logout: String { return "logout".localized }
}

现在用起来就更爽了:

loginButton.title = .localized_login
logoutButton.title = .localized_logout

得益于Xcode代码提示补全的功能,我只需输入”.” “login” 回车,基本就就可以完成输入: localized_login.png

乍一看,已经将写字符串时出错的概率降到最低了,但这样又要多写一堆代码,岂不是把之前好不容易提升起来的效率又降低了,再加上万一,我们在写 localized_logout 时还是写成了 “loguot”.localized ,这不是”辛辛苦苦大半年,一朝回到解放前”的节奏?

自动化万岁

思路:使用脚本读取 Localizable.strings ,然后输出成我们需要的常量格式。

Build Phases中新建一个 Run Script,填入以下脚本:

# Localizable.strings文件路径
localizableFile="${SRCROOT}/${PROJECT_NAME}/Support/en.lproj/Localizable.strings"

# 生成的swift文件路径(根据个人习惯修改)
localizedFile="${SRCROOT}/${PROJECT_NAME}/Source/Utils/LocalizedUtils.swift"

touch $localizedFile

# 将localizable.strings中的文本转为swift格式的常量,存入一个临时文件
sed "s/\" = \".*$/;/g" ${localizableFile} | sed "s/.*/& &/" | sed "s/^\"/ static var localized_/g" | sed "s/; \"/: String { return \"/g" | sed "s/;/\".localized }/g" > "${localizedFile}.tmp"

# 先将localized作为计算属性输出到目标文件
echo -e "import Foundation\n\nextension String {\n var localized: String { return NSLocalizedString(self, comment: self) }" > "${localizedFile}"

# 再将临时文件中的常量增量输出到目标文件
cat "${localizedFile}.tmp" >> "${localizedFile}"

# 最后增量输出一个"}"到目标文件,完成输出
echo -e "\n}" >> "${localizedFile}"

# 删除临时文件
rm "${localizedFile}.tmp"

以上脚本的作用就是将localizable.strings中的内容转换成swift的常量形式,并作为String的extension存储起来,具体步骤看注释。

其中有几点需要注意:

  • 第一次运行记得将LocalizableUtils.swift加入到Xcode项目中
  • sed的用法中,^… 表示以…开头,…$ 表示以…结尾 [参考链接]。
  • > 表示覆盖输出到文件,>> 表示增量输出到文件。
  • echo -e 表示将\n作为换行符输出(其他转义字符同效)。
  • 将 Run Script 放在 Compile Sources 的上面,这样可以在编译代码前执行,如果出现错误也很容易定位(例如Localizable.strings中行末忘记写分号)。

脚本效果:

本地化文件:

# en.lproj/Localizable.strings

"login" = "Login";
"logout" = "Logout";

输出文件:

# LocalizedUtils.swift
import Foundation
extension String {
 var localized: String { return NSLocalizedString(self, comment: self) }

 static var localized_login: String { return "login".localized }
 static var localized_logout: String { return "logout".localized }
}

至此,我们只要在写好Localizable.strings或有修改时 ⌘+B build一下,就能愉快的使用了。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • iOS tableview实现简单搜索功能

    iOS tableview实现简单搜索功能

    这篇文章主要为大家详细介绍了iOS tableview实现简单搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • iOS实现自定义起始时间选择器视图

    iOS实现自定义起始时间选择器视图

    本篇文章主要介绍了iOS实现自定义起始时间选择器视图,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 30分钟快速带你理解iOS中的谓词NSPredicate

    30分钟快速带你理解iOS中的谓词NSPredicate

    NSPredicate类是用来定义逻辑条件约束的获取或内存中的过滤搜索。下面这篇文章将通过30分钟快速带大家理解iOS中的谓词NSPredicate类,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2018-03-03
  • IOS 聊天界面(自适应文字)的实现

    IOS 聊天界面(自适应文字)的实现

    本文主要介绍一个实现聊天界面的思路过程,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • iOS瀑布流的简单实现(Swift)

    iOS瀑布流的简单实现(Swift)

    这篇文章主要介绍了iOS瀑布流的简单实现,说到瀑布流, 或许大家都不陌生, 瀑布流的实现也有很多种! 本文使用两种方法介绍,有兴趣的可以了解一下。
    2016-11-11
  • iOS App使用GCD导致的卡顿现象及解决方法

    iOS App使用GCD导致的卡顿现象及解决方法

    这篇文章主要给大家介绍了关于iOS App使用GCD导致的卡顿现象及解决方法的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • 详解iOS应用开发中的ARC内存管理方式

    详解iOS应用开发中的ARC内存管理方式

    这篇文章主要介绍了详解iOS应用开发中的ARC内存管理方式,文中示例基于Objective-C语言,需要的朋友可以参考下
    2016-02-02
  • iOS添加购物车动画效果示例

    iOS添加购物车动画效果示例

    本篇文章主要介绍了iOS 购物车动画效果示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • iOS应用脚本重签名的实现方法

    iOS应用脚本重签名的实现方法

    这篇文章主要介绍了iOS应用脚本重签名的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • Observing KVO Key-Value基本使用原理示例详解

    Observing KVO Key-Value基本使用原理示例详解

    这篇文章主要为大家介绍了Observing KVO Key-Value基本使用原理示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08

最新评论