使用此函数在回调中调用其他函数
Using this to call other function in callback
嘿,伙计们,我正试图用addEventListener
调用回调函数中的一个函数
我使用的代码是
<html>
<body>
<table id="outside">
<tr><td id="t1">one</td></tr>
<tr><td id="t2">two</td></tr>
</table>
<script>
function avis(n) {
return n;
}
var c = document.getElementById('outside');
function babe() {
if(this.avis(c) == 'outside') {
console.log('yuck');
}
}
var el = document.getElementById("outside");
el.addEventListener("click", babe, false);
</script>
上面的代码给出了类似Uncaught TypeError: undefined is not a function
的错误
但当我使用类似的代码时
function babe() {
if(this.id == 'outside') {
console.log('yuck');
}
}
它很好用。。
所以我的问题是…是否可以在回调中调用另一个具有this.functionname()
的函数?
this.avis
不是函数,avis
是
function avis(n) {
return n;
}
var c = document.getElementById('outside');
function babe() {
if(avis(c).id == 'outside') {
console.log('yuck');
}
}
var el = document.getElementById("outside");
el.addEventListener("click", babe, false);
<table id="outside">
<tr><td id="t1">one</td></tr>
<tr><td id="t2">two</td></tr>
</table>
进一步说明
这个内部babe指的是您在其上创建事件处理程序的元素id:outside
。它由JavaScript在元素上下文中调用(就像apply一样)。但是您不需要avis
函数。只需检查this.id
,除非你需要avis
做其他事情
var c = document.getElementById('outside');
function babe() {
if(this.id == 'outside') {
console.log('yuck');
}
}
var el = document.getElementById("outside");
el.addEventListener("click", babe, false);
<table id="outside">
<tr><td id="t1">one</td></tr>
<tr><td id="t2">two</td></tr>
</table>
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用