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 相关文章推荐
逆序二维数组插入一元素的php代码
Jun 08 PHP
PHP将XML转数组过程详解
Nov 13 PHP
ThinkPHP中的关联模型注意点
Jun 16 PHP
Laravel 5.3 学习笔记之 安装
Aug 28 PHP
PHP实现的贪婪算法实例
Oct 17 PHP
PHP简单实现二维数组赋值与遍历功能示例
Oct 19 PHP
PHP实现基于栈的后缀表达式求值功能
Nov 10 PHP
php curl操作API接口类完整示例
May 21 PHP
laravel 自定义常量的两种方案
Oct 14 PHP
PHP 图片合成、仿微信群头像的方法示例
Oct 25 PHP
PHP多进程简单实例小结
Nov 09 PHP
PHP基本语法
Mar 31 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
PHP删除目录及目录下所有文件的方法详解
2013/06/06 PHP
php生成验证码,缩略图及水印图的类分享
2016/04/07 PHP
php实现的中秋博饼游戏之掷骰子并输出结果功能详解
2017/11/06 PHP
Ubuntu上安装yaf扩展的方法
2018/01/29 PHP
动态为事件添加js代码示例
2009/02/15 Javascript
clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析
2010/03/12 Javascript
js操作select控件的几种方法
2010/06/02 Javascript
javascript内置对象操作详解
2015/02/04 Javascript
jquery实现无刷新验证码的简单实例
2016/05/19 Javascript
jquery——九宫格大转盘抽奖实例
2017/01/16 Javascript
Bootstrap模态框(Modal)实现过渡效果
2017/03/17 Javascript
使用vue制作FullPage页面滚动效果
2017/08/21 Javascript
详解Angular5 服务端渲染实战
2018/01/04 Javascript
JavaScript实现求最大公共子串的方法
2018/02/03 Javascript
详解vue-cli项目中的proxyTable跨域问题小结
2018/02/09 Javascript
关于vue v-for循环解决img标签的src动态绑定问题
2018/09/18 Javascript
jsonp跨域获取百度联想词的方法分析
2019/05/13 Javascript
js canvas实现5张图片合成一张图片
2019/07/15 Javascript
微信小程序 点击切换样式scroll-view实现代码实例
2019/10/11 Javascript
微信小程序实现购物车功能
2020/11/18 Javascript
Python编写检测数据库SA用户的方法
2014/07/11 Python
python数据结构学习之实现线性表的顺序
2018/09/28 Python
django query模块
2019/04/20 Python
详解将Pandas中的DataFrame类型转换成Numpy中array类型的三种方法
2019/07/06 Python
Python 日期的转换及计算的具体使用详解
2020/01/16 Python
Jupyter notebook无法导入第三方模块的解决方式
2020/04/15 Python
Python WebSocket长连接心跳与短连接的示例
2020/11/24 Python
品管员岗位职责
2013/11/10 职场文书
幼儿园五一活动方案
2014/02/07 职场文书
一位农村小子的自荐信
2014/04/07 职场文书
低碳生活倡议书
2014/04/14 职场文书
2015年员工试用期工作总结
2014/12/12 职场文书
幼儿园感谢信
2015/01/21 职场文书
同学聚会致辞集锦
2015/07/28 职场文书
2016年中秋节寄语大全
2015/12/07 职场文书
Java面试题冲刺第十八天--Spring框架3
2021/08/07 面试题