首页 > web前端 > js教程 > 使用 setTimeout 调用基于字符串的函数是否合理?

使用 setTimeout 调用基于字符串的函数是否合理?

DDD
发布: 2024-10-20 07:42:02
原创
901 人浏览过

Can String-Based Function Calls with setTimeout Be Justified?

将字符串传递给 setTimeout:避免和异常的原因

将字符串传递给 setTimeout 或其 setInterval 对应项通常会引起 devido 的不满在全球范围内执行、潜在的性能问题和安全漏洞的担忧。推荐的替代方案是使用匿名函数作为第一个参数。

但是,在某些情况下可能有一个可取之处。如果程序员打算访问存在于全局范围内但已在本地覆盖的函数或变量,他们可以考虑使用已弃用的字符串语法。然而,由于可能存在变量阴影,这种方法被认为是糟糕的编程实践。

在大多数情况下,可以将全局变量作为窗口对象的属性(例如,window.globalVar)访问,从而使其无需诉诸基于字符串的函数调用。因此,不太可能遇到使用字符串作为 setTimeout 或 setInterval 的第一个参数真正有益的情况。

历史上,代码字符串作为这些函数的参数的唯一可用性源于JavaScript 1.0 的限制。仅在 JavaScript 1.2 中才引入 Function 对象引用作为参数。保持与旧版浏览器和脚本的兼容性会阻止开发人员完全消除基于字符串的调用。通过了解注意事项和罕见的异常,程序员在编写涉及 setTimeout 和 setInterval 的代码时可以做出明智的决定。

以上是使用 setTimeout 调用基于字符串的函数是否合理?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板