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 相关文章推荐
建立文件交换功能的脚本(三)
Oct 09 PHP
投票管理程序
Oct 09 PHP
Windows 下的 PHP-PEAR 安装方法
Nov 20 PHP
PHP生成唯一的促销/优惠/折扣码(附源码)
Dec 28 PHP
ThinkPHP中关联查询实例
Dec 02 PHP
php中实现获取随机数组列表的自定义函数
Apr 02 PHP
php+ajax实现无刷新的新闻留言系统
Dec 21 PHP
4种PHP异步执行的常用方式
Dec 24 PHP
Yii控制器中操作视图js的方法
Jul 04 PHP
php获取访问者浏览页面的浏览器类型
Jan 23 PHP
yii gridview实现时间段筛选功能
Aug 15 PHP
PHP设计模式之原型模式定义与用法详解
Apr 03 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文件打包 下载之使用PHP自带的ZipArchive压缩文件并下载打包好的文件
2012/06/13 PHP
php中array_slice和array_splice函数解析
2016/10/18 PHP
PHP多进程之pcntl_fork的实例详解
2017/10/15 PHP
php接口隔离原则实例分析
2019/11/11 PHP
laravel5.6 框架邮件队列database驱动简单demo示例
2020/01/26 PHP
javascript时间自动刷新实现原理与步骤
2013/01/06 Javascript
Javascript高级技巧分享
2014/02/25 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
每个程序员都需要学习 JavaScript 的7个理由小结
2016/09/03 Javascript
JavaScript使用Ajax上传文件的示例代码
2017/08/10 Javascript
ES6解构赋值实例详解
2017/10/31 Javascript
使用vux实现上拉刷新功能遇到的坑
2018/02/08 Javascript
js捆绑TypeScript声明文件的方法教程
2018/04/13 Javascript
AngularJS实现与后台服务器进行交互的示例讲解
2018/08/13 Javascript
element-ui使用导航栏跳转路由的用法详解
2018/08/22 Javascript
React router动态加载组件之适配器模式的应用详解
2018/09/12 Javascript
Vue 事件处理操作实例详解
2019/03/05 Javascript
vue 实现特定条件下绑定事件
2019/11/09 Javascript
详解Vue数据驱动原理
2020/11/17 Javascript
VUE实现吸底按钮
2021/03/04 Vue.js
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
python的常见命令注入威胁
2013/02/18 Python
Python中的is和id用法分析
2015/01/26 Python
Python与shell的3种交互方式介绍
2015/04/11 Python
python基于Tkinter库实现简单文本编辑器实例
2015/05/05 Python
Python实现二维数组按照某行或列排序的方法【numpy lexsort】
2017/09/22 Python
Python设计模式之外观模式实例详解
2019/01/17 Python
对Python3 pyc 文件的使用详解
2019/02/16 Python
python如何编写win程序
2020/06/08 Python
Python3.9 beta2版本发布了,看看这7个新的PEP都是什么
2020/06/10 Python
OpenCV 之按位运算举例解析
2020/06/19 Python
浅谈HTML5中dialog元素尝鲜
2018/10/15 HTML / CSS
转让协议书范本
2014/09/13 职场文书
整改通知书
2015/04/20 职场文书
大学生村官工作心得体会
2016/01/23 职场文书
SpringCloud Alibaba项目实战之nacos-server服务搭建过程
2021/06/21 Java/Android