12

我有这个jQuery脚本:

$(document).ready(function() {
    $(':input:enabled:visible:first').focus();
    $('.letters').keyup( function() {
        var $this = $(this);
        if($this.val().length > 1)
            $this.val($this.val().substr(0, 1));
            $(this).next('input').focus();
        });
});

它将焦点放在input='text'页面加载的第一个字段上。当用户输入一个字符时,它会将焦点移动到下一个输入字段。它还将限制每个字段中允许的字符数(当前为 1 个字符)。

我想知道是否可以清除焦点上输入字段的当前值。无论是当用户单击光标以聚焦该字段时,还是当$(this).next('input').focus();集合聚焦于下一个输入字段时。

也可以验证字符只允许字母字符吗?

4

3 回答 3

16

要过滤输入,请使用

​$('input').on('keydown', function(e) {
    if( !/[a-z]|[A-Z]/.test( String.fromCharCode( e.which ) ) )
        return false;
});​​​​​​​​

要清除click&上的输入字段focus,请使用

$('input').on('click focusin', function() {
    this.value = '';
});

请注意,当您单击当前形式的非焦点输入控件时,此事件将触发两次。

演示:http: //jsfiddle.net/xbeR2/

于 2012-12-20T18:59:25.880 回答
10

要回答您的焦点问题,是的,您可以这样做:

$("input").focus(function() {
  this.value = "";
});

要回答唯一允许字母的问题,这已经 过了

于 2012-12-20T18:57:39.350 回答
0

用这个

$( document ).ready(function() {
  var search_text_s = "WYSZUKAJ";

  // author ZMORA
  // search input focus text
  $("#searchClear").focus(function() {
    if(this.value == search_text_s){
      this.value = "";
    }
  }).blur(function() {
    if(this.value != search_text_s){
      this.value = search_text_s;
    }
  });
});
于 2015-07-09T21:27:12.487 回答