在進(jìn)行JS開發(fā)過程中,尤其是在開發(fā)報表時,報表已集成到Web頁面中,通過在頁面?zhèn)鬟f參數(shù)至報表中時,會發(fā)現(xiàn)有時某些參數(shù)值,傳遞到報表中是顯示為問號或亂碼等等一系列不能正常顯示的情況。
創(chuàng)新互聯(lián)建站自2013年起,先為豐臺等服務(wù)建站,豐臺等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為豐臺企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
這是由于瀏覽器和報表服務(wù)器的編碼不同,字符多次進(jìn)行編碼轉(zhuǎn)換時出現(xiàn)錯誤導(dǎo)致字符的顯示出現(xiàn)亂碼,尤其是中日韓文和特殊字符更容易出現(xiàn)亂碼問題。
以開發(fā)報表軟件FineReport為例,在給報表服務(wù)器發(fā)送請求之前,對URL或者只對URL里面的參數(shù)名字和參數(shù)值,進(jìn)行cjkEncode的編碼,該方式兼容了各種不同的字符集,如ISO8859-1、 UTF-8、 GBK、 ENU_JP,尤其對中日韓文的處理采取了統(tǒng)一的方案。
javascript中FineReport字符轉(zhuǎn)換原理
在給報表服務(wù)器發(fā)送請求之前,對URL或者只對URL里面的參數(shù)名字和參數(shù)值,進(jìn)行cjkEncode的編碼。源碼如下:
function cjkEncode(text) { if (text == null) { return ""; } var newText = ""; for (var i = 0; i < text.length; i++) { var code = text.charCodeAt (i); if (code >= 128 || code == 91 || code == 93) {//91 is "[", 93 is "]". newText += "[" + code.toString(16) + "]"; } else { newText += text.charAt(i); } } return newText; }
經(jīng)過編碼的URL或者Form表單,報表服務(wù)器智能的將這些字符正確的轉(zhuǎn)換過來。
cjkEncode方法在FineReport的JS庫中已經(jīng)預(yù)先提供了,用戶只要加載了FR的JS庫,就可以使用FR.cjkEncode對中日韓文字符進(jìn)行encode,如下示例:
1、 對URL進(jìn)行cjkEncode
如果只對參數(shù)值進(jìn)行編輯轉(zhuǎn)換,在參數(shù)后面調(diào)用FR.cjkEncode()方法,如:
window.location="http://localhost:8075/WebReport/ReportServer?reportlet=reportname.cptname="+FR.cjkEncode("華東");
2、對Form表單進(jìn)行cjkEncode