前端开发中多语言的切换,可使用js动态替换内容
1、在用户点击切换语言后,把选择的语言版本保存在cookie中
function setCookie(name,value)
{var Days = 30;var exp = new Date();exp.setTime(exp.getTime() + Days*24*60*60*1000);document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}
function getCookie(name)
{var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");if(arr=document.cookie.match(reg))return unescape(arr[2]);elsereturn null;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
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",};
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
4、遍历带set-lan属性的标签,进行文本替换
$('[set-lan]').each(function(){var me = $(this);var a = me.attr('set-lan').split(':');var p = a[0]; var m = a[1]; var lan = getCookie('lan');switch(lan){case 'cn':var t = cn[m]; break;case 'en':var t = en[m];break;default:var t = hk[m];}if(t==undefined) t = cn[m];if(t==undefined) t = en[m];if(t==undefined) t = hk[m];if(t==undefined) return true; switch(p){case 'html':me.html(t);break;case 'val':case 'value':me.val(t);break;default:me.html(t);}});
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
以上是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];}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;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
那么在js中使用的文字就只要用此函数来读取就可以了
如
alert('姓名');
改成
alert(get_lan('name'));