javascript - 如何获取网页 HTML 可用的所有 JavaScript 函数?

标签 javascript html dom

我想知道是否可以获取 HTML 中包含的所有 JavaScript 函数。例如,如果我的 HTML 包含以下内容:

<script src="https://www.example.com/script.js"></script>
<script>
  function foo() {}
  function bar() {}
</script>

如何使用 JavaScript 检索此网页可用的所有 JS 函数。在这种情况下,我需要检索 foobarhttps://www.example.com/script.js。执行 document.getElementsByTagName("script"); 只会将脚本作为 HTML 对象返回,但我需要获取 HTML 中包含的每个脚本的所有函数。这能做到吗?

最佳答案

您可以像这样迭代窗口对象并检测所有函数:

var list = [];
for (let i in window) {
    if (typeof(window[i]) === "function")
        list.push(i);
}
console.log(list)

通过围绕您的脚本执行此操作,我们可以检测中间添加的函数。

<script>
var list1 = [];
for (let i in window) {
    if (typeof(window[i]) === "function")
        list1.push(i);
}
</script>

<script>
// The script to measure
function newFunction() {}
</script>

<script>
var list2 = [];
for (let i in window) {
    if (typeof(window[i]) === "function")
        list2.push(i);
}
let functionList = list2.filter((item) => {return list1.indexOf(item) == -1})
console.log(functionList.join(" "));
</script>

关于javascript - 如何获取网页 HTML 可用的所有 JavaScript 函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65153150/

相关文章:

javascript - 尝试使用 Angular-gridify 时出现 Angular Injector 错误

javascript - event.preventdefault() 问题 - 尝试阻止 anchor 标记加载

javascript - 使用 jQuery 更改文本

javascript - 我可以从脚本中获取 JavaScript 库的加载位置吗?

javascript - 加载对象内容后运行 Javascript 函数

javascript - 表单不断抛出 "Direct Access to this page is not allowed."找不到Bug

javascript - 在 fiddle 中工作,但在保存到文件时不工作

javascript - Mongoose 查找并创建多维数组

html - 在 flexbox li 元素中底部对齐图像

html - 选择元素的隐藏选项离开 "black"背景