1

我有两个文本字段,每当我在第一个字段中写一个数字时,它应该在第二个字段上给我它的名字。

假设我在“第一个”字段上写了 11,那么它应该自动将单词“十一”(不是数字本身)放在“第二个”字段上。任何数字都是一样的。

我知道这可以用 jQuery 来完成,但我不知道怎么做。有什么建议么??

4

4 回答 4

3
$(function() {
  $('.input').bind('keyup',function() {
     $('.output').val($(this).val());
  });
});

你可以在这里测试它http://jsbin.com/owani3

于 2010-10-01T18:54:16.430 回答
1

这应该做的工作

$('#f1').live('keyup', function(){
    $('#f2').val($(this).val())
})

检查工作演示:http: //jsfiddle.net/E44Un/

于 2010-10-01T18:56:52.543 回答
1

对于任意数量的文本框,这应该有效:

​​$(".syn").live("keyup", function() {
  var self = $(this);
  $(".syn").each(function() {
    $(this).val(self.val());
  });
})​​​​​​​​​​​​​​​

只需syn在您的文本输入中添加一个类

于 2010-10-01T19:06:37.243 回答
1

要关联两个字符串,最简单的方法是使用对象来创建字典/映射,如下所示;

$('#input1').bind('keyup',function() {
     var map = {
         "1":"One",
         "2":"Fish",
         "3":"Bar"
     };

     $('#input2').val(map[$(this).val()]);
});

你可以在这里看到这个:http: //www.jsfiddle.net/dCy6f/

对于更高级的行为:

$('#input1').bind('keyup',function() {
     var str = '';
     var input = $(this).val();
     var intVal = parseInt(input, 10); // Dont forget the radix
     var map = {
         "1":"One",
         "2":"Fish",
         "3":"Bar"
     };

     if (intVal > 50 && intVal < 100) {
         str = 'Something';
     } else if (map.hasOwnProperty(input)) {
         str = map[input];
     }

     $('#input2').val(str);
});

您可以在此处测试此实施:http: //www.jsfiddle.net/H6skz/

如果您希望仅在用户完成第一个输入字段的输入后更新第二个值,请将“keyup”更改为“change”。

要将其抽象为函数,您可以执行以下操作:

function relate(me, withMe) {
    $(me).bind('keyup',function() {
         var str = '';
         var input = $(this).val();
         var intVal = parseInt(input, 10); // Dont forget the radix
         var map = {
             "1":"One",
             "2":"Fish",
             "3":"Bar"
         };

         if (intVal > 50 && intVal < 100) {
             str = 'Something';
         } else if (map.hasOwnProperty(input)) {
             str = map[input];
         }

         $(withMe).val(str);
    });
}

然后按如下方式使用它:

relate('#input1', '#input2');

要获得更直观的界面,请编写一个 jQuery 插件:

(function ($) {
    jQuery.fn.relate = function (withMe) {
        this.bind('keyup',function() {
             var str = '';
             var input = $(this).val();
             var intVal = parseInt(input, 10); // Dont forget the radix
             var map = {
                 "1":"One",
                 "2":"Fish",
                 "3":"Bar"
             };

             if (intVal > 50 && intVal < 100) {
                 str = 'Something';
             } else if (map.hasOwnProperty(input)) {
                 str = map[input];
             }

             $(withMe).val(str);
        });
    };
}(jQuery));

然后使用如下:

$('#input1').relate('#input2');
于 2010-10-01T20:04:34.120 回答