本文實例講述了Thinkphp搭建包括JS多語言的多語言項目實現方法。分享給大家供大家參考。具體實現方法如下:
一、問題:
項目需要開發英文版,於是需要搭建多語言項目.
項目使用Thinkphp框架,隱約記得Thinkphp有多語言設置,翻看了幫助手冊,果然有,這就邊實驗邊開始:
二、實現方法:
Thinkphp采用app_begain來檢測和切換語言包,語言包和項目相關,構架等都比較簡單,具體的這裡:http://www.thinkphp.cn/info/188.html
搭建好了,就可以使用URL."?l=en-us"來動態切換和調試,很不錯的.
這邊發現js內的多語言不好處理,總不能全部assign過去,反正多語言也不會總是配置,干脆自動生成對應的多語言js文件,然後頁面根據LANG_SET來動態請求對應的多語言文件,在基礎Action類的_initialize()方法內調用下面的生成函數:
復制代碼 代碼如下:public function _generateJsLanguageFile(){
if(C("LANG_SWITCH_ON")){
$jsLangFilePath = "./Public/v2/js/lang";
$langList = L();
$jsLangFileName = $jsLangFilePath."/".LANG_SET.".js";
//@unlink($jsLangFileName);//測試,不永久緩存語言包
//已存在語言包
if(is_file($jsLangFileName)){
return;
}
$str = "var \$LANG={";
$total = count($langList);
$k = 1;
foreach ($langList as $key => $value) {
$str .=$key.":'".$value."'";
if($k < $total){
$str .=",";
}
// $str .="\r\n";
$k++;
}
if(!emptyempty($str)){
$str .= "}";
$file_handel = fopen($jsLangFileName, "w+");//打開文件,重寫模式
fwrite($file_handel, $str);
fclose($file_handel);
}
}
}
這樣,每次訪問前都會生成當前的語言包,然後在Tpl內調用.
這樣,每次都會自動載入,這個js是永久緩存的,如果有語言包的更改,只需要修改Thinkphp的語言包,然後刪除舊的js語言包,讓他自動重新生成.
js內就可以這麼使用:top10_title = $LANG._NEW_LANGUAGE;這樣整個項目就等於是雙語的,並且是一處配置即可.
希望本文所述對大家的ThinkPHP框架程序設計有所幫助。