实现的效果

需要在web中实现多语言的切换,当用户语言切换完成后下次重新打开网页,也是上次设置的语言进行显示。

资源网站搜索大全https://55wd.com

实现步骤

1、在用户点击切换语言后,把选择的语言版本保存在cookie中

//写入cookie函数
function setCookie(name,value)
{
var Days = ;
var exp = new Date();
exp.setTime(exp.getTime() + Days****);
document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
} //获取cookie
function getCookie(name)
{
var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
if(arr=document.cookie.match(reg))
return unescape(arr[]);
else
return null;
} //setCookie('lan','hk'); 繁体中文
//setCookie('lan','cn'); 简体中文
//setCookie('lan','en'); 英文

2、在包含静态文本的标签中,添加一个属性:set-lan=”html:name” ,属性值中的html代表内容的位置,name代表要替换的文字的标识 。例如:

<span set-lan="html:name">名字</span>
<input type="text" value="名字" set-lan="val:name" /> 这些就需要前端工程师在开发过程中添加进去,并且,要切换语言文字的外面都必须要有一个标签包裹,否则无法进行切换;
如:
<span set-lan="html:name"><i class="icon"></i>名字</span>
这样的代码,是无法把“名字”替换成“Name”的,会把“名字”前面的i标签也一起替换掉,如果不想把i标签也替换掉,就要在“名字”外面添加一个标签,改成:
<span><i class="icon"></i><lan set-lan="html:name">名字</lan></span>

3、定义3个语言的标识+内容的json字符串

var cn = {
"name" : "姓名",
"tel" : "电话",
"email" : "邮箱",
}; var hk = {
"name" : "姓名",
"tel" : "電話",
"email" : "郵箱",
}; var en = {
"name" : "Name",
"tel" : "Tel",
"email" : "Email",
};

4、遍历带set-lan属性的标签,进行文本替换

$('[set-lan]').each(function(){
var me = $(this);
var a = me.attr('set-lan').split(':');
var p = a[]; //文字放置位置
var m = a[]; //文字的标识 //用户选择语言后保存在cookie中,这里读取cookie中的语言版本
var lan = getCookie('lan'); //选取语言文字
switch(lan){
case 'cn':
var t = cn[m]; //这里cn[m]中的cn是上面定义的json字符串的变量名,m是json中的键,用此方式读取到json中的值
break;
case 'en':
var t = en[m];
break;
default:
var t = hk[m];
} //如果所选语言的json中没有此内容就选取其他语言显示
if(t==undefined) t = cn[m];
if(t==undefined) t = en[m];
if(t==undefined) t = hk[m]; if(t==undefined) return true; //如果还是没有就跳出 //文字放置位置有(html,val等,可以自己添加)
switch(p){
case 'html':
me.html(t);
break;
case 'val':
case 'value':
me.val(t);
break;
default:
me.html(t);
} });

5、以上是html中的文字替换,但是写在js中的文字怎么办? 可以定义一个函数,来读取

function get_lan(m)
{
//获取文字
var lan = getCookie('lan'); //语言版本
//选取语言文字
switch(lan){
case 'cn':
var t = cn[m];
break;
case 'hk':
var t = hk[m];
break;
default:
var t = en[m];
} //如果所选语言的json中没有此内容就选取其他语言显示
if(t==undefined) t = cn[m];
if(t==undefined) t = en[m];
if(t==undefined) t = hk[m]; if(t==undefined) t = m; //如果还是没有就返回他的标识 return t;
}

那么在js中使用的文字就只要用此函数来读取就可以了 ,如

alert('姓名');
//改成
alert(get_lan('name'));

  

最新文章

  1. 【故障处理】一次RAC故障处理过程
  2. oracle中复制表和数据 &amp;&amp; 多表插入语句
  3. 循序渐进Python3(三) -- 3 -- 内置函数
  4. 在Spring中使用JDK定时器实现调度任务
  5. 学渣也要搞 laravel(4)—— 服务 加解密篇
  6. python的py文件打包成exe
  7. UVa 474 - Heads / Tails Probability
  8. 初识DJango——MTV模型
  9. Java线程-异常处理
  10. idea添加JPA导出实体类
  11. Stack堆栈的数据结构
  12. 017_mac格式化硬盘,mac如何格式化硬盘
  13. mybatis学习笔记--常见的错误
  14. .NET Core 用 VS Code新建各种类型的项目
  15. vue 移动端的一些ui
  16. PAT 1051 复数乘法(15 )(代码+思路)
  17. C#读取excel文件提示未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序
  18. pip2和pip3冲突问题解决方法
  19. 009 jquery过滤选择器-----------(表单对象属性过滤选择器 与 表单选择器)
  20. 第2章 2.n物理层--数据通信基础知识总结

热门文章

  1. Java实现第八届蓝桥杯最大公共子串
  2. python XlsxWriter模块创建aexcel表格
  3. 07.Django-缓存
  4. UniRx精讲(一):UniRx简介&amp;定时功能实现
  5. 5、vue的传值
  6. 学而思Java开发岗位面试
  7. 【译】Introducing YARP Preview 1
  8. 【从单体架构到分布式架构】(三)请求增多,单点变集群(2):Nginx
  9. mermaid使用简介(画论文插图的一种解决方案)
  10. 【Java】错误: 需要class, interface或enum