首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jquery:如何将表单元素信息传递给另一个函数?

jquery:如何将表单元素信息传递给另一个函数?
EN

Stack Overflow用户
提问于 2012-04-12 03:07:48
回答 3查看 1.5K关注 0票数 2

我正在尝试对表单元素模糊做一些事情。我遇到的问题是将元素的信息传递给第二个函数,比如ID、class等。我对这个例子进行了简化:

代码语言:javascript
运行
复制
function otherfunction() {
    var inputID = $(this).attr("id");
    alert(inputID);
}


$(".formelement").blur(function () { 

// Do some stuff here

otherfunction();

}); 

当然,警告框显示inputID未定义。如何才能将元素的信息传递给其他函数?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-04-12 03:09:56

将输入作为参数传递:

代码语言:javascript
运行
复制
function otherfunction(el) {
    var inputID = $(el).attr("id");
    alert(inputID);
}


$(".formelement").blur(function () {
    // Do some stuff here

    otherfunction(this);
}); 

或者,使用Function.prototype.apply

代码语言:javascript
运行
复制
function otherfunction() {
    var inputID = $(this).attr("id");
    alert(inputID);
}


$(".formelement").blur(function () {
    // Do some stuff here

    otherfunction.apply(this);
}); 
票数 3
EN

Stack Overflow用户

发布于 2012-04-12 03:11:40

在以下情况下使用$.proxy

代码语言:javascript
运行
复制
$(".formelement").blur($.proxy(otherfunction, this));

以及javascript的callapply

代码语言:javascript
运行
复制
$(".formelement").blur(function () { 

    // Do some stuff here

    otherfunction.call(this); // or otherfunction.apply(this); 
});
票数 2
EN

Stack Overflow用户

发布于 2012-04-12 03:15:11

我认为你可以这样使用:

代码语言:javascript
运行
复制
function otherfunction(obj) {
    var inputID = $(obj).attr("id");
    alert(inputID); }


$(".formelement").blur(function () { 

otherfunction($(this));

});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10112333

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档