JS国际化网站中英文切换(理论支持所有语言)应用于h5版APP
网页框架类APP实现国际化参考文案一
参考:https://blog.csdn.net/CSDN_LQR/article/details/78026254
另外付有自己实现的方法 本人用于H5版的APP使用
一、简述
把页面成国际化,实现中英文切换,为此,网上找了一些中英文切换的解决方案,大概为如下两种:
1、使用谷歌整站翻译Api
优点:只须调用接口,即可轻松完成整站翻译,翻译准确度还行。
缺点:需要梯子。
参考文章:js代码实现网站中英文相互翻译
2、自己编写中英文对照表,用js控制
优点:一对一翻译,所以准确度最高。
缺点:需要编写大量中英文对照表,只适合于少量的固定翻译。
参考文章:html页面如何实现中英文切换?
由于公司的要求是把整站进行翻译,且官网中存在新闻,即存在大量不可预料的数据,同时考虑到富文本数据不好翻译。所以,总的来说,第一种方案最为合适,不过可惜,需要梯子,没办法,只能别寻出路。好在微软也有一个类似谷歌整站翻译的Api:
The Translator Web Widget API
其实,微软提供的Demo实现上也很简单,分如下几步:
引入The Translator Web Widget API
监听dom加载完毕,调用Microsoft.Translator.Widget.Translate()整站翻译。
二、实现
1、封装language.js
根据上面的对微软提供的Demo的研究,我们对此进一步封装,因为中英文切换一般都是一次点击后,往后的统一每个页面都需要或不需要翻译,这就需要记录一个状态值,这里选用html5提供的storage来储存这个状态,并向外提供一个修改该状态并刷新页面的方法。故,该js(language.js)编写如下:
$(function(){
// do something
var script=document.createElement("script");
script.type="text/javascript";
script.src="http://www.microsoftTranslator.com/ajax/v3/WidgetV3.ashx?siteData=ueOIGRSKkd965FeEGM5JtQ**";
document.getElementsByTagName('head')[0].appendChild(script);
var value = sessionStorage.getItem("language");
document.onreadystatechange = function () {
if (document.readyState == 'complete') {
if(value==="1"){
Microsoft.Translator.Widget.Translate('zh-CHS', 'en', onProgress, onError, onComplete, onRestoreOriginal, 2000);
}
}
}
function onProgress(value) {
}
function onError(error) {
}
function onComplete() {
$("#WidgetFloaterPanels").hide();
}
function onRestoreOriginal() {
}
});
function translate(){
var value = sessionStorage.getItem("language");
if(value==="1"){
sessionStorage.setItem("language", "0");
}else{
sessionStorage.setItem("language", "1");
}
window.location.reload();//刷新当前页面.
}
2、编写测试页面
编写一个测试页面(test.html)。要使用上面的language.js,必须进行以下三步:
设置页面编码为utf-8
引入jquery和language.js
设置按钮的点击事件,去调用中英文切换函数:translate();
<!DOCTYPE html>
<head>
<title>Microsoft Widget API Sample</title>
<meta charset="UTF-8"/>
<script type="text/javascript" src="jquery-1.11.3.js"></script>
<script type="text/javascript" src="language.js"></script>
</head>
<body>
<button id="change">中英文切换</button
</br></br></br></br></br></br></br></br></br></br></br></br></br></br></br>
<div style="text-align: center" >
你好
</div>
</body>
<script type="text/javascript">
$("#change").click(function(){
translate();
})
</script>
</html>
试试看效果吧,反正我觉得还行~
三、其他
上面编写的language.js中写死了中文转英文(zh-CHS转en),如果项目需要其他语言的转换,对language.js进行自定义扩展即可。
附:
我简单的用requere实现了下 ,支持中英韩语,默认其他均英语
首先将一入几个自己写好的语言包:key为中文;value为相应国际化的语言,每次动态加载value 就阔以了
eg:我称为语言包
define(function(){
   var object = {
"年":"year",
"月":"month",
"周":"week",
"日":"day",
"时":"hour",
"分":"minute",
"秒":"seconds",
}
return object
}
加载逻辑:
define(function(){
  //<-- ####### internationalization  ########## -->
  var languageObj=null
  switch (navigator.language) {
    case "zh-CN":
    languageObj={}
    break;
    case "en-US":
    loadModule('english')
    break;
    case "ko-KR":
    loadModule('korean')
    break;
    default:
    loadModule('english')
    break;
  }
  function loadModule(jsModule,black){
    require([jsModule], function(obj){
       languageObj = obj
       typeof block =="function"&&block(obj)
    })
  }
  var internationalization = {
    tell:function (key) {
        return languageObj[key]||key
    }
  }
  window.$i18n=internationalization.tell
  return internationalization
})
由于部分机型的适配问题
更改为提前加载英语语言包
define(["english"], function(englishObj) {
    //<-- ####### internationalization  ########## -->
    var internationalization = {
        tell: function(key) {
            switch (navigator.language) {
                case "zh-CN":
                    return key
                    break;
                case "en-US":
                   return englishObj[key]||key
                    break;
                case "ko-KR":
                return englishObj[key]||key
                    break;
                default:
                return englishObj[key]||key
                    break;
            }
        }
    }
    window.$i18n = internationalization.tell
    return internationalization
})
启动加载后在需要国际化处理的地方通通用$i18n("中文")即可
简单可行。
JS国际化网站中英文切换(理论支持所有语言)应用于h5版APP的更多相关文章
- [UE4]国际化,中英文切换
		只有“Text”数据类型才支持国际化 必须以独立游戏窗口运行,语音切换才会起作用. 
- ThinkPHP3.2中英文切换!
		小伙伴们好久不见!!! 最近公司项目版本升级,小梦已经忙成了狗,无暇顾及文章,今天抽时间写一篇助助兴! 用Thinkphp这个国产框架已经2年多了,现在有一个小功能:网站中英文切换功能,当然这 ... 
- SpringMVC 国际化-中英文切换
		项目结构 1.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http: ... 
- 【vue】中英文切换(使用 vue-i18n )
		一.准备工作 1.vue-i18n 1.仓库地址 2.兼容性:支持 Vue.js 2.x 以上版本 1-1.安装依赖vue-i18n (c)npm install vue-i18n 1-2.使用 在 ... 
- 纯js国际化(i18n)
		i18n,是internationalization单词的简写,中间18个字符略去,简称i18n,意图就是实现国际化,方便产品在不同的场景下使用 目标:可以点击切换语言或者ChangeLanguage ... 
- 正则表达式split匹配多种例如 “】”,“,”两种(页面级中英文切换方案)
		在做登陆界面的时候,因为涉及到中英文 因为前后台已经分离,所以前端需要自行设计中英文 做法: 编写两个文件,一个中文文件,一个是英文文件,分别放在对应的目录下面 文件的内容 { "login ... 
- AudioPlayer.js,一个响应式且支持触摸操作的jquery音频插件
		AudioPlayer.js是一个响应式.支持触摸操作的HTML5 的音乐播放器.本文是对其官网的说用说明文档得翻译,博主第一次翻译外文.不到之处还请谅解.之处. JS文件地址:http://osva ... 
- php或js判断网站访问者来自手机或者pc
		php或js判断网站访问者来自手机或者pc机 2013年9月26日,在弄wtuonline的时候为了区分用户是来自手机版浏览器还是pc,针对不同平台选择不同的网站版本,最终总结如下: ... 
- php或js判断网站访问者来自手机或者pc机
		php或js判断网站访问者来自手机或者pc机 2013年9月26日,在弄wtuonline的时候为了区分用户是来自手机版浏览器还是pc,针对不同平台选择不同的网站版本,最终总结如下: ... 
随机推荐
- vs2017下载安装
			https://docs.microsoft.com/en-us/visualstudio/releasenotes/vs2017-relnotes 
- Sql中substr的使用
			pandas和SQL数据分析实战 https://study.163.com/course/courseMain.htm?courseId=1006383008&share=2&sha ... 
- Mysql创建数据库以及用户分配权限
			一.创建mysql数据库 1.创建数据库语法 --创建名称为“testdb”数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb DEFAULT C ... 
- JDBC连接抽象方法的使用例子
			package com.zdlt.auth.api.base.datasource; import java.sql.*; import java.util.ArrayList; import jav ... 
- (转)How To Create a Sudo User on Ubuntu
			转自:https://linuxize.com/post/how-to-create-a-sudo-user-on-ubuntu/ The sudo command is designed to al ... 
- https://www.jianshu.com/p/1038c6170775
			import os # 方法一: os.walk实现 def items_dir(rootname): l = [] for main_dir, dirs, file_name_list in os. ... 
- phpstorm2019.1 实现保存(ctrl+s)同时格式化代码
			1.选择Edit(编辑)->Macros(宏)->Start Macro Recording(开始录制宏),如下图: 2.直接按想要录制的快捷键,先按Ctrl+ALT+L,然后键盘按Ctr ... 
- .net for TCP服务端 && 客户端
			关键代码 详细代码请看示例代码 Service //创建套接字 IPEndPoint ipe = new IPEndPoint(IPAddress.Parse(ipaddress), port); / ... 
- 【Spring Boot学习之六】Spring Boot整合定时任务&异步调用
			环境 eclipse 4.7 jdk 1.8 Spring Boot 1.5.2一.定时任务1.启动类添加注解@EnableScheduling 用于开启定时任务 package com.wjy; i ... 
- [数据结构 - 第3章] 线性表之顺序表(C++实现)
			一.类定义 顺序表类的定义如下: #ifndef SEQLIST_H #define SEQLIST_H typedef int ElemType; /* "ElemType类型根据实际情况 ... 
