jquery亂碼與contentType屬性設置問題解決方案
更新時間:2013年01月07日 11:31:55 作者:
讓人頭痛的Jquery亂碼問題。其實這方面文章已經(jīng)很多了,但全面解決各種問題的很少,今天總結一下,方便自己也方便大家,感興趣的朋友可以了解下哦
今天閑的無聊,把以前遺留的問題解決一下,比如讓人頭痛的Jquery亂碼問題。其實這方面文章已經(jīng)很多了,但全面解決各種問題的很少,今天總結一下,方便自己也方便大家。
原因很簡單: 其實他的中文亂碼就是因為contentType沒有指定編碼,對于不同Jquery的版本中這個地方有不同的設置,就拿我遇到的,jquery-1.6.1和jquery-1.8.3就有不同的定義。
解決辦法:在jquery-1.6.1文件中,搜索'contentType' 然后在application/x-www-form-urlencoded后面加上; charset=UTF-8 最終變成contentType:"application/x-www-form-urlencoded; charset=UTF-8"即可。
這樣通過post方法提交后會出現(xiàn)亂碼的問題就可以完美解決。
如果還有亂碼現(xiàn)象,只能說你接收頁面的編碼也有問題, 這是由于異步對象XMLHttpRequest在處理返回的responseText的時候,是按UTF-8編碼進行解碼的。所以post方式的話,必須把這個頁面另存一下,將頁面文件的編碼改為 UTF-8 (請務必記住)。
沒修改前,整個FROM表單數(shù)據(jù)全部為亂碼狀態(tài),對于這種情況,大家按以上方法可以輕松解決。
以下是一些特別情況的問題總結,來源于網(wǎng)絡:
JQuery Ajax提交出現(xiàn)中文亂碼的解決辦法2
前使用Jquery的時候一直沒有發(fā)現(xiàn),用Ajax提交的時候會出現(xiàn)亂碼,我猜測可能是因為編碼的原因
可能存在以下幾點原因:
1.HTML的編碼不統(tǒng)一:如頁面用的GB2312,好像JQuery對它支持不太好。以前我一直都是用UTF-8的,一直都沒有發(fā)現(xiàn);
2.文件的編碼,這個不好在表面上看到,簡體中文版的操作系統(tǒng)存的文本格式的文件默認是 GB2312,建議把文件換成UTF-8格式的
最簡單的解決辦法,把提交的中文文本用 JS的 escape 處理一下,就不會現(xiàn)出現(xiàn)亂碼了。
如:
//保存數(shù)據(jù)
$.ajax({
url:"/guide/savecomments.aspx" ,
type:"POST" ,
dataType:"json" ,
data:"Action=SaveComment&CommNickName=" +escape(CommNickName.val()) + "&CommContent=" +escape(CommContent.val()) + "&GuideID=" + GuideID.val() + "&ScoreLogType=<%=ScoreLogType %>",
success:function(results){
alert(results.message);
-------------------------------------------------------------------------------
解決的辦法上用js的編碼函數(shù)encodeURIComponent(string)處理一下,把中文"王曉明"編碼成"%E7%8E%8B%E6%99%93%E6%98%8E",就OK了。
順便說一下,我的tomcat下的URIEncoding=UTF-8
-------------------------------------------------------------------------------
今天在使用jquery檢測用戶名的時候,對英文和數(shù)字的用戶名檢測正確,但是對中文的時候,檢測出錯,經(jīng)過在網(wǎng)上查詢一段時間,終于找到了原因,是亂碼問題,解決方法:
1、只要在ajax中有數(shù)據(jù)提交時,如果頁面編碼不是utf-8的,都應該對提交的數(shù)據(jù)進行編碼,js的編碼函數(shù)為escape()
2、在服務器端頁接收數(shù)據(jù)后進行解碼,然后對數(shù)據(jù)進行相關的處理后再編碼
3、返回到客戶端后再解碼
4、如果沒有提交數(shù)據(jù),而是直接從服務器端獲取數(shù)據(jù),那直接在服務器頁面設置Response.Charset="gb2312"即可,不用再編碼解碼
vbscript中分別對應js中的escape()和unescape()函數(shù) 程序代碼
-------------------------------------------------------------------------------
通過以下處理方式得到解決:
傳遞參數(shù)的時候 對參數(shù)進行編碼priceName="encodeURI(priceName)",也可以用encodeURIComponent();
服務器端無需做其他處理: String priceName = request.getParameter("priceName");
原因很簡單: 其實他的中文亂碼就是因為contentType沒有指定編碼,對于不同Jquery的版本中這個地方有不同的設置,就拿我遇到的,jquery-1.6.1和jquery-1.8.3就有不同的定義。
解決辦法:在jquery-1.6.1文件中,搜索'contentType' 然后在application/x-www-form-urlencoded后面加上; charset=UTF-8 最終變成contentType:"application/x-www-form-urlencoded; charset=UTF-8"即可。
這樣通過post方法提交后會出現(xiàn)亂碼的問題就可以完美解決。
如果還有亂碼現(xiàn)象,只能說你接收頁面的編碼也有問題, 這是由于異步對象XMLHttpRequest在處理返回的responseText的時候,是按UTF-8編碼進行解碼的。所以post方式的話,必須把這個頁面另存一下,將頁面文件的編碼改為 UTF-8 (請務必記住)。
沒修改前,整個FROM表單數(shù)據(jù)全部為亂碼狀態(tài),對于這種情況,大家按以上方法可以輕松解決。
以下是一些特別情況的問題總結,來源于網(wǎng)絡:
JQuery Ajax提交出現(xiàn)中文亂碼的解決辦法2
前使用Jquery的時候一直沒有發(fā)現(xiàn),用Ajax提交的時候會出現(xiàn)亂碼,我猜測可能是因為編碼的原因
可能存在以下幾點原因:
1.HTML的編碼不統(tǒng)一:如頁面用的GB2312,好像JQuery對它支持不太好。以前我一直都是用UTF-8的,一直都沒有發(fā)現(xiàn);
2.文件的編碼,這個不好在表面上看到,簡體中文版的操作系統(tǒng)存的文本格式的文件默認是 GB2312,建議把文件換成UTF-8格式的
最簡單的解決辦法,把提交的中文文本用 JS的 escape 處理一下,就不會現(xiàn)出現(xiàn)亂碼了。
如:
復制代碼 代碼如下:
//保存數(shù)據(jù)
$.ajax({
url:"/guide/savecomments.aspx" ,
type:"POST" ,
dataType:"json" ,
data:"Action=SaveComment&CommNickName=" +escape(CommNickName.val()) + "&CommContent=" +escape(CommContent.val()) + "&GuideID=" + GuideID.val() + "&ScoreLogType=<%=ScoreLogType %>",
success:function(results){
alert(results.message);
-------------------------------------------------------------------------------
解決的辦法上用js的編碼函數(shù)encodeURIComponent(string)處理一下,把中文"王曉明"編碼成"%E7%8E%8B%E6%99%93%E6%98%8E",就OK了。
順便說一下,我的tomcat下的URIEncoding=UTF-8
-------------------------------------------------------------------------------
今天在使用jquery檢測用戶名的時候,對英文和數(shù)字的用戶名檢測正確,但是對中文的時候,檢測出錯,經(jīng)過在網(wǎng)上查詢一段時間,終于找到了原因,是亂碼問題,解決方法:
1、只要在ajax中有數(shù)據(jù)提交時,如果頁面編碼不是utf-8的,都應該對提交的數(shù)據(jù)進行編碼,js的編碼函數(shù)為escape()
2、在服務器端頁接收數(shù)據(jù)后進行解碼,然后對數(shù)據(jù)進行相關的處理后再編碼
3、返回到客戶端后再解碼
4、如果沒有提交數(shù)據(jù),而是直接從服務器端獲取數(shù)據(jù),那直接在服務器頁面設置Response.Charset="gb2312"即可,不用再編碼解碼
vbscript中分別對應js中的escape()和unescape()函數(shù) 程序代碼
-------------------------------------------------------------------------------
通過以下處理方式得到解決:
傳遞參數(shù)的時候 對參數(shù)進行編碼priceName="encodeURI(priceName)",也可以用encodeURIComponent();
服務器端無需做其他處理: String priceName = request.getParameter("priceName");
您可能感興趣的文章:
- asp.net下Response.ContentType類型匯總
- 用asp實現(xiàn)網(wǎng)頁調用doc附Response.ContentType 詳細列表
- html 的 ContentType 小結
- 讓手機訪問WAP網(wǎng)站服務器 IIS WAP服務器的MIME類型設置
- asp.net 下載文件時根據(jù)MIME類型自動判斷保存文件的擴展名
- WIN2003中使用IIS配置手機下載類WAP網(wǎng)站的MIME類型介紹
- Mime類型與文件后綴對照表
- response.setContentType()的作用及MIME參數(shù)詳解
- 下載站mime屬性設置(讓文件可下載)
- IIS自定義MIME類型的步驟
- 自己動手打造ajax圖片上傳(網(wǎng)上沒有的)
- 基于C# winform實現(xiàn)圖片上傳功能的方法
- jquery+php+ajax顯示上傳進度的多圖片上傳并生成縮略圖代碼
- php多個文件及圖片上傳實例詳解
- yii實現(xiàn)圖片上傳及縮略圖生成的方法
- jQuery插件jcrop+Fileapi完美實現(xiàn)圖片上傳+裁剪+預覽的代碼分享
- http圖片上傳安全性問題 根據(jù)ContentType (MIME) 判斷其實不準確、不安全
相關文章
jQuery中each和js中forEach的區(qū)別分析
這篇文章主要介紹了jQuery中each和js中forEach的區(qū)別,結合實例形式較為詳細的分析了jQuery中each和js中forEach針對數(shù)組與對象遍歷的相關操作技巧與注意事項,需要的朋友可以參考下2019-02-02
jquery3和layui沖突導致使用layui.layer.full彈出全屏iframe窗口時高度152px問題
這篇文章主要介紹了解決jquery3和layui沖突導致使用layui.layer.full彈出全屏iframe窗口時高度152px問題,需要的朋友可以參考下2019-05-05

