前端html页面如何实现多语言切换功能

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端html页面如何实现多语言切换功能相关的知识,希望对你有一定的参考价值。

需要语音翻译脚本库,

html 不能自动切换,但是浏览器自带语音切换还是无法实现多国语言翻译的。

国内的电脑用户基本上是中文、简体繁体和英文切换,首先要搞清楚HTML逻辑,如果要改变网页文字内容要用如JQ的 $("#id).html("内容")来改变网页内容,否则就是调用浏览器自带的插件进行切换,但是电脑并没有集成全世界的语言怎么切换。

(特别提醒:自动语言翻译不一定准确,哪怕是百度翻译、搜狗翻译、有道翻译等等,翻译出来的效果也不一定符合实际语意和专业用语,多国语言网站通常不会用在大型网站上,而是几个页面的网页展示,因为准确翻译多国语言需要人工翻译),目前有见过阿里巴巴电商网站做了多国语言版,不知道怎样实现的。

语言脚本库可以上网去找,下载到网站指定目录再调用



海鸽信息网

参考技术A 每一种语言加载一种对应该语言内容的js

Android 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.ENGLISHLocale.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页面如何实现多语言切换功能的主要内容,如果未能解决你的问题,请参考以下文章

iOS-多语言版本开发(转载)

php网站中英文切换

非单页的静态文件如何实现多语言切换

java中如何实现多语言切换

asp 中如何实现多语言切换???如简体中文、繁体中文、英文。

[sciter]:sciter如何使用i18实现桌面应用多语言切换及其利弊