IE瀏覽器與FF瀏覽器關於Ajax傳遞參數值為中文時的區別執行個體分析_AJAX相關

來源:互聯網
上載者:User

本文執行個體講述了IE瀏覽器與FF瀏覽器關於Ajax傳遞參數值為中文時的區別。分享給大家供大家參考,具體如下:

前面介紹了《Javascript基於AJAX回呼函數傳遞參數》,這裡主要來分析一下ajax傳遞中文參數過程中針對不同瀏覽器的亂碼處理方法。

Ajax傳遞參數為中文時出現亂碼,我遇到的情況是:

1.我的資料庫連接 編碼為 GB2312,latin1_swedish_ci

2.php 檔案編碼格式為 UTF-8,瀏覽器顯示編碼為 : UTF-8

3.我的頁面顯示方式為兩種:

一)頁面載入時自動載入,每隔一秒重新整理一次

二)點擊一個分機組名稱時,獲得該分機組的相應的成員卡片資訊

4.對於第一種情況的處理:

control.php頁面上獲得session:

讀取資料庫的內容:

line 53:

複製代碼 代碼如下:
$grouparr[] = iconv("GB2312","UTF-8",$g[0]); //資料庫內容轉換為 UTF-8,這樣能正常顯示頁面上的中文

line106:

複製代碼 代碼如下:
$_SESSION['dispatchgroup'] = iconv("UTF-8","GB2312",$grouparr[0]);//將轉換的中文修改為 GB2312,用於在 dispatchinfo.php 檔案中獲得查詢的條件值,獲得GB2312編碼的值。

dispatchinfo.php: line 291

if($_SESSION['dispatchgroup']){  $groupaddressinfo = function_listaddressesbygroup($_SESSION['dispatchgroup'],1,$value,0,$_SESSION['dispatchexten'],$_SESSION['dispatchgrouppage']);    //2013-5-17$groupaddressinfo = "listaddressesbygrouptype|0|LocalExt|1|12|1,,,801,空閑,,|1,,,802,不線上,,|1,,,803,空閑,,|1,,,804,不線上,,|,,,805,不線上,,|,,,806,不線上,,|,,,807,不線上,,|,,,808,不線上,,|,,,809,不線上,,|,,,810,不線上,,|5,餐廳,,811,10.1.6.189;串連|6,,,812,user2;斷開|";}

此種情況IE和FF,均能正常顯示。

5.對於第二種情況:

點擊“分機組”名稱,獲得點擊的分機組的中文名稱,通過Ajax 傳遞到 dispatchinfo2.php 檔案中進行處理,修改前,js點擊事件後獲得的中文名稱,alert均為正常值【格式為UTF-8】,此時資料庫中的內容為GB2312,這時,在經過 iconv轉碼就會出現錯誤。

因為只對於第一種情況,我在處理時採用轉換編碼的方式

複製代碼 代碼如下:
$groupname = iconv("GB2312","UTF-8",$groupname);

此時再次編碼就會出現錯誤了,

解決方案:

JS 的非同步提交處理:

checkval(); var ajax = InitAjax();var url = "dispatchinfo2.php?"+arges;//2013-08-21 limx 中文編碼問題url = encodeURI(encodeURI(url));ajax.open('GET',url,true);

dispatchinfo2.php

$groupname = urldecode($groupname);$groupname = iconv("utf-8","GB2312",$groupname);

四行代碼完美解決中文編碼的問題。

因為AJAX發送資料都是採用UTF-8編碼的方式發送的,所以要在伺服器 端進行編碼轉換(我這裡頁面是採用GB2312編碼的,如果是採用UTF-8的話應該不會有這步的問題),所以我在伺服器端進行了UTF-8轉 GB2312

希望本文所述對大家ajax程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.