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 相关文章推荐
怎么使 Mysql 数据同步
Oct 09 PHP
多数据表共用一个页的新闻发布
Oct 09 PHP
打造计数器DIY三步曲(下)
Oct 09 PHP
PHP如何利用P3P实现跨域
Aug 24 PHP
php foreach循环中使用引用的问题
Nov 06 PHP
PHP中使用Session配合Javascript实现文件上传进度条功能
Oct 15 PHP
PHP静态文件生成类实例
Nov 29 PHP
php绘制一个矩形的方法
Jan 24 PHP
学习PHP session的传递方式
Jun 15 PHP
Netbeans 8.2与PHP相关的新特性介绍
Oct 08 PHP
php+js实现的拖动滑块验证码验证表单操作示例【附源码下载】
May 27 PHP
PHP7移除的扩展和SAPI
Mar 09 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+redis消息队列实现抢购功能
2018/02/08 PHP
使用PHP+Redis实现延迟任务,实现自动取消订单功能
2019/11/21 PHP
jQuery插件-jRating评分插件源码分析及使用方法
2012/12/28 Javascript
javascript中的document.open()方法使用介绍
2013/10/09 Javascript
使用EVAL处理jqchart jquery 折线图返回数据无效的解决办法
2015/11/26 Javascript
JavaScript学习总结之JS、AJAX应用
2016/01/29 Javascript
20分钟轻松创建自己的Bootstrap站点
2016/05/12 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
关于JavaScript和jQuery的类型判断详解
2016/10/08 Javascript
基于vue2.0+vuex的日期选择组件功能实现
2017/03/13 Javascript
AngularJS常见过滤器用法实例总结
2017/07/06 Javascript
Angularjs cookie 操作实例详解
2017/09/27 Javascript
基于vue 开发中出现警告问题去除方法
2018/01/25 Javascript
React Native 自定义下拉刷新上拉加载的列表的示例
2018/03/01 Javascript
微信小程序下拉框功能的实例代码
2018/11/06 Javascript
Vue3为什么这么快
2020/09/23 Javascript
在Python中关于中文编码问题的处理建议
2015/04/08 Python
使用Python3编写抓取网页和只抓网页图片的脚本
2015/08/20 Python
python 编码规范整理
2018/05/05 Python
Python 限制线程的最大数量的方法(Semaphore)
2019/02/22 Python
pycharm新建一个python工程步骤
2019/07/16 Python
Django 模型类(models.py)的定义详解
2019/07/19 Python
python mqtt 客户端的实现代码实例
2019/09/25 Python
Tensorflow中tf.ConfigProto()的用法详解
2020/02/06 Python
python 最简单的实现适配器设计模式的示例
2020/06/30 Python
HTML5 Canvas绘制圆点虚线实例
2015/01/01 HTML / CSS
哥伦比亚最大的网上商店:Linio哥伦比亚
2016/09/25 全球购物
老师给学生的表扬信
2014/01/17 职场文书
八年级语文教学反思
2014/02/11 职场文书
房屋产权证明书
2014/10/15 职场文书
给男朋友的道歉短信
2015/05/12 职场文书
2015年节能减排工作总结
2015/05/14 职场文书
导游词之扬州大明寺
2019/10/09 职场文书
浅谈vue2的$refs在vue3组合式API中的替代方法
2021/04/18 Vue.js
PHP使用非对称加密算法RSA
2021/04/21 PHP
Matplotlib绘制混淆矩阵的实现
2021/05/27 Python