此脚本仅部分适用于最后一个textarea对象:
$('textarea[data-placeholder]').each(function () {
var $this = $(this);
$placeholder = $this.attr('data-placeholder');
$placeholder = $placeholder.replace(/\<br>/g, "\n");
$informer_id = $this.attr('data-informer-link');
console.log('each: ' + $informer_id + ', placeholder: ' + $placeholder);
$this.attr('value', $placeholder);
$this.focus(function () {
if ($this.val() == $placeholder) {
$this.attr('value', '');
}
});
$this.blur(function () {
if ($this.val() == '') {
$this.attr('value', $placeholder);
console.log('each brur placeholder: ' + $informer_id);
$('[data-informer-id=' + $informer_id + '] i.fa')
.addClass('fa-circle')
.removeClass('fa-check-circle');
} else {
console.log('each brur value: ' + $informer_id);
$('[data-informer-id=' + $informer_id + '] i.fa')
.removeClass('fa-circle')
.addClass('fa-check-circle');
}
});
// remove the focus, if it is on by default
$this.blur();
$('[data-informer-id=' + $informer_id + '] i.fa')
.addClass('fa-circle')
.removeClass('fa-check-circle');
});如果我用var $this = $(this);捕获一个对象,为什么会发生这种情况?
实例:http://jsfiddle.net/ynts/M9pZN/
发布于 2014-04-18 04:46:02
问题在于你的变数。您错过了关键字var,所以变量是全局的
var $placeholder = $this.attr('data-placeholder');
$placeholder = $placeholder.replace(/\<br>/g, "\n");
var $informer_id = $this.attr('data-informer-link');upd:删除不必要的var
https://stackoverflow.com/questions/23147415
复制相似问题