有没有比较便捷的方法,可以知道前端触发了什么 funcion?比如在一个网页中,我点击某个未知功能的按钮,触发了一连串 function,如何快捷地知道这些的 function 名字?

2020-01-16 02:21:19 +08:00
 good1uck
1729 次点击
所在节点    问与答
10 条回复
KasuganoSoras
2020-01-16 02:35:41 +08:00
浏览器控制台输入:
$("这里是元素选择器")[0].onclick

例如帖子的顶和踩按钮:
$("#topic_638293_votes > a:nth-child(1)")[0].onclick

返回内容:
function onclick(event) {
upVoteTopic(638293);
}
good1uck
2020-01-16 04:27:45 +08:00
@KasuganoSoras 谢谢,如果不仅局限于按钮触发的 function 呢?
moyupoi
2020-01-16 08:47:12 +08:00
调试工具有个事件选项,选上就行,每个都调用,比较烦就是了
luchenwei9266
2020-01-16 09:47:25 +08:00
试一下给这个按钮加断点。触发断点后,然后在 Chrome 调试工具的 Sources 面板的右侧有个 Call Stack,可以看相关的调用栈信息。
daguaochengtang
2020-01-16 10:16:32 +08:00
@KasuganoSoras 如果代码是用 addEventListener 添加的事件处理器,onclick 可能是 null 哦,简单点可以在当前页面控制台测试以下代码:

```
document.body.onclick // return null
document.body.addEventListener('click', function(){}) // 添加了点击事件
document.body.onclick // return null 虽然添加了点击事件,但是 onclick 属性还是 null
```
joe237
2020-01-16 10:21:20 +08:00
以 chrome 浏览器的 devtools 为例,打开 devtools,选择 elements 选项,找到你的元素,不限定于“按钮”,任何元素都成,左侧面板中有个 event listeners,里面包含了该对应元素上的所有事件,每个事件对应的方法都可以展开看详细内容
daguaochengtang
2020-01-16 10:27:58 +08:00
daguaochengtang
2020-01-16 10:30:59 +08:00
接上图,保存为变量后 chrome 会把这个函数赋给一个变量,比如 temp1,你直接 temp1(),和点击感谢是一样的
```
ƒ onclick(event) {
if (confirm('你确定要向本主题创建者发送谢意?')) { thankTopic(638293, '14539'); }
}
```
vanishcode
2020-01-20 23:07:38 +08:00
不知道是不是你想要的
https://github.com/vanishcode/Blog/issues/91
vanishcode
2020-01-20 23:09:49 +08:00
getEventListeners()这个方法是 native 的 cli 函数,代码里用不了( puppeteer 可能能用),上文博客中的$._data 是 jq 的方法,具体你可以看它怎么实现的,或者使用 puppeteer 或者其他 headless 注入一个 jq。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/638293

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX