php和js怎么通过json互相传递数据

发布时间:2021-02-01 10:34:03 作者:小新
来源:亿速云 阅读:238

这篇文章给大家分享的是有关php和js怎么通过json互相传递数据的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

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 json_encode(array('k'=>array("a"=>'1','2','3')))

这样的方式,查看你需要构造的目标字符串的json格式。这样你就可以在js中根据你想要的结果来构造了!

感谢各位的阅读!关于“php和js怎么通过json互相传递数据”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

推荐阅读:
  1. javascript与php使用json传递数据
  2. vue.js 组件之间传递数据

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

json php js

上一篇:怎样使用php判断所处服务器操作系统的类型

下一篇:使用PHP批量去除文件UTF8 BOM信息的示例

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》