Json格式的所有内容
1)并列的数据之间用逗号(", ")分隔
2)映射用冒号(": ")表示
3)并列数据的集合(数组)用方括号("[]")表示
4)映射的集合(对象)用大括号("{}")表示
举例:"北京市的面积为16800平方公里,常住人口1600万人。上海市的面积为6400平方公里,常住人口1800万。"
写成json格式就是这样:
[
{"城市":"北京","面积":16800,"人口":1600},
{"城市":"上海","面积":6400,"人口":1800}
]
1.php程序中json用法
PHP提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。
1)直接写json格式并输出
$json = '[{"name":"sunyan","age":22},{"name":"zhanglan","age":24}]';
$result = json_decode($json);//将json数据格式解码成php数据格式并输出
foreach($result as $key => $value) {
if($value) {
echo "<br>$value->name<br>"." $value->age<br>";
}
}
输出结果
sunyan
22
zhanglan
24
2)一维数组转换成json格式并输出
$message['login']='login success';
$json_message=json_encode($message);
echo $json_message;
$a=json_decode($json_message);
echo $a->login;
{"login":"login success"}
login success
3)二维数组转换成json格式并输出
$list['name']="sunyan";
$list['age']=22;
$list_merge[]=$list;
$list['name']="zhanglan";
$list['age']=24;
$list_merge[]=$list;
$list_json=json_encode($list_merge);
echo $list_json;
输出结果
[{"name":"sunyan","age":22},{"name":"sunyan","age":24}]
若想在转变回数组形式输出,需将其解码
$list_j=json_decode($list_json);
数组输出方式一:
foreach($list_j as $key=>$v){
echo "$key<ul>";
echo "<li>$v->name</li>";
echo "<li>$v->age</li>";
echo"</ul>";
}
数组输出方式二:
foreach($list_merge as $key=>$list){
echo "$key<ul>";
foreach($list as $k=>$v){
echo "<li>$v</li>";
}
echo"</ul>";
}
输出结果
0
sunyan
22
1
sunyan
24
注意,没有经过编码,解码的数组只能方式二输出
2.js程序中json用法
js与服务器端进行交互的时候,发送与接受数据都可以使用json数据格式
1)js 与php程序交互
以注册为例,若用户名已经有人注册,网页会提醒你更换用户名
php代码
function check_name($username){
$dbc=connect_mysql();
if ($dbc){
$q='select * from usermessage where name=?';
$stmt=mysqli_prepare($dbc,$q);
mysqli_stmt_bind_param($stmt,'s',$name);
$name=$username;
mysqli_stmt_execute($stmt);
mysqli_stmt_store_result($stmt);
if(mysqli_stmt_affected_rows($stmt)==1){
$message['check_name']='name exit';
$json_message=json_encode($message);
return $json_message;
}else{
$message['check_name']='name no exit';
$json_message=json_encode($message);
return $json_message;
}
mysqli_stmt_close($stmt);
mysql_close($dbc);
}else{
die('Could not connect: ' . mysql_error());
}
}
js代码
$("#input_name").blur(function(){
if($("#input_name").val().length<2||$("#input_name").val().length>20){
$("#span_name_error").text("用户名长度必须是2-20位");
}else{
name=$("#input_name").val().replace(/\s/g,'');//去掉头尾空格
$.ajax({
type: "post",
dataType: "json",
url: "/todolist/register_handle.php?act=check_name",
data: {username:name},
success: function(json_message){
var data=(eval(json_message)).check_name;
if(data=="name exit"){
$("#span_name_error").text("此用户名已经被注册");
}else if(data=="name no exit"){
$("#span_name_error").text("");
}
}
});
}
});