程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php 二維數組傳遞給 js 問題解決記錄

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

編輯:關於PHP編程

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


需求:

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


實現步驟:

php:json_encode → json → js:eval

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


代碼:

php:


var json=;


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

遇到的問題:

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吧。。。無語。



  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved