调试F9/F10/F11/F8
这篇随笔记录来自于实现活动促销页弹幕过程学习:
// 页面加载完初始化方法
$(function () {
GetCustList();
createBarrage();
})
// 某功能的初始化方法
function GetCustList() {
var successFun = function (json) {
barrageArr = json.Info;
barrageLen = barrageArr.length;
};
var par = { act: "GetList", "id": id };
JsAjax("/Handle/promotion/nc_promotion_custHandle.ashx", par, successFun);
} function createBarrage() {
if (barrageLen != 0) {
arrLen = barrageLen;
var barrageItem = document.createElement("li");
barrageObjIndex = Math.floor(Math.random() * arrLen);
html = ' <div class="barrageImg"><img src="' + (barrageArr[barrageObjIndex].user_avatar ? barrageArr[barrageObjIndex].user_avatar : '/images/promotion/iconPhoto2.png') + '" alt="picture" /></div> ' + formatName(barrageArr[barrageObjIndex].user_name) + '<span class="applyFont">报名</span>参与活动--- ';
barrageItem.innerHTML = html;
barrageItem.className = "barrageItem commFlex";
barrageUl.appendChild(barrageItem);
move(barrageItem);
} else {
console.log("第一次:" + barrageLen);
}
}
function move(barrage) {
$(barrage).animate({
"left": 0,
"opacity": 1
}, 1200, function () {
barrage.style.webkitTransform = 'translate(-300px)';
barrage.style.transform = 'translateY(-300px)';
});
}

概念:
$(function({ funA(); funcB()…});$(function()}是页面加载后将会执行的初始化方法;其中初始化方法里的哥调用方法会按顺序执行;对于某一个方法,里面的语句也是自上而下一步步执行。
关于调试:
F10——单步执行step over:下一行,如果断点在函数内部,单步执行时遇到子函数时,会将整个子函数视作一步执行,在不存在子函数的情况下,F10和F11效果一样(虽子函数是一步执行完的,对于子函数来说,内部依然是自上而下一步步执行的,只是F10的作用相当只取子函数的结果,对于外部函数来说,能更快执行完内部所涉及的各项操作)。
说明:如上图所示,在A处打断点,F10 > B > F10 > C > F10 > C下方右花括号“}” > F10 > 如上述所贴页面初始化方法内的createBarrage()方法。
F11——单步执行step into:下一行,执行到的外部函数内存在子函数的话,使用F11会进入到子函数,可在子函数内使用F11查看每步执行结果。
说明:如上图所示,在A处打断点,F11 > B > F11 > C > 将进入封装的JsAjax(url, data, successFun)方法中 > Shift + F11 > C下方右花括号“}” > F11 > 如上述所贴页面初始化方法内的createBarrage()方法。
Shift + F11——直接跳出当前断点执行到的函数并进入下一步(如果在子函数使用。则跳到子函数所在父函数位置的下一步;如果断点是在父函数中,则执行父函数的兄弟函数)。
说明:如上图所示,在A处打断点,Shift + F11 > 如上述所贴页面初始化方法内的createBarrage()方法;另一个如F11说明。
断点在不同地方的执行顺序理解:
某功能的初始化方法存在页面初始化方法内和初始化方法外。在某功能初始化方法开始出打断点时,断点标签会跳到方法内的第一行(134,而不是133)。
只要对某功能初始化方法打断点,那么这个页面的各函数都会把页面加载初始化的方法执行完才能正常显示,即使断点的方法之前有其他功能方法也没能先执行完并显示相应数据。
在页面初始化方法内对GetCustLsit()打断点:
F10 > createBarrage() > funC > … > 直到执行到页面初始化的" }); "处可将页面初始化完,动态数据得以显示。
在页面初始化方法外对GetCustList()打断点(133或134,都会跳到134):
这里的断点位置作为方法的第一行,相当于是给某功能方法初始化时进行断点,因为方法存在页面加载初始化方法中,所以,这时需要等待$(function(){…})方法执行完之后,动态加载的数据才能显示(这里我暂时理解为,在初始化时打断点,相当于总的初始化函数执行到该函数时,便停止执行,要跳转到该初始化方法中)。
只要打断点的地方是会自上而下执行到的语句,那页面的其他初始化方法也是不能执行。因为只要该方法不能完成执行完,就没法执行完页面初始化方法。
在变量函数内对变量进行断点,如上图A处的barrageLen处断点,F10 > A处的右花括号“}”处 > F10 > JsAjax(url, data, successFun)中successFun的执行处(successFun为函数变量,函数调用在JsAjax(…)方法中)。

