Ajax 如何通过url 传递Json 数据或者数组 给PHP进行处理

前端之家收集整理的这篇文章主要介绍了Ajax 如何通过url 传递Json 数据或者数组 给PHP进行处理前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
/**
  * @author kaizhu_Qin
  * @copyright http://blog.csdn.net/kaizhu_qin
  * @version 2013-12-23
  * @latest update 2013-12-23
  */
首先,我们应该明白,url是不能直接传递数组类型的数据的。
例如:我们想通过url传递一个包含了用户名和密码的数据给login.PHP进行出来
var a=new Array(); 
a['name']="admin"; 
a['password']="admin";
var data='userinfo='+a;
$.ajax({ 
	type:"POST",url:"login.PHP",data:data,success:function(data){ 
		console.log(data); }
	});

这样通过url传数组是不成功的。

目前,JSON已经成为最流行的数据交换格式之一,我们可以尝试通过JSON 来完成:

下面我们先来了解下JSON:

从5.2版本开始,PHP原生提供json_encode()json_decode()函数,前者用于编码,后者用于解码。

一、json_encode()

函数主要用来将数组和对象,转换为json格式。先看一个数组转换的例子:

$arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5);
echo json_encode($arr);
//结果为:
//{"a":1,"b":2,"c":3,"d":4,"e":5}

二、json_decode()
函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:
$json = '{"a":1,"e":5};
var_dump(json_decode($json));
结果就是生成一个PHP对象:
object(stdClass)#1 (5) {

  ["a"] => int(1)
    ["b"] => int(2)
    ["c"] => int(3)
    ["d"] => int(4)
    ["e"] => int(5)

}

如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:

$json = '{"a":1,"e":5}';
var_dump(json_decode($json,true));

结果就生成了一个关联数组:

  array(5) {

   ["a"] => int(1)
     ["b"] => int(2)
     ["c"] => int(3)
     ["d"] => int(4)
     ["e"] => int(5)

  }

/***************************************************华丽的分割线****************************************************************/
同样的道理,我们反过来应用下:
我们在js里将需要传递的数组进行处理,写为下面的形式:

需要传递的数组:

var a = new Array(); 
a['name']="333"; 
a['password']="54dfdgf";
//JSON数据形式:
var a='{"username":admin,"password":admin}';
var data='userinfo='+a;
$.ajax({ 
	type:"POST",success:function(data){ 
		console.log(data); 
	}
});

在login.PHP 文件

$json=_POST['userinfo'];
print_r((json_decode($json,true)));
//结果:Array ([username] => admin [password] => admin)
这样我们使用Ajax通过url传递的数组就可以在PHP获得了。

当然,如果我们使用ajax的方式,传递form表单的数据,serialize() 能更加快速地序列化表单值。
serialize() 方法通过序列化表单值,创建 URL 编码文本字符串。
关于serialize() 的具体用法,大家可以参考这里:《jQuery ajax - serialize() 方法

猜你在找的Ajax相关文章