【问题标题】:Access variable from event handler in javascript object从 javascript 对象中的事件处理程序访问变量
【发布时间】:2014-07-18 17:59:02
【问题描述】:

我正在尝试创建一个 jQuery 类来在提交表单时验证输入字段。我在同一个页面中有不同的表单,我需要为每个表单创建一个验证器实例。

HTML

<form method="post" action="index.php" id="form1">
  <input type="submit" value="Send" />
</form>

<form method="post" action="index.php" id="form2">
  <input type="submit" value="Send" />
</form>

<script type="text/javascript">
var form1 = new DataValidator('#form1');
var form2 = new DataValidator('#form2');
</script>

我会从提交事件处理程序访问对象变量,但是当我打印 this.selector 变量时,我看到了一个 undefined 值。

JavaScript

function DataValidator(selector)
{
  this.form = $(selector);
  this.selector = selector;

  $(selector).submit(function() 
  {
    alert('submit ' + this.selector);
    return false;
  });
}

【问题讨论】:

标签: javascript jquery oop event-handling


【解决方案1】:

this 不是局部变量,因此它不会保存在闭包中。您需要将其保存在局部变量中。在 jQuery 事件处理程序中,this 始终绑定到事件的目标。

function DataValidator(selector)
{
  this.form = $(selector);
  this.selector = selector;
  var self = this;

  this.form.submit(function() 
  {
    alert('submit ' + self.selector);
    return false;
  });
}

【讨论】:

  • 其实 OP 代码中的this 只是form 对象,而不是DataValidator 构造函数创建的对象。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2010-12-06
  • 2011-03-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-09-22
相关资源
最近更新 更多