动态添加输入,jquery变得不起作用

时间:2015-04-03 18:43:42

标签: javascript jquery html autocomplete

我一直在搜索,实际上已经发现了一些类似的问题,但仍无法解决我的问题。我仍然在努力学习jquery而且仍然很新。

Anywa,我正在尝试在表格上动态添加输入。到目前为止,我已经能够显示使用新输入文本添加行。输入文本假设具有自动完成功能。但新动态添加的输入永远不会成功显示自动完成选项。

(为了说清楚,我将代码放入JSFiddle,这是链接:

http://jsfiddle.net/yodann/6t74T/637/

这是我的代码:

<?php
                            echo '<tr class="row_odd"><td class="ui-widget">';
                            echo form_input(array('id' => 'aff[]', 'name' => 'aff', 'value' => '',
                                    'class' => 'form-control auto_form', 'placeholder' => 'Masukkan nama tempat',
                                    'style' => 'width:100%'));
                            echo '</td><td><img src="'.getfrontendlink('images/del_button.png').
                                 '" width="24px" height="auto"></td></tr>';
?>

function addRow() {
    var count = $('#aff_table tr').length;
    var tx = count % 2 == 0 ? 'row_even' : 'row_odd';
    $('#aff_table tr:last').after('<tr class="' + tx + '">' +
        '<td class="ui-widget">'+
        '</td><td><img src="<?=getfrontendlink('images/del_button.png')?>" width="24px" height="auto"></td></tr>');

    var dat = $('#aff_table tr:last').children('td.ui-widget');
    $("input.auto_form:last").clone(true).appendTo(dat);
    $("input.auto_form:last").val("");           
}

<?php 
        if ($datas != '') {
            $i = 0;
            $php_array = array();
            foreach ($datas->result_array() as $row):
                $php_array[$i++] = ($row['pp_id'].'>>'.$row['pp_name'].', '.
                    (strlen($row['address']) > 25 ? substr($row['address'],0,25) : $row['address']).', '.
                    $row['city_name'].', '.$row['province_name']);
            endforeach;

            $js_array = json_encode($php_array);
            echo "var availableTags = ". $js_array . ";\n";
        }
?>

$( ".auto_form" ).autocomplete({
    source: availableTags
});

1 个答案:

答案 0 :(得分:0)

如果我正确理解了这个问题: 在函数addRow()的末尾,你应该再次初始化.autocomplete属性。 如果实例化自动完成一次,那么在添加动态输入字段后,jquery不会自动添加所需的属性。

function addRow() {
    var count = $('#aff_table tr').length;
    var tx = count % 2 == 0 ? 'row_even' : 'row_odd';
    $('#aff_table tr:last').after('<tr class="' + tx + '">' +
        '<td class="ui-widget">'+
        '</td><td><img src="<?=getfrontendlink('images/del_button.png')?>" width="24px" height="auto"></td></tr>');

    var dat = $('#aff_table tr:last').children('td.ui-widget');
    $("input.auto_form:last").clone(true).appendTo(dat);
    $("input.auto_form:last").val("");  

    $(".auto_form").autocomplete({source: availableTags});      
}

尝试将clone更改为simple append: http://jsfiddle.net/rk27xbce/