1. 新浪博客上的一个例子,原作者 http://blog.sina.com.cn/s/blog_6ce9e8870101de3t.html
index.html
jQuery Ajax 实例演示
login.php
$_REQUEST['username'],'password'=>$_REQUEST['password']));?>
代码解释:
login.php :
a. json_encode :http://php.net/manual/en/function.json-encode.php 不复制过来了,几个例子都很好。
index.html:
a.$.ajax() : http://www.w3school.com.cn/jquery/ajax_ajax.asp
b.$.ajax() -> data: 两种办法:
$.ajax({ type: "POST", url: "some.php", data: "name=John&location=Boston", //第一种方式传参 // data: {name:"John",location:"Boston"} //第二种方式传参 // data: {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2' /* 第一种我们用url传参,参数里面如果加带"&"这个符号的话,可能参数接收不到或不完整, 如“ data: "name=John&location=Boston",” 如果name的值是"john&smith"这样写可能就会有问题, 我们可以用JS里面的encodeURIComponent()方法进行转义, 但如果用data: {name:"John",location:"Boston"}这种方式写的话就不需要进行转义*/ 另一篇
- /**
- * 订单取消
- * @return {Boolean} 处理是否成功
- */
- function orderCancel(orderId, commant){
- var flag = false;
- $.ajax({
- type: "POST",
- url: "../order/orderCancel.action", //orderModifyStatus
- data: { "orderId":orderId,"commant":commant},
- dataType:"json",
- async:false,
- cache:false,
- success: function(data){
- var member = eval("("+data+")"); //包数据解析为json 格式
- if(member.success=="true"){
- flag = true;
- }else if(member.success=="false") {
- alert(member.info);
- }
- },
- error: function(json){
- alert("订单取消异常,请刷新后重试...");
- }
- });
- hidediv();
- return flag;
- }
c.$.ajax() -> success :
success:要求为Function类型的参数,请求成功后调用的回调函数,有两个参数。 (1)由服务器返回,并根据dataType参数进行处理后的数据。 (2)描述状态的字符串。 function(data, textStatus){ //data可能是xmlDoc、jsonObj、html、text等等 this; //调用本次ajax请求时传递的options参数
关于json.password 的这个点
有这么一篇博客:http://blog.csdn.net/haiqiao_2010/article/details/12653555
最近在用jquery的ajax方法传递接收json数据时发现一个问题,那就是返回的data数据,有时候可以直接作为json数据使用,可有时候又不行。查了些资料,解释如下:[javascript] view plain copy$.ajax({ url: ajaxurl, type: "POST", success: function(data){ //假设返回的json数据里有status及info2个属性 //有时候可以直接ajaxobj.status或者ajaxobj["status"]去访问 //但有时候,却要通过eval()或者 $.parsejson();才可以通过ajaxobj.status访问,而且这种情况下,需要是complete而不是success ajaxobj=eval("("+data+")"); //或者$.parsejson() //var ajaxobj = $.parsejson(data); if(ajaxobj.status=="0") { alert("请登陆."); } else if(ajaxobj.status=="1")//未绑定微博 { alert(ajaxobj.info); } return true; }, error:function(ajaxobj) { if(ajaxobj.responseText!='') alert(ajaxobj.responseText); } }); 先说明第一种情况: 能够直接 data.属性名访问的情况,服务器端代码一定是直接return的一个常量字符串。 什么是常量字符串呢,常量字符串就是指直接用“”组成的字符串,没有定义String 变量直接把一串“”print到前台的情况,就可以直接data.属性名访问,而且jquery端只要写success就可以拿到。 下面是造成要eval并且不能进入success的原因: 这种情况是因为服务器端向外print的时候是一个String对象,通常此类问题在我的代码里是因为后台json比较复杂,在组织的时候我用到了StringBuffer,然后最后print的时候print的是StringBuffer对象的toString,所以就相当于print了一个String对象 这种情况下jquery的ajax方法就不会进入success方法,只能用complete接收,并且想要解析data里的json数据的话,必须对data.responseText进行eval ()或者 $.parsejson(); 除此两点,还有需要注意的是,如果你使用的是jq1.4,那么他对json的格式有着更严格的要求,所有的key和属性都要用双引号标注起来,虽然key不用双引号原生的js是允许的,但是jq1.4似乎有这个要求。以上是我个人的想法跟理解,若有不同见解欢迎指教.
php 接受 json
代码如下:
<?php $json_string = $_POST["txt_json"]; if(ini_get("magic_quotes_gpc")=="1") { $json_string=stripslashes($json_string); } $user = json_decode($json_string); echo var_dump($user); ?>
在这个文件中,首先得到html文件中POST表单域txt_json的值,放入变量$json_string中,而后判断,如果当前PHP的设定为magic_quotes_gpc=On,即传入的双引号等会被转义,这样json_decode函数无法解析,因此我们要将其反转义化。而后,使用json_decode函数将JSON文本转换为对象,保存在$user变量中,最终用echo var_dump($user);,将该对象dump输出出来
到此处,已经会了基本的 html 利用 ajax和 form同 php 联络 php和数据库联络,下面准备做一个登陆界面,密码帐号存入数据库,界面利用amuizui的模板。