解決JSON.stringify()自動(dòng)將中文轉(zhuǎn)譯成unicode的問題
最近在工作中,發(fā)現(xiàn)在IE8下JSON.stringify()自動(dòng)將中文轉(zhuǎn)譯為unicode編碼,原本選擇的中文字符,傳到后臺(tái)變?yōu)榱藆nicode編碼,即\u****的形式。查找資料后發(fā)現(xiàn),與標(biāo)準(zhǔn)的JSON.stringify()不同,IE8內(nèi)置的JSON.stringify()會(huì)自動(dòng)將編碼從utf-8轉(zhuǎn)為unicode編碼,導(dǎo)致出現(xiàn)這種類似于亂碼的情況。
解決方法分為兩種,第一種是后臺(tái)接收到數(shù)據(jù)之后,將該數(shù)據(jù)再進(jìn)行一次轉(zhuǎn)碼,重新轉(zhuǎn)為utf-8,然后再保存到數(shù)據(jù)庫中,這樣,再次從數(shù)據(jù)庫取出傳給前端的數(shù)據(jù)將變成utf-8格式(即正常的中文)。第二種則是不管在IE8下還是高級瀏覽器中,使用eval()統(tǒng)一進(jìn)行轉(zhuǎn)碼,最后的結(jié)果都為utf-8編碼。
本文主要講解第二種方法,即使用eval()轉(zhuǎn)碼的方法。在MDN上,eval()的解釋是:eval()的參數(shù)是一個(gè)字符串。如果字符串表示的是表達(dá)式,eval()會(huì)對表達(dá)式進(jìn)行求值。如果參數(shù)表示一個(gè)或多個(gè)JavaScript語句, 那么eval()就會(huì)執(zhí)行這些語句。
var a = "吃翔翔"; var unicodeJsonA = JSON.stringify("a"); //unicode var jsonA = eval('(' + unicodeJsonA + ')'); //utf-8
如上代碼,通過eval()執(zhí)行,強(qiáng)行將unicode轉(zhuǎn)碼為utf-8,無論JSON.stringify()后出來的結(jié)果是utf-8還是unicode,統(tǒng)一轉(zhuǎn)為utf-8格式。
其實(shí),解決的方法還有第三種——使用json2.js中的JSON.stringify()代替IE8的JSON.stingify()。但是,當(dāng)有瀏覽器自帶的JSON對象時(shí),會(huì)啟用瀏覽器自帶的JSON對象代替json2.js中的JSON對象。為了解決這個(gè)問題,可以將json2.js中的JSON對象改為JSON2對象,即將JSON.stringify()改為JSON2.stringify()。
以上幾種方法皆可解決IE8下自動(dòng)將中文轉(zhuǎn)譯為unicode的問題。
以上這篇解決JSON.stringify()自動(dòng)將中文轉(zhuǎn)譯成unicode的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- JSON.stringify 語法實(shí)例講解
- js解析與序列化json數(shù)據(jù)(一)json.stringify()的基本用法
- JSON.parse()和JSON.stringify()使用介紹
- 關(guān)于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
- JSON.stringify轉(zhuǎn)換JSON時(shí)日期時(shí)間不準(zhǔn)確的解決方法
- 打印json對象的內(nèi)容及JSON.stringify函數(shù)應(yīng)用
- 談?wù)凧SON對象和字符串之間的相互轉(zhuǎn)換JSON.stringify(obj)和JSON.parse(string)
- jQuery解決IE6、7、8不能使用 JSON.stringify 函數(shù)的問題
- 深入淺析JSON.parse()、JSON.stringify()和eval()的作用詳解
- JSON.stringify的多種用法總結(jié)
相關(guān)文章
javascript基于定時(shí)器實(shí)現(xiàn)進(jìn)度條功能實(shí)例
這篇文章主要介紹了javascript基于定時(shí)器實(shí)現(xiàn)進(jìn)度條功能,簡單分析了javascript定時(shí)器的功能、使用方法并給出了基于定時(shí)器實(shí)現(xiàn)的進(jìn)度條功能實(shí)例,需要的朋友可以參考下2017-10-10javascript 動(dòng)態(tài)生成css代碼的兩種方法
這篇文章主要介紹了javascript 動(dòng)態(tài)生成css代碼的兩種方法,有時(shí)候我們需要利用js來動(dòng)態(tài)生成頁面上style標(biāo)簽中的css代碼,下面就給大家介紹兩種方法,需要的朋友可以參考下2017-03-03關(guān)于window.pageYOffset和document.documentElement.scrollTop
window.pageYOffset:Netscape屬性,指的是滾動(dòng)條頂部到網(wǎng)頁頂部的距離2011-04-04JS簡單實(shí)現(xiàn)禁止訪問某個(gè)頁面的方法
這篇文章主要介紹了JS簡單實(shí)現(xiàn)禁止訪問某個(gè)頁面的方法,涉及基本的頁面跳轉(zhuǎn)操作技巧,需要的朋友可以參考下2016-09-09