JSON用法之将PHP数组转JS数组,JS如何接收PHP数组


Posted in PHP onOctober 08, 2015

首先下载下面这个文件(这是一段是别人写出来专门解析json的代码),然后引入这个文件!

    http://pan.baidu.com/s/1dD8qVr7

    现在当我们需要用ajax与后台进行交互时,怎样将php的数组传送到js文件并且并js所识别?

JSON用法之将PHP数组转JS数组,JS如何接收PHP数组

    先看php文件,当我们获取到$arr这个数组后

foreach ($arr as $value) {
  $json .= json_encode($value) . ',';
} 
echo '[' . substr($json,0,strlen($json) - 1) . ']';

json_encode()是将$arr的每一个值进行json编码,然后我们想输出一个json的数组,所以我们将每个编译后的值后面加一个逗号并且最后在所有值外面加上'[]',这是json数组的格式,注意因为我们在将每一个值进行json编码后都加上一个逗号在后面,这样就导致最后所有值合并数组时多一个逗号,所有我们得用substr()函数将其最后一个逗号去掉!

    然后我们来看js文件

当我们用arr接受到php文件传输的json数组后

var json = JSON.parse(arr);

JSON是咱们开始下载那个文件中定义的一个对象,我们用它的parse方法将json数组转化成js的数组!这是变量json接受到的是一个js数组所以直接不能打印出来,你可以遍历这个json数组或者json[0]来输出!

其实,说白了咱们将php数组转化成js数组的思路就是利用json这个中间量来实现!当然你也可以只用php和js来实现数组的转化,方法不止一种!

PHP数组和Json之间的转换

之所以要用到Json,很多时候是因为使用ajax对象时,程序与JS函数之间的数据交互。因为JS不认识PHP中的数组,PHP也不认识JS中的数组或对象。Json很好的解决了这个问题。

Json简介

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript的一个子集,这意味着JavaScript可以直接读取Json,非常方便。

Json的具体形式是:

1.对象

对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。

例如: {“username”: “Eric”,”age”:23,”sex”: “man”}

代码示例:

<script type="text/javascript">  function getUser()
{
  var  user = {
  "username": "Eric",
  "age":23,
  "family": {"mother":"Marry","father":"Alon","brother":"Tom"}
  };  alert( user.username );  alert( user.age );  alert(user.family.brother);
}  getUser();  </script>

2、数组

数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔。

例如: ["Eric",23, "man"]

代码示例:

<script type="text/javascript">  function getArray() 
{  
var arr = ["Jarry",23, ["www.xiaophper.com","wxyh_999@126.com"]];  
alert(arr[0]);  alert(arr[1]);  alert(arr[2][0]); 
alert(arr[2][1]);  
}  
getArray();  
</script>

注意:对象和数组两种形式在JS中的调用时不一样啊,对象用“.”调用,数组用下标[0]、[1]调用。还要注意在传递Json串时string类型的值要用引号括起来。

PHP中将数组转变成Json

强大的PHP已经提供了内置函数:json_encode() 和 json_decode()。很容易理解,json_encode()就是将PHP数组转换成Json。相反,json_decode()就是将Json转换成PHP数组。

例如:

$array = array("name" => "Eric","age" => 23); 
echo json_encode($array);

程序将打印出 :

{“name”:”Eric”,”age”:23}

再看下面的例子:

$array = array(0 => "Eric", 1 => 23); 
echo json_encode($array);

程序将打印出 :["Eric",23]

以上两个例子可以看出,如果PHP数组的键都是数字,那么json_encode()返回一个数组形式的Json,如果PHP数组的键全是字符串。那么json_encode()就会返回一个对象形式的Json。刚已经说过。两者在js中的调用是不同的。

事实上,只要在PHP数组的键中有一个字符串形式的键,那么json_encode()就会返回对象形式的Json。这是不正确的。因为,虽然在PHP代码中不会出现错误,但要是将这样的Json传给JS函数,JS会将此Json当做一个对象,而对象是不可能以数字作为属性名的。也就是说JS 不知道这是什么 : user.0.username  (中间是数字零)

