我试图实现自动完成搜索,我将写一些东西,相关数据将显示在自动完成搜索,但我想填补输入框中的条形码扫描仪输入以及。当输入框充满扫描器时,它将提示相关数据。但是我在写东西时所面临的问题--它显示了相关的数据--但是当条形码扫描输出被填充到输入框时,它并不意味着..。我该如何实现呢?
HTML代码:
<input type="text" required autofocus class="form-control m-input" id="customerSearch" placeholder="Customer name">JavaScript代码:
$('#customerSearch').autocomplete({
source: '{!! asset('customerSearch') !!}',
select: function(suggestion,ui) {
// $("#customer_id").val(ui.item.id);
}
})发布于 2018-07-08 06:53:23
自动聚焦是在按键事件中触发的,所以代码扫描器不会触发它。在更改输入后,必须自己触发事件。试试这个:
$('#customerSearch').on('input', function(){
$('#customerSearch').trigger('keydown');
});发布于 2018-07-08 06:54:17
在输入中插入值不会触发事件。
我建议尝试下面的方法来触发一个事件,如果它有效,那么该事件应该触发jQuery自动完成来更新。
创建一个事件:
const event = new Event('keydown')然后发送此事件:
customerSearch.dispatchEvent(event)这在jQuery中也是可能的:
jQuery('#customerSearch').trigger('keydown')
// or
$('#customerSearch').trigger('keydown')您需要在代码扫描器更改输入值之后触发/分派事件。看起来是这样的:
customerSearch.value = codeScannerValue
// or however it actually works
$('#customerSearch').trigger('keydown')
// or
customerSearch.dispatchEvent(new Event('keydown'))https://stackoverflow.com/questions/51229391
复制相似问题