標籤:ring 指令碼 int form format action tin 實現 array
<?php
/**
* Formats a JSON string for pretty printing
*
* @param string $json The JSON to make pretty
* @param bool $html Insert nonbreaking spaces and <br />s for tabs and linebreaks
* @return string The prettified output
*/
$arr = array("ret"=>0,"data"=>array(‘a‘ => 1, ‘b‘ => "指令碼之家", ‘c‘ => 3, ‘d‘ => 4, ‘e‘ => 5));
$json = json_encode($arr);
function _format_json($json, $html = false) {
$tabcount = 0;
$result = ‘‘;
$inquote = false;
$ignorenext = false;
if ($html) {
$tab = " ";
$newline = "<br/>";
} else {
$tab = "\t";
$newline = "\n";
}
for($i = 0; $i < strlen($json); $i++) {
$char = $json[$i];
if ($ignorenext) {
$result .= $char;
$ignorenext = false;
} else {
switch($char) {
case ‘{‘:$tabcount++;$result .= $char . $newline . str_repeat($tab, $tabcount);break;
case ‘}‘:$tabcount--;$result = trim($result) . $newline . str_repeat($tab, $tabcount) . $char;break;
case ‘,‘:$result .= $char . $newline . str_repeat($tab, $tabcount);break;
case ‘"‘:$inquote = !$inquote;$result .= $char;break;
case ‘\\‘:if ($inquote) $ignorenext = true;$result .= $char;break;
default:$result .= $char;
}
}
}
return $result;
}
echo _format_json($json);
/*
{
"ret": 0,
"data": {
"a": 1,
"b": "\u811a\u672c\u4e4b\u5bb6",
"c": 3,
"d": 4,
"e": 5
}
}
**/
?>
PS:這裡再為大家推薦幾款比較實用的json線上工具供大家參考使用:
線上JSON代碼檢驗、檢驗、美化、格式化工具:
http://tools.jb51.net/code/json
JSON線上格式化工具:
http://tools.jb51.net/code/jsonformat
線上XML/JSON互相轉換工具:
http://tools.jb51.net/code/xmljson
json代碼線上格式化/美化/壓縮/編輯/轉換工具:
http://tools.jb51.net/code/jsoncodeformat
C語言風格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
<a href="?action=up&id=200">上一篇</a>
<a href="?action=down&id=200">下一篇</a>
如果是實現上一篇就在action=up頁面寫函數
$id= $_GET[‘id‘];
//上一篇:
$sql= select * from article where id < ‘.$id.‘ order by id desc limit 0,1‘;
$rs= mysql_query($sql);
$row= mysql_fetch_array ($rs);
//下一篇:
$sql= select * from article where id < ‘.$id.‘ order by id asc limit 0,1‘;
$rs= mysql_query($sql);
$row= mysql_fetch_array ($rs);
原理,查詢比當前ID小(where id < ‘.$id.‘上一篇)和比當前ID大(where id > ‘.$id.‘下一篇)的1條(limit 0,1)資料,並按降序(desc,上一篇)和升序(asc,下一篇)顯示出來,當只取一篇的時候,可以省略降序或升序。
PHP自訂函數格式化json資料怎麼調用?