Whenever I type in the autocomplete field an ajax request is sent and there is no code I’ve written to do this. Checking the console I see it’s a 400 GET request to the controller that loaded this view with param (json) appended to the url. I’m absolutely stumped.
<head>
<script data-main="<?=base_url()?>public/requirejs/main.js" src="<?=base_url()?>public/requirejs/require-jquery.js"></script>
<script>
requirejs(['a_mod'],
function(a_mod) {
$(document).ready(function() {
var param = [];
param = $('#elem').attr('value');
a_mod.foo(param, "#someElem");
});
});
<script>
main.js
require(["jquery",
"jquery-ui"],
function() {
}
);
The autocomplete function
'foo' : function(param, elementAutocomplete, elementTags) {
console.log("init ac");
$(elementAutocomplete).autocomplete({
source: param,
minLength: 1,
select: function (event, ui) {
event.preventDefault();
//
}
}).data( "autocomplete" )._renderItem = function( ul, item ) {
return $("<li></li>")
.data( "item.autocomplete", item )
.append( '<a>' + item.label + '</a>' )
.appendTo(ul);
}
},
Your
sourceattribute for the autocompleter is a string:And a string
sourcemeans that it is a URL:Saying
var param = [];just means thatparamis initialized as an empty array, it doesn’t mean thatparamwill always be an array. You need to fix yourparamvalue to be an array.