一般情況下,URL 中的參數(shù)應(yīng)使用 url 編碼規(guī)則,即把參數(shù)字符串中除了 -_. 之外的所有非字母數(shù)字字符都將被替換成百分號(%)后跟兩位十六進制數(shù),空格則編碼為加號(+)衔峰。但是對于帶有中文的參數(shù)來說,這種編碼會使編碼后的字符串變得很長蛙粘。如果希望有短一點的方式對參數(shù)編碼垫卤,可以采用 base64 編碼方式對字符串進行編碼,但是 base64 編碼方式不能處理 JavaScript 中的中文出牧,因為 JavaScript 中的中文都是以 UTF-16 方式保存的穴肘。而 base64 只能處理單字節(jié)字符,所以不能直接用 base64 對帶有中文的 JavaScript 字符串進行編碼舔痕。但是可以通過 utf.js 這個程序中提供的 utf16to8 來將 UTF-16 編碼的中文先轉(zhuǎn)化為 UTF-8 方式评抚,然后再進行 base64 編碼。這樣編碼后的字符串伯复,在傳遞到服務(wù)器端后可以直接通過 base64_decode 解碼成 UTF-8 的中文字符串盈咳。但是還有個問題需要注意。base64 編碼中使用了加號(+)边翼,而 + 在 URL 傳遞時會被當成空格鱼响,因此必須要將 base64 編碼后的字符串中的加號替換成 %2B 才能當作 URL 參數(shù)進行傳遞。否則在服務(wù)器端解碼后就會出錯组底。
所以我們需要做的就是encodeURI(str).replace(/+/g,'%2B')
將帶加號的參數(shù)轉(zhuǎn)碼丈积,而不是整個url轉(zhuǎn)碼