PHP自訂函數格式化json資料怎麼調用?

來源:互聯網
上載者:User

標籤: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資料怎麼調用?

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.