PHP 相关文章推荐
ZF等常用php框架中存在的问题
Jan 10 PHP
快速开发一个PHP扩展图文教程
Dec 12 PHP
php下保存远程图片到本地的办法
Aug 08 PHP
PHP中spl_autoload_register函数的用法总结
Nov 07 PHP
php可生成缩略图的文件上传类实例
Dec 17 PHP
codeigniter显示所有脚本执行时间的方法
Mar 21 PHP
在WordPress中使用wp-cron插件来设置定时任务
Dec 10 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
May 27 PHP
搭建自己的PHP MVC框架详解
Aug 16 PHP
wordpress自定义标签云与随机获取标签的方法详解
Mar 22 PHP
php和html的区别点详细总结
Sep 24 PHP
Mac下关于PHP环境和扩展的安装详解
Oct 17 PHP
php开发微信支付获取用户地址
Oct 04 #PHP
浅谈使用PHP开发微信支付的流程
Oct 04 #PHP
8个必备的PHP功能开发
Oct 02 #PHP
PHP人民币金额转大写实例代码
Oct 02 #PHP
基于OpenCart 开发支付宝,财付通,微信支付参数错误问题
Oct 01 #PHP
php中preg_match的isU代表什么意思
Oct 01 #PHP
php 利用array_slice函数获取随机数组或前几条数据
Sep 30 #PHP
You might like
为什么《星际争霸》是测试人工智能的理想战场
2019/12/03 星际争霸
php 设计模式之 工厂模式
2008/12/19 PHP
判断PHP数组是否为空的代码
2011/09/08 PHP
php中创建和调用webservice接口示例
2014/07/25 PHP
基于jquery的滚动鼠标放大缩小图片效果
2011/10/27 Javascript
JavaScript与DOM组合动态创建表格实例
2012/12/23 Javascript
js异常捕获方法介绍
2013/04/10 Javascript
浅析js设置控件的readonly与enabled属性问题
2013/12/25 Javascript
JavaScript实现两个Table固定表头根据页面大小自行调整
2014/01/03 Javascript
Node.js中创建和管理外部进程详解
2014/08/16 Javascript
JS中script标签defer和async属性的区别详解
2016/08/12 Javascript
通过JS获取Request.QueryString()参数的值实现方法
2016/09/27 Javascript
详解jquery easyui之datagrid使用参考
2016/12/05 Javascript
JS常用正则表达式总结【经典】
2017/05/12 Javascript
浅谈nodejs中的类定义和继承的套路
2017/07/26 NodeJs
老生常谈js数据类型
2017/08/03 Javascript
原生JS实现小小的音乐播放器
2017/10/16 Javascript
微信小程序下拉框组件使用方法详解
2018/12/28 Javascript
微信小程序中插入激励视频广告并获取收益(实例代码)
2019/12/06 Javascript
Element MessageBox弹框的具体使用
2020/07/27 Javascript
python实现逆波兰计算表达式实例详解
2015/05/06 Python
Python 搭建Web站点之Web服务器网关接口
2016/11/06 Python
itchat接口使用示例
2017/10/23 Python
Python高斯消除矩阵
2019/01/02 Python
分享8个非常流行的 Python 可视化工具包
2019/06/05 Python
使用APScheduler3.0.1 实现定时任务的方法
2019/07/22 Python
详解Python self 参数
2019/08/30 Python
PyInstaller的安装和使用的详细步骤
2020/06/02 Python
详解Python的爬虫框架 Scrapy
2020/08/03 Python
墨西哥巴士车票在线购买:ClickBus
2018/03/27 全球购物
Belstaff英国官方在线商店:Belstaff.co.uk
2021/02/09 全球购物
自我评价正确写法范文
2013/12/10 职场文书
2014年十一国庆节爱国演讲稿
2014/09/23 职场文书
租赁协议书
2015/01/27 职场文书
学习《中小学教师职业道德规范》心得体会
2016/01/18 职场文书
2016幼儿教师自荐信范文
2016/01/28 职场文书