我最近开始为我的网站实施语言选项。以下是它的基本工作原理:
if(isset($_GET['lang']))
{
$langr= $_GET['lang'];
$_SESSION['lang'] = $langr;
setcookie('lang', $langr, time() + (3600 * 24 * 30));
}
elseif(isset($_SESSION['lang']))
{
$langr = $_SESSION['lang'];
}
elseif(isset($_COOKIE['lang']))
{
$langr = $_COOKIE['lang'];
}
else
{
$langr = 'en';
}
switch ($langr)
{
case 'en':
$lang_file = $_SERVER['DOCUMENT_ROOT']."/includes/lang/en.php";
break;
case 'fr':
setlocale (LC_ALL, 'fr_FR.utf8','fra');
$lang_file = $_SERVER['DOCUMENT_ROOT']."/includes/lang/fr.php";
break;
default:
$lang_file = $_SERVER['DOCUMENT_ROOT']."/includes/lang/en.php";
}
include_once $lang_file;
它会在我网站的每个页面顶部加载相应的语言文件。但是,使用jQuery的UI datepicker时会出现问题。我在网上找到了datepicker的区域设置文件,并为它创建了一个单独的文件:
///jquery.ui.datepicker-fr.js file
jQuery(function($){
$.datepicker.regional['fr'] = {
closeText: 'Fermer',
prevText: 'Précédent',
nextText: 'Suivant',
currentText: 'Aujourd\'hui',
monthNames: ['janvier', 'février', 'mars', 'avril', 'mai', 'juin',
'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'],
monthNamesShort: ['janv.', 'févr.', 'mars', 'avril', 'mai', 'juin',
'juil.', 'août', 'sept.', 'oct.', 'nov.', 'déc.'],
dayNames: ['dimanche', 'lundi', 'mardi', 'mercredi', 'jeudi', 'vendredi', 'samedi'],
dayNamesShort: ['dim.', 'lun.', 'mar.', 'mer.', 'jeu.', 'ven.', 'sam.'],
dayNamesMin: ['D','L','M','M','J','V','S'],
weekHeader: 'Sem.',
dateFormat: 'dd/mm/yy',
firstDay: 1,
isRTL: false,
showMonthAfterYear: false,
yearSuffix: ''};
$.datepicker.setDefaults($.datepicker.regional['fr']);
});
问题是我需要在检测到语言更改时动态加载jquery.ui.datepicker-fr.js
,以便我的datepicker切换为法语。我在想的是创建一个PHP函数,我将放在我的<head>
中,它会回显我的文件,但问题是我的所有网页都不是PHP而且我觉得这不是很好有效的方法。关于如何做到这一点的任何其他想法?
答案 0 :(得分:1)
你需要检查一下header.php,它会是这样的:
<script type="text/javascript>" src="/js/<?php if($_SESSION['lang'] == "en"){ echo 'datepicker-en.js'}else echo 'datepicker-fr.js'; ?>"></script>
因此它会根据您的语言参数自动检测 datepicker 文件。
答案 1 :(得分:1)
我会这样做,有一个单独的PHP文件负责获取正确的JS文件, 这样你就可以在计划HTML页面中使用它......
<script type="text/javascript" src="/getCorrectJsFile.php"></script>
答案 2 :(得分:0)
您如何看待这种方法?
function getBaseURL()
{
var url = location.href;
var baseURL = url.substring(0, url.indexOf('/', 14));
if (baseURL.indexOf('http://localhost') != -1)
{
var url = location.href;
var pathname = location.pathname;
var index1 = url.indexOf(pathname);
var index2 = url.indexOf("/", index1 + 1);
var baseLocalUrl = url.substr(0, index2);
return baseLocalUrl + "/";
}
else
{
return baseURL + "/";
}
}
function getCookie(c_name)
{
var i,x,y,ARRcookies=document.cookie.split(";");
for (i=0;i<ARRcookies.length;i++)
{
x=ARRcookies[i].substr(0,ARRcookies[i].indexOf("="));
y=ARRcookies[i].substr(ARRcookies[i].indexOf("=")+1);
x=x.replace(/^\s+|\s+$/g,"");
if (x==c_name)
{
return unescape(y);
}
}
}
function getLang()
{
var lang = getCookie("lang");
switch(lang)
{
case "fr":
document.write("<script src='"+getBaseURL()+"js/lang/jquery.ui.datepicker-"+lang+".js'></script>");
break;
default:
document.write("");
}
}
getLang();
这些函数将位于一个公共的js文件中,我会在我的所有页面上调用getLang()
函数...
答案 3 :(得分:0)
如何使用.change()和.post()?您可以在表单中添加lang的id,用户可以在其中更改语言。
$('#lang').change(function(){
//link to your php file
var findlangfile = "<?php echo index.php/findlang.php;?>
$.post(findlangfile, {
lang: $('#lang').val(),
}, function(response){
// you do things
});
return false;
});
答案 4 :(得分:0)
您可以使用jQuery cookie插件,这是一个很好的插件。然后使用jQuery和php一样执行相同的过程。如果语言提供为url参数 - 使用插件设置cookie(使用上面的getBaseURL()函数获取语言值)。否则加载cookie然后加载适当的javascript文件。像$('head').append('<script..');
之类的东西应该完成任务。
确保使用$(function() { /* code here */ });
虽然可以通过这种方式完成任务,但我强烈建议您将所有页面都切换到php,因为它会简化这样的事情。
答案 5 :(得分:0)
改进了Moeed的答案:
<script src="/js/<?php echo 'datepicker-' . *COOKIE/SESSION VALUE, LIKE en* . '.js'; ?>"></script>
这将动态选择datepicker-???.js
,其中???
是Cookie / session-cookie所代表的值。