通过JavaScript验证HTML输入中的数字不起作用

时间:2011-10-11 06:14:33

标签: javascript jquery html

验证input中的数字不起作用,这里是完整的代码:http://jsfiddle.net/aVF7M/

$('.number').each(function(){
    $(this).bind('keyup change',function(){
        $(this).val($(this).val().replace(/\D/g,''));
    });
});


$('a.add_input').live('click', function (event) {
    event.preventDefault();
    num()
    var $class = '.' + $(this).closest('div.find_input').find('div').attr('class').split(" ")[0];
    var size_un = $($class).length;
    var $this = $(this),
        $div = $this.closest($class),
        $clone = $div.clone().hide().insertAfter($div).fadeIn('slow');
    $clone.find('.remove_table').remove();
    $clone.find('.adda').not(':has(.remove_input)').append('<div class="mediumCell"><a href="" class="remove_input"></a></div>');
    $clone.find('input:checkbox').prop('checked', false);
    $clone.find('input:text').val('')
    $this.remove();
    var size_un = $($class).length---1;
    $($class + ':last input:checkbox').prop('name', 'checkbox_units[' + size_un + '][]');
    console.log($($class + ':last input:checkbox').prop('name'));
});

1 个答案:

答案 0 :(得分:0)

考虑到你已经定义了num()并且它可以工作。

当您动态添加input.number时,您需要使用live -

$('.number').live('keyup change',function(){
    $(this).val($(this).val().replace(/\D/g,''));
});

演示http://jsfiddle.net/aVF7M/1/