php 二維數組傳遞給 js 問題解決記錄

需求:

php從數據庫中讀取到二維數組。傳遞到js中

 

實現步驟:

php:json_encode  →   json  →  js:eval

即在php中使用json_encode()將php的二維數組轉化成json格式。傳遞到js中,使用eval()解析得到js的二維數組。

 

代碼:

php:

 

<?php  
header("Content-Type: text/html; charset=utf8") ;
$con=mysqli_connect("url","name","password","databasename");
// Check connection
if (mysqli_connect_errno($con))
    echo "Failed to connect to MySQL: " . mysqli_connect_error();

mysqli_query($con,"set character set 'utf8'");
mysqli_query($con,"set names 'utf8'");

$json_arr = array(array("a","b","c",1,2,3),array("q","w",1,2));
$jsonstr = json_encode($json_arr);

?

 

> var json=<?=$jsonstr?>;

 

 


 

js:

 

 

<script type="text/javascript" src="http://.../test.php"></script>
<script language="javascript" type="text/javascript">	    
	$(document).ready(function(){
	    var jsonstr =eval(json);
	    for(var k=0;k<jsonstr.length;k++){
               for(var i=0;i<jsonstr[k].length;i++)
                  alert(jsonstr[k][i]);
            }
        })
</script>

 

 

遇到的問題:

1.php中二維數組使用json_encode()轉化成json時。第二維數組能夠echo出來,可是轉化成json爲空。

到網上查資料確定問題是第二維數組中含有非utf8編碼。果然,我把二維數組中第二維數組互換位置,變成第一個數組的json爲空了。

結論:json_encode()能夠轉化多維數組。可是基本要求是編碼爲utf8。遇到多維數組中某一子數組轉化json爲null,極有可能使這一子數組中含有編碼不是utf8的元素。

 

 

2.wamp mysql 在phpmyadmin中看到數據表內容是正常漢字。可是用php讀取出來打印發現漢字都變成?了。

數據庫中各個表的整理方式都是utf8_general_ci。php文件裏也聲明瞭

 

header("Content-Type: text/html; charset=utf-8") ;
...
mysqli_query($con,"set character set 'utf-8'");
mysqli_query($con,"set names 'utf-8'");

這些代碼我一直是這麼用的(之前用的是wamp低版本號。還是用的mysql_query。如今報錯說廢棄了,就改成了mysqli)。之前也沒出現過中文變成?的情況。網上一查,原來是utf-8與utf8這個地方。。

 

 

應該是這樣:

 

header("Content-Type: text/html; charset=utf8") ;
...
mysqli_query($con,"set character set 'utf8'");
mysqli_query($con,"set names 'utf8'");

結論:mysql中還是使用utf8吧。。。

 

無語。

轉自:https//:www.cnblogs.com/mengfanrong/p/5092664.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章