include/conn.php為數據庫鏈接文件,不會的網上搜索
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
<?php include './include/conn.php' ; //數據庫鏈接文件 $sql_notice = mysql_query( 'SELECT * FROM gg_notice where enable = "1" limit 0,10' ); $notice = mysql_fetch_array( $sql_notice , MYSQL_ASSOC); print_r ( $notice ); ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" > <html xmlns= "http://www.w3.org/1999/xhtml" > <head> <title>第一php網提供的教程--將數據庫讀取的數據生成json格式</title> <meta http-equiv= "Content-Type" content= "text/html; charset=utf-8" /> <!-- <script src= "http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type= "text/javascript" /></script> --> <script language=javascript> </script> </head> <body> <pre> <h1>請注意兩種方法生成的對象數組在結構上的區別</h1> <?php echo '<h1>法一</h1>' ; //假設以下數組是根據我們從數據庫讀取的數據生成的 $jarr = array ( 'total' =>239, 'row' => array ( array ( 'code' => '001' , 'name' => '中國' , 'addr' => 'Address 11' , 'col4' => 'col4 data' ), array ( 'code' => '002' , 'name' => 'Name 2' , 'addr' => 'Address 12' , 'col4' => 'col4 data' ), ) ); //法一: $jobj = new stdclass(); //實例化stdclass,這是php內置的空類,可以用來傳遞數據,由于json_decode后的數據是以對象數組的形式存放的, //所以我們生成的時候也要把數據存儲在對象中 foreach ( $jarr as $key => $value ){ $jobj -> $key = $value ; } print_r( $jobj ); //打印傳遞屬性后的對象 echo '使用$jobj->row[0][\'code\']輸出數組元素:' . $jobj ->row[0][ 'code' ]. '<br>' ; echo '編碼后的json字符串:' .json_encode( $jobj ). '<br>' ; //打印編碼后的json字符串 echo '<hr>' ; //法二: echo '<h1>法二</h1>' ; echo '編碼后的json字符串:' ; echo $str =json_encode( $jarr ); //將數組進行json編碼 echo '<br>' ; $arr =json_decode( $str ); //再進行json解碼 print_r( $arr ); //打印解碼后的數組,數據存儲在對象數組中 echo '使用$arr->row[0]->code輸出數組元素:' . $arr ->row[0]->code; ?> </body> </html> |