javascript - 使用事件监听器并从未命名函数中解析它

标签 javascript

我有一个简单的事件监听器,但需要将 this 解析为我的函数,但不知道如何解析。

这是我目前所拥有的:

var inpt = document.getElementById('curq');
inpt.addEventListener("keyup", function(e,max){ int_inpt_only(e,max); } , false);

function int_inpt_only(e,max) {
                this.value = this.value.replace(/[^0-9]/g,'');
                if(this.value > max) this.value = max;
                if(this.value<1)this.value=1;
}

问题是 this 没有在我的函数中定义,因为范围没有执行,所以我想知道如何链接它们而不必两次查找元素。

最佳答案

使用 Function.call :

inpt.addEventListener("keyup", function (e) {
    int_inpt_only.call(this, e, 100);
}, false);

Demo


您发布的处理程序逻辑也有一个小问题:

inpt.addEventListener("keyup", function(e,max){ int_inpt_only(e,max); } , false);
                                          ^^^

事件处理程序不接收第二个参数,因此 max 未定义。


或者,如果这就是您的事件处理程序所做的全部事情,并且 int_inpt_only 可以通过词法作用域访问 max 变量(例如,在外部作用域中定义),只需传递一个函数引用改为作为事件处理程序:

inpt.addEventListener("keyup", int_inpt_only, false);

Demo

关于javascript - 使用事件监听器并从未命名函数中解析它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17559188/

相关文章:

javascript - 如何在上一个 Action 仍在发生时阻止 JQuery Action

javascript - 在操作现有页面时移动在函数中创建的元素

javascript - 如何从数组中设置firebase数据库中的数据?

javascript - 在 javascript 中将坐标存储为 2D 矢量类

javascript - Rails-找出JavaScript配置

javascript - 按下某个键时如何使用 JavaScript/HTML/CSS 加载新页面?

JAVASCRIPT:单击其他类后使类可见

javascript - 从重定向 Angular 5 中获取查询参数

javascript - cocos2dJs 跨平台游戏语言更改期间设备崩溃(Android 平台)

java - HtmlUnitDriver 中预期的内容类型为 'application/javascript'