教你如何使用firebug调试功能了解javascript闭包和this


Posted in Javascript onMarch 04, 2015

对于跟我一样,自学javascript且没有其他语言学习经验的人来说,一开始的时候,javascript的调试也是一个比较大的难点,很多基础的东西都需要自己去摸索,这个过程是非常苦闷的。

想着趁机会将上面那篇闭包博文的配图用firebug再来演示一遍,也算是一点调试经验分享。

示例代码如下:

function fn(){
var max = 10;

return function bar(x){

    if (x > max) {

    
console.log(x);

    }

}

}

var fl = fn(),

max = 100;

fl(15);

选择firebug——脚本

教你如何使用firebug调试功能了解javascript闭包和this

右侧监控栏可以window对象以及变量max、fl、fn。

同时下面也可以看到window的属性,以location为例,可以直接在“控制台”运行window.location输出,进一步可以window.location.href输出location的href属性值。当然,一般在引用window对象的属性和方法时,不需要用“window.xxx”这种形式,而直接使用“xxx”。

言归正传,

回到“脚本”栏,通过打“断点”的方式调试javascript和查看变量值。

有几个概念可以先了解下:断点、单步进入、单步跳过、单步退出。这里就不详叙了。

本次主要是采用设置断点、单步进入的方式。

可以在左侧行标处单击设置断点,断点右键可以正则判断。

可以设置多个断点,“断点”栏内可以删除已设置的断点。

这里就直接在script标签的开始处打断点并刷新页面。

此时

1、右边监控区域原window对象处变成this,并指向window。在“控制台”输出this.location会得到location一样的结果。

2、全局变量max、fl初始化为undefined

3、fn()是函数声明,因为解析器会率先读取函数声明,并使其在执行任何代码之前可用(可以访问)

教你如何使用firebug调试功能了解javascript闭包和this

点击右上角的“单步进入”按钮

逐次执行代码并在监控区域查看this、各个变量的值变化以及堆栈的情况。可以和推荐的那篇博客相互参照来看。

然后再来一个this的例子
代码如下:

var name = 'The Window';

var obj = {

  name: 'The local',

  getNameFunc: function () {

    console.log(this.name);

    return function () {

      console.log(this.name);

    };

  }

};

var c = obj.getNameFunc();

c();

依然“单步进入”,可以看到在执行c()这行代码的时候,进入到getNameFunc里面,this从指向window对象变为obj,控制台输出‘The local'。

逐步执行可以非常清晰的看到整个代码的运行逻辑。

以上就是本文关于使用Firebug的调试功能了解javascript闭包和this的方法总结了,希望大家能够喜欢

Javascript 相关文章推荐
在Javascript里访问SharePoint列表数据的实现方法
May 22 Javascript
js动态创建标签示例代码
Jun 09 Javascript
基于jQuery实现下拉框
Nov 24 Javascript
JavaScript实现横线提示输入验证码随输入验证码输入消失的方法
Sep 24 Javascript
浅谈angularjs $http提交数据探索
Jan 20 Javascript
jQuery表格的维护和删除操作
Feb 03 Javascript
使用node.js对音视频文件加密的实例代码
Aug 30 Javascript
使用electron实现百度网盘悬浮窗口功能的示例代码
Oct 24 Javascript
今天,小程序正式支持 SVG
Apr 20 Javascript
vue项目打包后上传至GitHub并实现github-pages的预览
May 06 Javascript
Vue父组件监听子组件生命周期
Sep 03 Javascript
Javascript Symbol原理及使用方法解析
Oct 22 Javascript
深入理解JavaScript系列(37):设计模式之享元模式详解
Mar 04 #Javascript
jQuery插件开发的五种形态小结
Mar 04 #Javascript
深入理解JavaScript系列(36):设计模式之中介者模式详解
Mar 04 #Javascript
百度UEditor编辑器如何关闭抓取远程图片功能
Mar 03 #Javascript
jQuery实现复选框成对选择及对应取消的方法
Mar 03 #Javascript
js实现文本框中输入文字页面中div层同步获取文本框内容的方法
Mar 03 #Javascript
JS实现文字放大效果的方法
Mar 03 #Javascript
You might like
PHP入门学习的几个不错的实例代码
2008/07/13 PHP
codeigniter框架批量插入数据
2014/01/09 PHP
PHP实现的DES加密解密实例代码
2016/04/06 PHP
php 使用expat方式解析xml文件操作示例
2019/11/26 PHP
Jquery Ajax的Get方式时需要注意URL地方
2011/04/07 Javascript
html文件中jquery与velocity变量中的$冲突的解决方法
2013/11/01 Javascript
JavaScript中的typeof操作符用法实例
2014/04/05 Javascript
JS实现slide文字框缩放伸展效果代码
2015/11/05 Javascript
详解jQuery中的empty、remove和detach
2016/04/11 Javascript
移动端H5开发 Turn.js实现很棒的翻书效果
2016/06/20 Javascript
AngularJS 过滤与排序详解及实例代码
2016/09/14 Javascript
JS实现Ajax的方法分析
2016/12/20 Javascript
使用snowfall.jquery.js实现爱心满屏飞的效果
2017/01/05 Javascript
微信小程序 本地数据存储实例详解
2017/04/13 Javascript
nodejs 日志模块winston的使用方法
2018/05/02 NodeJs
jQuery实现获取form表单内容及绑定数据到form表单操作分析
2018/07/03 jQuery
vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】
2018/11/08 Javascript
Node.js Event Loop各阶段讲解
2019/03/08 Javascript
vue的路由映射问题及解决方案
2019/10/14 Javascript
关于小程序优化的一些建议(小结)
2020/12/10 Javascript
vue 中this.$set 动态绑定数据的案例讲解
2021/01/29 Vue.js
[01:17]炒鸡美酒第四天TA暴走
2018/06/05 DOTA
Django Admin实现上传图片校验功能
2016/03/06 Python
Python爬虫获取图片并下载保存至本地的实例
2018/06/01 Python
python matplotlib实现将图例放在图外
2020/04/17 Python
python3+opencv 使用灰度直方图来判断图片的亮暗操作
2020/06/02 Python
HTML5验证以及日期显示的实现详解
2013/07/05 HTML / CSS
HTML5表单验证特性(知识点小结)
2020/03/10 HTML / CSS
Jacadi Paris美国官方网站:法国童装品牌
2017/10/15 全球购物
新加坡最受追捧的体验平台:Hapz
2018/01/01 全球购物
瑞典度假品牌:OAS
2019/05/28 全球购物
日语专业个人的求职信
2013/12/03 职场文书
信息合作协议书
2014/10/09 职场文书
大学生学习新党章思想汇报
2014/10/25 职场文书
selenium.webdriver中add_argument方法常用参数表
2021/04/08 Python
nginx部署多前端项目的几种方法
2021/05/25 Servers