在Titanium里实现多语言

移动开发
虽然Titanium里已有实现多语言的API可以非常方便地实现多语言国际化的功能,但其有一定的局限性,即不能在app里随时更换不同的语言,一定要直接更改整个手机里的语言设置才可生效,具体使用可以查看官方教程。

我这里介绍的方法就可以解决直接在app里随时更换语言的问题,实现起来也很简单,原来其实与官方的差不多,也是要通过读取不同的xml语言文件来显示相关语言。OK,废话少说,直接上代码吧:

  1. functionL(text){ 
  2.  
  3. varlangFile=Ti.App.Properties.getString('lang'); 
  4.  
  5. varfile=Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory,'languages/'+langFile+'.xml'); 
  6.  
  7. varxmltext=file.read().text; 
  8.  
  9. varxmldata=Ti.XML.parseString(xmltext); 
  10.  
  11. vardata=xmldata.documentElement.getElementsByTagName(text); 
  12.  
  13. Ti.API.info('lang:'+JSON.stringify(data.item(0).text)); 
  14.  
  15. if(data!=null
  16.  
  17. returndata.item(0).text; 
  18.  
  19. return""
  20.  

以上一个简单的function就可以实现我们想要的效果了,呵呵,接下来让我慢慢解释一下吧。首先第一句

Ti.App.Properties.getString(‘lang’);

就是从当前appsession里获取语言设置,当然这个可放到数据库里保存起来也行,否则关了应用下次再开就没了。第二句

varfile=Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory,’languages/’+langFile+‘.xml’);

就是直接获取相关的语言文件,因此xml的命名规则要和你设置的语言名称一致,如en-US.xml,zh-CN.xml…

后面几句也不需多解释了,一看就知道是读取XML然后获取其属性值的意思。但这里要注意的是XML文件的格式,必须要有一个根,然后才可填写键值对的语言文字,我刚开始就在这里被卡住了,以下是en-US.xml的内容:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <lang> 
  3. <title>title</title> 
  4. </lang> 
  5.  
  6.   

OK,就是调用此函数,如以上语言key是title,那么只需直接使用:

Ti.App.Properties.setString(‘lang’,'en-US’);//设置当前语言

Ti.API.info(‘title:’+L(‘title’));

就可以获取当前语言的文字了,用此方法就可实现让用户随时更换当前语言

责任编辑:佚名 来源: 移动Web开发社区
相关推荐

2011-08-05 17:54:33

Cocoa Touch 多语言

2009-08-25 10:44:50

C#实现多语言

2014-04-16 14:50:20

Spark

2014-07-09 09:20:06

WPFWPF应用

2009-08-31 17:13:09

2024-05-09 08:14:09

系统设计语言多语言

2022-08-09 07:22:15

语言数据库程序

2009-08-21 18:46:30

下载Server 20

2023-08-04 10:18:15

2021-09-07 10:17:35

iOS多语言适配设计

2021-06-29 21:48:32

开源语言架构

2009-08-03 17:33:01

ASP.NET多语言支

2021-07-24 11:41:42

前端开发技术

2009-07-17 10:02:29

WPF程序多语言支持

2010-11-19 09:25:06

to_dataOracle

2020-04-14 09:50:02

2019-08-22 10:20:41

Ubuntu设置语言

2019-12-05 16:00:15

Vim插件编程文本编辑器

2022-10-27 22:11:40

react扩展库语言

2020-09-16 14:01:10

Vue.js项目语言
点赞
收藏

51CTO技术栈公众号