我正在尝试使用LoopJ(http://loopj.com/jquery-tokeninput/demo.html)autocompelte来创建功能搜索框。正如您在演示页面上看到的,以下代码运行自动完成:
$(document).ready(function() {
$("#demo-input-pre-populated").tokenInput("tvshows.php", {
searchDelay: 1000,
minChars: 3,
tokenLimit: 1,
prePopulate: [
{id: 9000, name: "Kriss Akabusi"}
]
});
});
假设您要将文本框值作为GET请求发送到tvshows.php
。由于此代码只会获取文本框的初始值(假设为id=mytextbox
),因此我尝试编辑此代码,以使其在文本框值更改时满足我的要求:
var $elem = $("#demo-input-pre-populated");
$("#mytextbox").on('change', function() {
var country = $.trim(this.value);
$elem.tokenInput("tvshows.php?country=" + country, {
searchDelay: 1000,
minChars: 3,
tokenLimit: 1,
});
});
它很有效。那么,问题是什么?
正如您在JavaScript代码中看到的,我删除了prePopulate
表单的第二个JS代码(prePopulate是搜索框的默认值)。由于在我更改文本框的值之前不会设置prePopulate
- 通过在其中键入内容(id = mytextbox
)。
那么,我怎么能一起处理所有这些东西呢?在更改文本框的值之前,我尝试了不同的方法使prePopulate
正常工作。但我还没有成功。
答案 0 :(得分:0)
您可以使用onAdd函数执行此操作
var $elem = $("#demo-input-pre-populated");
var arr = [];//Array to hold selected values
$("#mytextbox").on('change', function() {
var country = $.trim(this.value);
$elem.tokenInput("tvshows.php?country=" + country, {
searchDelay: 1000,
minChars: 3,
tokenLimit: 1,
prePopulate: arr,
onAdd:function(item)
{
arr.push(item);
}
});
});