我使用自动完成多个输入文本元素,我想从不同的函数获取数据取决于触发事件的元素,因为我在文本元素的数据属性中传递Web服务链接.我不想在页面上写3次不同的自动完成.
HTML: –
<input class="autocomplete" name="firstname" link='getfirstname'/>
<input class="autocomplete" name="middlename" link='getmiddlename'/>
<input class="autocomplete" name="lastname"
link='getlastname'/>
Jquery: –
$('.autocomplete').autocomplete({
source: function (request, response) {
jQuery.get($(this).data('link'), {
typedValue: request.term
}, function (data) {
response(data);
}, 'json');
},
minLength: 1
})
我在How to get the input element triggering the jQuery autocomplete widget?审查但没有帮助.
最佳答案 而不是$(this).data你需要使用$(this.element).data
$('.autocomplete').autocomplete({
source:function(request, callback){
console.log($(this.element).data("link"));
jQuery.get($(this.element).data('link'), {
typedValue: request.term
}, function (data) {
response(data);
}, 'json');
},
select: function(event, ui) {
console.log(event.target.name);
console.log($(this).prop('name'));
console.log($(event.target).data("link"));
}
})