调试F9/F10/F11/F8的更多相关文章
- Qt Creator单步调试快捷键F10经常失灵问题
使用Qt Creator调试程序的时候经常会遇到F10单步调试快捷键不响应的问题. 打开调试菜单如下:有两个快捷键为F10的调试菜单项,于是快捷键冲突了! 解决办法:废话不说,直接上图 由于Start ...
- tkinter事件机制
一.tkinter.Event tkinter的事件机制跟js是一样的,也是只有一个Event类,这个类包罗万象,集成了键盘事件,鼠标事件,包含各种参数. 不像java swing那种强类型事件,sw ...
- 基于Ruby的Watir-WebDriver自动化测试框架
基于Ruby的watir-webdriver自动化测试方案与实施(五) 基于Ruby的watir-webdriver自动化测试方案与实施(四) 基于Ruby的watir-webdriver自动 ...
- javascript设计模式之单体模式
一入前端深似海,刚入前端,以为前端只是div+css布局外加jquery操作DOM树辣么简单.伴随着对前端学习的深入,发现前端也是博大精深,而且懂得越多,才发现自己越无知,所以一定不能停下脚步的学习. ...
- jQuery键盘控制方法,以及键值(keycode)对照表
键盘控制应用范围非常广泛,比如快捷键控制页面的滚动:在填写表单时候,限制输入内容:或者是屏蔽复制.粘贴.退后等功能.这里说说用jQuery比原生态的JS好用,代码简单清晰,不要问我JS怎么写,因为我不 ...
- Visual Studio 必备神器
会使用工具是人类文明的一大进步,今天敏捷大行其道,好的工具可以大大的提高生产力,这里说的工具都是VS平台上的扩展工具,一些机械的部分可以交给工具去处理,自己多关注其他部分.下面分享下我觉得不错的工具, ...
- 一个特别不错的jQuery快捷键插件:js-hotkeys
这其实不是什么新技术,这个插件在很早前就已经发布了,之前有项目用到,所以分享出来添加方式的例子 jQuery.hotkeys.add('esc',function (){ //执行函数 }); jQu ...
- Visual Studio 必备神器---转
会使用工具是人类文明的一大进步,今天敏捷大行其道,好的工具可以大大的提高生产力,这里说的工具都是VS平台上的扩展工具,一些机械的部分可以交给工具去处理,自己多关注其他部分.下面分享下我觉得不错的工具, ...
- 项目必备!永无 bug 注释
佛祖保佑 永无bug 代码注释 // // _oo0oo_ // o8888888o // 88" . "88 // (| -_- |) // 0\ = /0 // ___/`-- ...
随机推荐
- 什么是 Aspect?
aspect 由 pointcount 和 advice 组成, 它既包含了横切逻辑的定义, 也包 括了连接点的定义. Spring AOP 就是负责实施切面的框架, 它将切面所定义的横 切逻辑编织到 ...
- 两个相同的对象会有不同的的 hash code 吗?
不能,根据 hash code 的规定,这是不可能的.
- nginx静态资源服务器配置
编辑 nginx.conf server { listen 80; server_name file.youxiu326.xin; location /image/ { #访问 file.youxiu ...
- 为什么HTTP/3要基于UDP?可靠吗?
目录 前言 为什么转用UDP? HTTP/3解决了那些问题? 队头阻塞问题 QPACK编码 Header 参考 推荐阅读: 计算机网络汇总 HTTP/3竟然是基于UDP的!开始我也很疑惑,UDP传输不 ...
- C语言常用字符串函数
string.h头文件中常用的函数 C 库函数 - strcat() char *strcat(char *dest, const char *src) 把 src 所指向的字符串追加到 dest 所 ...
- 【uniapp 开发】手绘签名组件
代码如下: <template> <view class="content"> <button type="primary" @t ...
- MySQL 中的 SQL 语句详解
@ 目录 总结内容 1. 基本概念 2. SQL列的常用类型 3. DDL简单操作 3.1 数据库操作 3.2 表操作 4. DML操作 4.1 修改操作(UPDATE SET) 4.2 插入操作(I ...
- Python中使用模块和库编程
""" python中使用模块和库编程 导入模块 import modulename [as alias] from modulename import fun1,fun ...
- Hash-题解-方法
有效的字母异位词 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词. 示例 1: 输入: s = "anagram", t = "nagar ...
- 一个程序的执行时间可以使用time+命令形式来获得
编写程序testtime.c #include <stdio.h> //这个头一定要加 #include<time.h> main() { time_t timep; time ...