`
jgsj
  • 浏览: 1001475 次
文章分类
社区版块
存档分类
最新评论

php和js如何通过json互相传递数据

 
阅读更多
当我们在结合php和javascript实现某些功能时,经常会用到json。json是js的一种数据格式,可以直接被js解析。而php无法直接读取json数据,但是php提供了json_decode函数来对json数据进行转化,从而可以被php脚本访问。同时,php也提供了json_encode函数来将数据转化成json格式。那么,js中的原生json与php中通过json_encode函数转化后的json是否完全一样呢?今天,站长就和大家一起来探讨这个问题。

我们通过php向javascript传递数组数据时,通常要将其转化为json格式,一遍javascript来获取,那么我们就以数组为例,先来看一下两者之间的区别。

1、一维数组

考虑php数组$array=array("1","2","3");使用json_encode函数转化后,对应的json字符串为["1","2","3"]。

细心的朋友很快就发现,转化后得到的json字符串,就是javascript中的数组形式,那么是否可以用js的数组访问方式来访问呢?

当然是可以的,但是你将这个json字符串传递给给js时,需要使用urlencode函数对其编码,如:

<a href="javascript:show('<?php echo urlencode(json_encode(array('1','2','3')));?>')" id="aj">访问json</a>

我们可以用下面的js代码来验证:

function show(str){
var jobj=eval_r(decodeURI(str));
alert(jobj[2]);
}

大家自己试一试就会发现,是的,可以用js中访问一维数组的方式来访问它。eval方法将json字符串解释为json对象,因为传递过来的是字符串,不转化的话,你得到将是字符串中第三个字符的值。

我们再来对这个一维数组做一下变化,我们发现上面的一维数组没有指定索引,所以它默认为数字索引,现在我们来给它加上键名:

考虑php数组$array=array('a'=>'1','b'=>'2','c'=>'3');使用json_encode函数转化后,对应的json字符串为{"a":"1","b":"2","c":"3"}

我们很快就发现了其中的不同,最明显的就是字符串两端的[]变成了{},那么这个字符串是否也可以按上面那样处理后被js访问呢?我们不防试一试:

<a href="javascript:show('<?php echo urlencode(json_encode(array('a'=>'1','b'=>'2','c'=>'3')));?>')" id="aj">访问json</a>

function show(str){
var jobj=eval_r(decodeURI(str));
alert(jobj.a);
}

大家如果动手试了就知道,点击链接后,没有出现弹窗。为什么呢?是PHP生成的json字符串格式不对吗?不是的,这是我们在使用eval函数解释的时候,出错了。把上面的函数代码换成:

function show(str){
var jobj=eval_r('('+decodeURI(str)+')');
alert(jobj.a);
}

再试试吧!怎么样,可以访问了吧。这告诉我们,在使用eval方法处理带有键名的json字符串时,需要在字符串两端加速括号。至于为什么,站长也不知道,站在巨人的肩膀上而已。

这里要注意,尽管PHP生成的json字符串{"a":"1","b":"2","c":"3"}被传递给js后无法被直接解释为json格式,但是如果你在js中使用该字符串直接创建json数据,是可以的。试试下面的代码吧:

var jobj={"a":"1","b":"2","c":"3"};
alert(jobj.b);

2、二维数组

二维数组在PHP用的应用非常广泛,因此了解二维数组转化后的json格式非常重要。有了上面的例子做铺垫,下面站长就直接给出示例代码:

<a href="javascript:show('<?php echo urlencode(json_encode(array(array('1','2','3'))));?>')" id="aj">访问json</a>

function show(str){
var jobj=eval_r(decodeURI(str));
alert(jobj[0][0]);
}

大家运行,会发现,这跟一维数组差不多,这是不带键名的例子,因此在show函数中,去掉字符串两端的括号也是可以的。

下面,我们对二维数组进行一下变化,在第二维中加入键名,请看示例代码:

<a href="javascript:show('<?php echo urlencode(json_encode(array(array("a"=>'1',"b"=>'2','3'))));?>')" id="aj">访问json</a>

function show(str){
var jobj=eval_r('('+decodeURI(str)+')');
alert(jobj[0].a);
}

大家运行代码后,发现,这里我们访问json数据的方式有点不一样。上面我们用的是alert(jobj[0][0]);而这里我们用的是alert(jobj[0].a);不要问我为什么,就是这样。这就是json的访问方式。

上面的例子,我们对二维数组的第二维添加了键名,下面我们对第一维添加键名,看看访问方式又有什么不同:

<a href="javascript:show('<?php echo urlencode(json_encode(array('k'=>array('1','2','3'))));?>')" id="aj">访问json</a>

function show(str){
var jobj=eval_r('('+decodeURI(str)+')');
alert(jobj.k[1]);
}

这里我们使用的是jobj.k[1]这样的方式,大家一定已经发现了,只要数组中含有键名,当数组被转化为json格式后,就要使用json对象.键名这样的方式来访问该键下的元素,上面的例子中,k键下的数组元素是数字索引,所以在json中使用k[1]这样的方式来访问。

下面,我们对数组的第一维和第二维都添加键名:

<a href="javascript:show('<?php echo urlencode(json_encode(array('k'=>array("a"=>'1','2','3'))));?>')" id="aj">访问json</a>

function show(str){
var jobj=eval_r('('+decodeURI(str)+')');
alert(jobj.k.a);
}

正如上面所提到的,只要含有键名,就必须以json对象.键名的方式来访问,如果有多个键就要用json对象.键名.键名...,不要问我为什么,这就是json的访问方式,只有javascript的发明者能向你解释,他为什么要这样规定。

结论:

1、将php中的数组转化为json字符串传递给js时。如果数组没有指定键名,那么可以直接使用js的eval方法将其转化为json格式供js处理;如果数组中含有键名,那么在使用eval方法处理时,需要使用()将json字符串括起来。

2、如果数组中含有键名,转化为json字符串后,在js中要用json对象.键名.键名...的方式来访问,如果是数字索引则用json对象[1]或者json对象.键名[1]这样的方式。

上面,我们主要讨论了,在PHP向js传递json字符串时,需要注意的事项。下面我们再来讨论,用js向php传递json字符串时需要如何处理。

聪明的你肯定已经知道了,只要将json数据用引号引起来作为字符串传递给PHP【通常用ajax进行】就可以用json_decode函数解码了。没错!就是这样!但是在构造json字符串的时候一定要仔细,如果你不经常构造json字符串,那么不妨用echo <wbr>json_encode(array('k'=&gt;array("a"=&gt;'1','2','3')))</wbr>这样的方式,查看你需要构造的目标字符串的json格式。这样你就可以在js中根据你想要的结果来构造了!

好了,今天对php和js之间如何使用json数据进行通信就讨论到这里,大家可以自己再试试将php的对象类型进行json编码后如何传递给js。

分享到:
评论

相关推荐

    php和js如何通过json互相传递数据.docx

    ### PHP 和 JS 如何通过 JSON 互相传递数据 在 Web 开发中,PHP 和 JavaScript(JS)都是非常重要的技术。PHP 是一种服务器端脚本语言,主要用于动态网站开发;而 JavaScript 则是一种客户端脚本语言,用于增强网页...

    php和js如何通过json互相传递数据相关问题探讨

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,被广泛用于PHP和JavaScript之间进行数据传输。PHP和JavaScript都支持JSON,但它们之间存在一些差异,特别是在处理JSON数据时。 在PHP中,我们通常...

    php基于jquery的ajax技术传递json数据简单实例.docx

    PHP 基于 jQuery 的 Ajax 技术传递 JSON 数据简单实例 本文主要介绍了 PHP 基于 jQuery 的 Ajax 技术传递 JSON 数据方法,以完整实例形式分析了 PHP 基于 jQuery 的 Ajax 无刷新提交数据实现方法。下面是详细的知识...

    php通过json传递数组到javascript

    php具有强大的后端处理能力,其生成的数据,尤其是数组,通过json传递给javascript.本文中演示的例子是一个文件的数据传送。

    PHP操作json数据

    在PHP中,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于JavaScript的一个子集,易于人阅读和编写,同时也...在实际工作中,要灵活运用这些函数和数据结构,确保数据的准确无误地转换和传递。

    前台ajax与后台json传递

    在Web开发中,前后端数据交互是至关重要的一个环节,特别是在动态网页应用中。"前台Ajax与后台Json传递...文件"前台ajax与后台json传递.txt"可能包含了更详细的代码示例和解释,这将帮助你进一步掌握这些概念和技术。

    php基于jquery的ajax技术传递json数据简洁实例_.docx

    总的来说,这个实例展示了如何使用jQuery的AJAX功能与PHP配合,通过JSON格式传递和接收数据。这种方式提高了用户体验,因为数据交换是在后台完成的,不会打断用户的操作流程。同时,JSON作为数据交换格式,因其轻量...

    json解析在js和php中的不同

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它以其简洁明了的文本形式,易于人阅读和编写,同时也方便机器解析和生成。在Web开发中,JSON经常用于前后端数据交互,因为它的结构与JavaScript...

    银行及对应的简码json数据

    这些简码可以是数字或字母的组合,用于识别和区分不同的银行机构,方便在电子交易、报表和数据分析中使用。例如,SWIFT代码(Society for Worldwide Interbank Financial Telecommunication)是国际银行业通用的一种...

    关于使用json传递数据给客户端的例子

    在本例中,我们将探讨如何使用JSON在服务端和客户端之间传递数据,结合MySQL数据库进行存储操作。 首先,JSON格式易于人阅读和编写,同时也容易让机器解析和生成。它的基本数据类型包括字符串、数字、布尔值、数组...

    PHP应用JSON技巧讲解 中文WORD版

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,被广泛用于Web应用程序之间传递数据。在PHP中,处理JSON数据十分便捷,因为PHP提供了内置的函数来编码和解码JSON。本文档将深入探讨PHP如何运用JSON...

    js json五子棋

    【标题】"js json五子棋"涉及到的主要知识点是JavaScript编程和JSON数据格式的应用,尤其在游戏开发中的实践。JavaScript是一种广泛使用的客户端脚本语言,主要用于网页和网络应用的交互,而JSON(JavaScript Object...

    使用PHP解析JSON数据1

    我们将通过PHP解析JSON数据,并将结果显示在HTML页面上,利用JavaScript的`eval()`函数来执行这个任务。 为了实现这一目标,我们首先创建一个名为“index.php”的PHP文件。在文件中,我们使用`file_get_contents()`...

    jquery+php查询数据库实现json的例子

    当jQuery的Ajax请求接收到服务器返回的JSON数据时,JavaScript会自动将其解析为JavaScript对象,可以使用`.done()`或`.success()`回调函数处理这些数据。例如,你可以遍历JSON对象,动态地更新HTML元素以展示数据库...

    Ecahrts地图数据各个区域的js文件以及json数据

    在"**Ecahrts地图数据各个区域的js文件以及json数据**"这个主题中,我们将深入探讨Echarts如何处理地图数据,以及如何利用经纬度进行定位和数据传输。 首先,Echarts地图的实现依赖于特定的js文件,这些文件包含了...

    php json类

    总的来说,PHP的JSON支持使得开发人员能够轻松地在服务器端与客户端(如JavaScript)之间传递数据,这对于Web应用程序的API开发和数据交换至关重要。熟悉这些函数的用法对于任何PHP开发者来说都是必不可少的技能。

    php生成json和xml

    首先,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。JSON格式基于JavaScript的一个子集,但它是语言无关的。在PHP中,我们可以使用内置的`json_...

    JsonView.rar里面有四个JSON数据格式化工具

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,被广泛用于Web应用程序之间传输数据。它以文本形式存储和传递数据,易于人阅读和编写,同时也易于机器解析和生成。JSONView是一款针对JSON数据的...

Global site tag (gtag.js) - Google Analytics