我有这个代码用于从输入字段创建Select2
元素:
var codigo_arancelario = $codigo_arancelario.val();
$codigo_arancelario.select2({
placeholder: "Seleccione un estado",
ajax: {
dataType: 'json',
url: function () {
return Routing.generate('obtenerCodigoArancelario');
},
data: function (codigo_arancelario) {
return {
filtro: codigo_arancelario
}
},
results: function (data) {
var myResults = [];
$.each(data.entities, function (index, item) {
myResults.push({
'id': item.id,
'nombre': item.nombre
});
});
return {
results: myResults
};
}
},
formatNoResults: function () {
return "No se encontró el código";
},
formatAjaxError: function () {
return "No hay conexión con el servidor";
}
});
但是每当我尝试使用它时,我都会在Firebug控制台上收到此错误:
TypeError:a未定义
我检查了响应标头,我得到了一个Content-Type application/json
并且我检查了请求标头,因为我在服务器端使用Symfony2并发送X-Requested-With XMLHttpRequest
。 Symfony2函数返回类似这样的JSON:
{
"valid":false,
"entities":[
{
"id":101,
"codigo":"4545",
"descripcion":null
},
{
"id":102,
"codigo":"45455",
"descripcion":"gfhgfhfghfgh"
},
{
"id":103,
"codigo":"45457",
"descripcion":"etert"
}
]
}
我的代码错误在哪里?
答案 0 :(得分:6)
Select2需要[{text="john doe",id="1"},{text="jane doe",id="2"}]
因此您需要将'nombre': item.nombre
更改为'text': item.nombre
它看起来应该如下:
myResults.push({
'id': item.id,
'text': item.nombre
});
答案 1 :(得分:-1)
可能是您的数据格式错误:
数据
键入:PlainObject或String或Array
要发送到服务器的数据。如果不是字符串,它将转换为查询字符串。它附加到GET请求的URL。请参阅processData选项以防止此自动处理。对象必须是键/值对。如果value是一个数组,jQuery会根据传统设置的值使用相同的键序列化多个值(如下所述)。