jQuery自动完成多个输入,每个输入都有唯一的数组

时间:2019-02-28 22:04:44

标签: jquery-ui-autocomplete

我注意到这个问题被问到多个输入框,但是每个输入框何时必须具有唯一的单词数组呢?

我正在尝试使用jQuery Autocomplete插件将功能附加到多个输入,每个输入都有一个唯一的单词数组。该数组是根据本地范围内附近输入中的文本填充的。每个范围都有一个具有不同值的输入以填充数组,以及一个用于自动完成的输入。 该函数仅使用最后一个填充的数组,而不是当前的自动完成功能已分配给该数组。

这是输出的html:

<?php
            foreach($caseanswers as $key=>$answer){
                    if($answer['input_req']===$term['input_req']){

                            echo '<span class="answer">
                            <textarea class="answertext" id="answer'.$answer['id'].'" disabled>'.$answer['answer'].'</textarea>
                            <div class="ui-widget"><textarea class="autocomplete"></textarea></div>
                            <br/><input type="button" onclick=RUDanswer(this) value="Edit"><input type="button"onclick=RUDanswer(this) value="Delete"></span><br/>';
                    }
            }

?>

这是jQuery代码(已经在jquery包装器中,已被忽略)

<script>
$(".autocomplete").each(function(){
            //alert($(this).val());
            acompletebox=$(this);

            function split(val){
                    return val.split(/\s/);
            }
            function extractLast(term){
                    return split(term).pop();
            }

            availableTags=acompletebox.parents('span.answer').find('.answertext').val().split(" ");
//              acompletebox.parents('span.answer').find('.answertext').val().split(" ");
//              console.log(availableTags);
            // don't navigate away from the field on tab when selecting an item
            $(this).on("keydown", function(event){
                    if(event.keyCode===$.ui.keyCode.TAB && $(this).autocomplete("instance").menu.active){
                            event.preventDefault();
                    }
            })
            $(this).autocomplete({
//                availableTags=acompletebox.parents('span.answer').find('.answertext').val().split(" ");

                    minLength: 3, source: function(request, response){
                    //delegate back to autocomplete, but extract the last term
                            response($.ui.autocomplete.filter(availableTags, extractLast(request.term)));
                    },
                    focus:function(){
                    //prevent value inserted on focus
                            return false;
                    },
                    select:function(event, ui){
                            var terms=split(this.value);
                            //remove the current input
                            terms.pop();
                            //add the selected item
                            terms.push(ui.item.value);
                            //add placeholder to get the comma-and-space at the end
                            terms.push("");
                            this.value=terms.join(" ");
                            return false;
                    }
            });
    });
</script>

我想问题是,如何为每个输入的自动完成数据源分配一个唯一的数组?
感谢您为爱好编码员提供的所有帮助!

1 个答案:

答案 0 :(得分:0)

虽然不理想,但.each()函数可以替换为.focus或其他on select函数。每次发生悬停时,它都必须重新编译列表,如果数据来自外部源,这在计算上可能会很昂贵,但是通过此简单更改就可以起作用。