gpt4 book ai didi

javascript - TypeError : prc. cng() 不是 Firefox 中的函数,Uncaught TypeError: Object # has no method 'cng' in Chrome

转载 作者:行者123 更新时间:2023-11-29 22:13:42 27 4
gpt4 key购买 nike

我正在编写一个供我正在从事的项目内部使用的小型库,我是一名业余 Javascript 开发人员,所以请注意我的错误。

我写了一个小的 html 文件以及下面的 javascript,

<html>
<head>
<script>
var prc = {
cng : function(evt){
console.log(evt);
}
}
</script>
</head>
<body>
<input type='text' id='prc' onkeydown="prc.cng(window.event)"/>
<body>
</html>

我尝试在 Firefox 和 Chrome 中执行此操作,而不是在 IE Still 中,

当我在 Firefox 中尝试时,它给出了这个错误 "TypeError: prc.cng is not a function" ,当在 chrome 中尝试时,它给出了 "Uncaught TypeError: Object #<HTMLInputElement> has no method 'cng'" .

我尝试在 StackOverflow 中搜索此内容,但他们面临的问题与我面临的问题截然不同。几乎大部分面临的问题都涉及 jQuery,这里请注意,我没有使用任何类型的库,而是使用普通的旧 Javascript 编写的。

如果能加深我对问题的理解,我们将不胜感激。

最佳答案

具有 id 的元素这与现有的 JS 变量相同,是将变量的内容替换为对元素的引用。

快速的解决方案是更改变量名称或元素 ID。


更稳健的解决方案是将所有数据限制在尽可能小的范围内。如果您不迫切需要它是全局的,那么就不要让它成为全局的,并且它不会从脚本外部被覆盖。

因为使用内部事件属性,您只能引用 <script> 中的变量如果它们是全局元素,这也是停止使用它们并转向现代元素的好时机。

// Self-executing anonymous function expression used to limit scope
(function () {

// Locally scoped prc that won't clash with the element
var prc = {
cng : function(evt){
console.log(evt);
}
}

// Event handler binding
document.getElementById('prc').addEventListener('keydown', function (evt) {
prc.cng(evt)
});

}());

请注意,此脚本不会延迟执行直到 loaddomReady所以将它放在输入的之后,以便在尝试查找事件处理程序时输入存在。

关于javascript - TypeError : prc. cng() 不是 Firefox 中的函数,Uncaught TypeError: Object #<HTMLInputElement> has no method 'cng' in Chrome,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16581252/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com