前端html页面如何实现多语言切换功能
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端html页面如何实现多语言切换功能相关的知识,希望对你有一定的参考价值。
需要语音翻译脚本库,
html 不能自动切换,但是浏览器自带语音切换还是无法实现多国语言翻译的。
国内的电脑用户基本上是中文、简体繁体和英文切换,首先要搞清楚HTML逻辑,如果要改变网页文字内容要用如JQ的 $("#id).html("内容")来改变网页内容,否则就是调用浏览器自带的插件进行切换,但是电脑并没有集成全世界的语言怎么切换。
(特别提醒:自动语言翻译不一定准确,哪怕是百度翻译、搜狗翻译、有道翻译等等,翻译出来的效果也不一定符合实际语意和专业用语,多国语言网站通常不会用在大型网站上,而是几个页面的网页展示,因为准确翻译多国语言需要人工翻译),目前有见过阿里巴巴电商网站做了多国语言版,不知道怎样实现的。
语言脚本库可以上网去找,下载到网站指定目录再调用
海鸽信息网
参考技术A 每一种语言加载一种对应该语言内容的jsAndroid app应用多语言切换功能实现
最近在做一个多语言切换的功能,类似于微信的语言切换,搜了下资料基本上都是以下这种:
1. 实现的效果
和微信类似,在设置界面打开切换语言的界面,选择语言后重启 HomeActivity,语言切换完成,下次重新打开 App ,也是用户设置的语言。
2. 实现步骤
1. 添加多语言文件
在不同的 value 文件夹下(例如 value 、value-en、values-zh-rTW 文件夹)添加不同语言的 string.xml
文件,我们的项目添加了英文、简体中文、繁体中文三种语言,如下图所示:
其中英文需要翻译,繁体如果没有专门翻译的话,可以找个简繁转换网站,直接将简体中文转成繁体中文,我用的这个网站:在线中文简体转繁体。
2. 更新 Configuration 中的 locale 属性
参照 Android 开发者官网 上 的描述,Configuration 包含了设备的所有的配置信息,这些配置信息会影响应用获取的资源。例如 string 资源,就是根据 Configuration 的 locale 属性来判断该取哪种语言的 string 资源,默认是 value 文件夹下的。
主要代码如下:
1 Resources resources = getContext().getResources(); 2 DisplayMetrics dm = resources.getDisplayMetrics(); 3 Configuration config = resources.getConfiguration(); 4 // 应用用户选择语言 5 config.locale = Locale.ENGLISH; 6 resources.updateConfiguration(config, dm);
我们用了 Locale
中的预设值 Locale.ENGLISH
、Locale.TRADITIONAL_CHINESE
和 Locale.SIMPLIFIED_CHINESE
,如果你需要设置的语言没有预设值,你可以自己新建一个 Locale
对象,具体自行 Google 吧。
注:跟随系统设置是 Locale.getDefault()
3. 重启 HomeActivity
我 们的 App 有个启动页 WelcomeActivity,类似微信那个小人启动页,如果从欢迎页重启,并不是一个好的体验,应该和微信的语言设置一样,直接回到 HomeActivity ,而不是从 WelcomeActivity 重新打开。实现其实也很简单,代码如下:
1 Intent intent = new Intent(this, HomeActivity.class); 2 intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK); 3 getActivity().startActivity(intent);
正常来说这段代码应该是没问题的,但是假如你的 App 存在某个 activity 和当前设置页 activity 不在一个 task 栈内的话(比如你从某个通知页用 FLAG_ACTIVITY_NEW_TASK
启动的一个 activity),就不会应用语言设置。因此可以直接杀掉当前 App 的进程,保证是“整个”重启了:
1 Intent intent = new Intent(this, HomeActivity.class); 2 intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK); 3 startActivity(intent); 4 // 杀掉进程 5 android.os.Process.killProcess(android.os.Process.myPid()); 6 System.exit(0);
按道理杀掉进程的两行代码任意一行即可,但是查阅相关资料,还是两个都加上吧,如果有详细了解欢迎沟通。此段代码其实参考自 CustomActivityOnCrash 开源项目,有兴趣的可以研究下这个开源库捕捉崩溃信息,重启应用部分的代码。
个人觉得这种重启HomeActivity的方法太粗暴了而且体验不好,不过貌似微信也是这么重启了HomeActivity。一般语言切换的设置会藏的比较深,比如微信,如果一个用户对手机操作不熟或者说对这个应用不熟,不小心切换了不知道什么语言然后给我跳回主页,再想设回中文就麻烦咯。所以,我认为最好是切完语言立即刷新然后还是停留当前页比较好。具体实现如下:
1、还是要添加多语言文件,跟上面的步骤1一样;
2、在BaseActivity中实现语言切换代码:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); EventBus.getDefault().register(this); changeAppLanguage(); }
1 public void changeAppLanguage() { 2 String sta = Store.getLanuageIsChinese() ? "zh" : "en";//这是SharedPreferences工具类,用于保存设置,代码很简单,自己实现吧 3 // 本地语言设置 4 Locale myLocale = new Locale(sta); 5 Resources res = getResources(); 6 DisplayMetrics dm = res.getDisplayMetrics(); 7 Configuration conf = res.getConfiguration(); 8 conf.locale = myLocale; 9 res.updateConfiguration(conf, dm); 10 }
1 public void onEvent(String str) { 2 switch (str) { 3 case Constant.EVENT_REFRESH_LANGUAGE: 4 changeAppLanguage(); 5 recreate();//刷新界面 6 break; 7 } 8 }
1 @Override 2 protected void onDestroy() { 3 super.onDestroy(); 4 EventBus.getDefault().unregister(this); 5 }
3、设置界面中的实现自然就是更新sharedPreferences 中的设置,然后发送EventBus就行啦
1 if () {//中文 2 Store.setLanuageIsChinese(true); 3 } else if () {//英文 4 Store.setLanuageIsChinese(false); 5 } 6 EventBus.getDefault().post(Constant.EVENT_REFRESH_LANGUAGE);
基本思路就是这样,如果还有什么更好的方法,敬请给俺留言,让我膜拜一下。
以上是关于前端html页面如何实现多语言切换功能的主要内容,如果未能解决你的问题,请参考以下文章