Jquery使用Firefox FireBug插件调试Ajax步骤讲解


Posted in Javascript onDecember 02, 2013

首先,我们用一个示例来说明JQuery的Ajax调用过程,

实现的一个功能是:点击确认支付按钮之后,实现余额支付的功能:

1.首先在php页面将相关需要调用的函数绑定到按钮上:

<input type="submit" name="pay_btn" id="pay_btn" value="确认支付" />
<script type="text/javascript">
$(function(){
    $("#pay_btn").bind("click",ABC.balancePay);
});

2.脚本处:

如果使用$.post方式实现:

var ABC = {
    balancePay: function(event){
        event.preventDefault();
        var tthis = $(event.currentTarget);
        var form = tthis.parents(‘form');
        var url = form.attr(‘action');
        var data = ‘code=15′ ;//+ $(‘#verifyCode').val();
        var jqXhr = $.post(url, data, undefined, ‘jsonp');
        jqXhr.done(function(datas){
                //console.log(‘这里是通过console打印出来的'); //#4
                $("#msg").text(‘结果:'+data);
});
}

$.post方式也可以直接指定回调函数:

var jqXhr = $.post(url, data, function(data){
            $("#msg").text('结果:'+data);
}, 'jsonp');

使用$.ajax方法实现:

var jqXhr = $.post(url, data, function(data){
            $("#msg").text(‘结果:'+data);
}, ‘jsonp');

使用$.ajax方法实现:

var jqXhr = $.ajax({
            type: ‘post',
            url: url,
            data: {code: ‘15′},
            dataType: ‘jsonp',
            sccuess:function(data){
            alert(‘good');},
            error: function(XMLHttpRequest, textStatus, errorThrown) {  //#3这个error函数调试时非常有用,如果解析不正确,将会弹出错误框
                        alert(XMLHttpRequest.status);
                        alert(XMLHttpRequest.readyState);
                        alert(textStatus); // paser error;
                    },
});

3.服务器端:

public function actionInterPayProc($callback)
{
//header("content-type: text/javascript");
//header(‘Content-type: text/html; charset=utf-8′);
         $code = $_POST['code'];
        //$code  //#1 此处给出一个有语法错误的表达式
        //echo $code;  //#2  此处标记,用于后面调试说明;
        …
        $result = 1;
            //echo $_POST['callback']. ‘(‘ . json_encode($result) . ‘);';//注意使用的编码方式需要和客户端请求保持一致;
exit(0);
}

调试工具

Firefox有强大FireBug 插件,现在比较新的浏览器如 Chrome 和 Safari,以及 IE 8都内置了调试工具,借助于这些调试工具,可以非常详细的查看 Ajax 的执行过程(chrome和firefox中调出调试工具的快捷键是ctrl+shift+c);
以下使用FireBug;

1.使用firebug,查看回调:

对于Ajax方法,是通过异步执行的服务器端程序,如果服务器端出错,在页面上不会显示的,我们需要借助调试工具来查看;例如,将以上示例中#2的注释去掉,触发ajax请求一次,可以在控制台面板中查看到错误的返回结果:

 

如果是服务器端程序出错,也可以直接看到,出错原因跟一般普通的页面一样,只不过是在ajax返回的面板中查看(web浏览器页面中不会有任何显示)。
这里需要说明的是,如果在服务器端使用了echo等方法将需要查看的变量打印出来了,那么,ajax调用的结果一定是失败的,因为这样看上去的回调函数名称被更改了,造成无法解析;

例如,打印的变量是333,那么最后回调的结果是:333ajaxcallbak(1);客户端寻找333ajaxcallbak这个函数名,无法解析。

2.使用error函数打印错误信息:

$.ajax()有一个error参数,可以指定一个函数,在请求失败时,将调用此方法。这里给出的信息,对于调试来说,非常有用;

error:function (XMLHttpRequest, textStatus, errorThrown)

error事件返回的第一个参数XMLHttpRequest有一些有用的信息:

XMLHttpRequest.readyState:

其返回的状态码对应了一种错误说明:

状态码

0 -(未初始化)还没有调用send()方法

1 -(载入)已调用send()方法,正在发送请求

2 -(载入完成)send()方法执行完成,已经接收到全部响应内容

3 -(交互)正在解析响应内容

4 -(完成)响应内容解析完成,可以在客户端调用了

XMLHttpRequest.status:

这里返回的状态码就是我们日常见到的HTTP状态;比如404,表示没有找到页面;

textStatus:

"timeout", "error", "notmodified" 和 "parsererror"。

(默 认: 自动判断 (xml 或 html)) 请求失败时调用时间。参数有以下三个:XMLHttpRequest 对象、错误信息、(可选)捕获的错误对象。如果发生了错误,错误信息(第二个参数)除了得到null之外,还可能是"timeout", "error", "notmodified" 和 "parsererror"。

通过这个error函数,程序出错就很容易排查;

比如上面的#2处,去掉注释,相当于更改了回调函数名;在erro里就会报:parsererror;

3.使用console.log打印输出:(alert()也可以)

这只是一个增强调试体验的辅助方法。对于js中的关注变量跟踪,我们可通过alert()方法打印出来,不过弹出框频繁会让人烦躁。console.log是一个替代方式,它是firebug插件的一个方法。console.log打印出来的变量结果会显示在firebug的控制台面板中;

可能的出错原因:

1.如果返回的结果格式不正确,在firebug中能看到结果;

2.对于JSON请求,对格式比较严格:

如果通过error函数打出来的报错是:parsererror

可能的原因是服务器端脚本编码的问题;可以在服务端处理函数内处理的第一行加上对应的header信息:

eg:header('Content-type: text/html; charset=utf-8');

当然,最有可能的是格式不正确:

echo "{'re':'success'}";jquery不能解析
echo "{\"re\":\"success\"}";就没有错误

不要输出怪异的json格式的字符串,要不jq1.4+版本不会执行success回调。如{abc:1}或者{'abc':1},要输出

{"abc":1}
{'success':true}改为{"success":true}

 

Javascript 相关文章推荐
javascript Zifa FormValid 0.1表单验证 代码打包下载
Jun 08 Javascript
jquery 指南/入门基础
Nov 30 Javascript
js中的cookie的读写操作示例详解
Apr 17 Javascript
JavaScript中的console.dir()函数介绍
Dec 29 Javascript
jquery ajax 如何向jsp提交表单数据
Aug 23 Javascript
javascript和jquery实现用户登录验证
May 04 Javascript
Angularjs中$http以post请求通过消息体传递参数的实现方法
Aug 05 Javascript
vue.js2.0点击获取自己的属性和jquery方法
Feb 23 jQuery
vue集成百度UEditor富文本编辑器使用教程
Sep 21 Javascript
three.js搭建室内场景教程
Dec 30 Javascript
vue组件 keep-alive 和 transition 使用详解
Oct 11 Javascript
使用Canvas绘制一个游戏人物属性图
Mar 25 Javascript
jquery遍历之parent()和parents()的区别及parentsUntil()方法详解
Dec 02 #Javascript
jQuery向上遍历DOM树之parents(),parent(),closest()之间的区别
Dec 02 #Javascript
javascript中对Attr(dom中属性)的操作示例讲解
Dec 02 #Javascript
浅析jquery的作用与优势
Dec 02 #Javascript
jquery获取css中的选择器(实例讲解)
Dec 02 #Javascript
jquery中的查找parents与closest方法之间的区别
Dec 02 #Javascript
jquery中的过滤操作详细解析
Dec 02 #Javascript
You might like
Zend Framework教程之模型Model基本规则和使用方法
2016/03/04 PHP
PHP水印类,支持添加图片、文字、填充颜色区域的实现
2017/02/04 PHP
PHP abstract 抽象类定义与用法示例
2018/05/29 PHP
YUI 读码日记之 YAHOO.lang.is*
2008/03/22 Javascript
NodeJS学习笔记之Connect中间件应用实例
2015/01/27 NodeJs
jQuery实现checkbox全选的方法
2015/06/10 Javascript
解决jQuery uploadify在非IE核心浏览器下无法上传
2015/08/05 Javascript
推荐阅读的js快速判断IE浏览器(兼容IE10与IE11)
2015/12/13 Javascript
js实现添加可信站点、修改activex安全设置,禁用弹出窗口阻止程序
2016/08/17 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
关于webpack2和模块打包的新手指南(小结)
2017/08/07 Javascript
实现一个完整的Node.js RESTful API的示例
2017/09/29 Javascript
Vue-Access-Control 前端用户权限控制解决方案
2017/12/01 Javascript
解决vue页面刷新或者后退参数丢失的问题
2018/03/13 Javascript
JS验证输入的是否是数字及保留几位小数问题
2018/05/09 Javascript
Mac下通过brew安装指定版本的nodejs教程
2018/05/17 NodeJs
初探Vue3.0 中的一大亮点Proxy的使用
2018/12/06 Javascript
javascript function(函数类型)使用与注意事项小结
2019/06/10 Javascript
微信小程序使用npm包的方法步骤
2019/08/13 Javascript
[58:12]Ti4第二日主赛事败者组 LGD vs iG 3
2014/07/21 DOTA
python读取浮点数和读取文本文件示例
2014/05/06 Python
使用Python生成随机密码的示例分享
2016/02/18 Python
python虚拟环境virtualenv的使用教程
2017/10/20 Python
python添加模块搜索路径和包的导入方法
2019/01/19 Python
Python参数传递实现过程及原理详解
2020/05/14 Python
python基本算法之实现归并排序(Merge sort)
2020/09/01 Python
css3弹性盒子flex实现三栏布局的实现
2020/11/12 HTML / CSS
英国豪华文具和皮具配件经典老品牌:Smythson(斯迈森)
2018/04/19 全球购物
GE设备配件:GE Appliance Parts(家电零件、配件和滤水器)
2018/11/28 全球购物
RIP版本1跟版本2的区别
2013/12/30 面试题
成人大专生实习期的自我评价
2013/10/02 职场文书
办公室岗位职责
2014/02/12 职场文书
电子工程专业毕业生求职信
2014/03/14 职场文书
科级干部群众路线教育实践活动对照检查材料思想汇报
2014/09/20 职场文书
酒店采购员岗位职责
2015/04/03 职场文书
2015年法律事务部工作总结
2015/07/27 职场文书