- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将选择 Chrome 作为示例,但我愿意接受任何浏览器的解决方案。
用例:我的网站上有一个更新按钮,用于更新购物车中的商品数量。我想允许用户输入 0 并单击更新以删除该项目。问题是,某些 js 函数中有一些监听器拒绝输入 0 并单击更新的能力(单击更新后,旧数量仍然保留)。
我的问题是,我可以使用什么开发工具来查找该事件期间正在运行哪个 js 函数?我不认为 Chrome 的检查器会这样做,而且我对 Firebug 不是很熟悉,但我也找不到那里的功能。
我觉得我应该能够像检查 css 样式一样检查 js 触发情况。有人知道我可以使用的工具吗?
最佳答案
我在工作中不得不调试一些特别令人讨厌的、看不见的 Javascript 问题。了解 Chrome 等开发工具的全部深度绝对有帮助。无可否认,找到可能导致问题的地方需要一些创造力,但有一些提示:
在 Chrome 的元素 View 下,尝试检查元素(右键单击,检查);然后,在开发人员 View 的右侧,向下滚动到“事件监听器”。在这里您可以查看哪些代码文件已连接事件。通常,这只会将您从您正在寻找的真正不正当的代码中引向中间框架,但有时它会为您指出正确的方向。
我看到的许多不需要的效果都是由于更改了我不想要的页面上的某些值或属性而造成的。每当发生这种情况时,您都可以右键单击该元素(在“元素” View 下)并说出“中断...”以及您要查找的特定场景。当 Chrome 遇到断点时,您可以在堆栈跟踪中向下查找,直到找到不应调用的可识别内容。
达到十票后编辑!
如果您感兴趣的更改是代码内部的,而不是 UI 中的,那么事情会变得更加棘手。这种情况的意思是,您知道代码中的某个地方正在发生如下令人难以置信的烦人的事情。
company.data.myObject.parameter = undefined;
在这种情况下,您知道 myObject
仍然是同一个对象,但它正在被修改,也许是无意的。为此,我经常插入以下代码,有时只是在所述修改发生之前的某个时刻通过开发人员控制台插入。
Object.defineProperty(company.data.myObject, 'parameter', {
set: (val) => {
debugger;
}
});
这包括一个箭头功能 - 您仅使用它进行调试,并且 Chrome 支持它,因此不妨节省击键次数。这样做的作用是,一旦某行代码尝试修改 myObject
的“parameter
”属性,就会卡住调试器。如果您可以从先前的断点运行这行代码(该断点将在局部变量中包含给定对象),则不一定需要对该变量进行全局引用。
否则,如果我一开始只是 HTML 代码,并且我想将其与 Javascript 代码联系起来,那么我通常只会查找“id”元素等标识功能,并搜索我的文件中的所有 JS 文件。它的开发目录。通常情况下,我可以很快到达。
关于javascript - 如何找到某些事件上正在运行的 Javascript?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18087209/
我为我的一些问题设置了标签。当搜索 labels="ab"时,我得到了相关的标签,但我似乎找不到询问标签的正确语法!="ab"。如何查询不等于ab的? 最佳答案 != 对我有用,尽管它只显示带有标签的
我最近使用 Visual Studio 2013 Express 配置了 GITHUB 和 Demo GITHub 帐户,即用于练习目的。 Good News is that : I have con
我有一个用于播放和暂停的切换按钮。 这是代码: export default (props) => { let [soundState, setSoundState] = useState({ s
一个 XML 文件被发布到我的 spring mvc 正在响应的 URL。 在 .NET 中,我可以这样做: request.Form[0] request.Form["abc"] 或 request
我们的监控脚本遇到问题。 程序流程为 客户将文件(.csv 格式)ftp/sftp 到“源”目录 Bash 脚本将完成的 .csv 文件重命名为 .aaa 文件 另一个 Bash 脚本将“.aaa”文
如果我开始一个线程: new Thread(() -> { while (running) { try { Thread.sl
我正在制作一个看起来像真正的书的 PDF 阅读器。 我在 ScrollView 中有一个 UIImageView 作为书的背景(想象一本打开的书,有空页)。 UIImageView 的层有 2 个子层
创建 Accordion - 在幻灯片上 - 正在滑动的元素下方的元素似乎向下移动了 px,然后又向上移动,从而产生了颤动效果。 $(document).ready(function() { //Pr
我有一个非常奇怪的问题,但只有在运行 Ubuntu 时才会出现(在 CentOS 上一切正常)。我用 Perl 编写了一个脚本并使用了 Mail::IMAPClient模块。 当我运行以下命令时: p
我知道我可以检查 UITextView 是否正在使用 textViewDidBeginEditing: 进行编辑,但我想检查它是否正在使用 if 语句进行编辑? 最佳答案 使用方法isFirstRes
我正在制作一个简单的点击器类型的游戏。问题是,我的 JPanel 忽略了我设置为每秒更新的 Swing 计时器,而是每毫秒更新一次,即使我删除了计时器也是如此。除了计时器的监听器之外,不会在任何地方调
我有以下代码,应该通过组织列表对每个组织进行 td,对每个组织调用 toString 方法,并将结果打印到控制台和名为 Debug1.tab 的文件。 try { StreamWriter p
我有以下代码用于将文件从 url 下载到 sdcard 。此代码适用于小文件,但当文件大时,我下载的文件大小为 0。任何帮助将不胜感激。 Java 代码 setContentView(R.layout
我有一个必须使用 tomcat 部署的 Angular 项目。 Angular 文件在 dist/project-ui/ 中构建文件夹。我复制了 project-ui文件夹到 webapps tomc
我有一堆切换按钮,下面有标签。如果按钮的标签变得太长,那么下一行的第一个按钮将卡在该标签上。 这是我的代码: https://jsfiddle.net/Android272/c150305z/ 我查了
具有特殊字符的 InnerHTML 正在 trim 数据。 elem.innerHTML = displayedObjects.name; 这里的 displayedObjects.name 包含一个
我已经成功地设置了我的证书和 key ,并使用了在这里找到的 mysql 文档: http://dev.mysql.com/doc/refman/5.1/en/replication-solution
在为游戏制作动画和更新计时器时,我读到任何与 GUI 相关的 Activity 都应该在 EDT 上运行,包括重新绘制屏幕。我正在使用单个 ScheduledExecutorService 来更新和绘
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Large numbers erroneously rounded in Javascript 我正在使用
我已经为 .NET RyuJit 安装了新的 Jit 编译器,并按照安装文档中的说明在 regedit 的 .NetFramework 中设置了 AltJit=* 键。 http://blogs.ms
我是一名优秀的程序员,十分优秀!