【发布时间】:2013-01-27 00:15:19
【问题描述】:
好的,我确定这里有一些简单的设置错误,但我不是 100% 是这样。
所以我尝试使用Select2 AJAX 方法作为用户搜索数据库并选择结果的一种方式。呼叫本身会返回结果,但是它不允许我从列表中选择答案。它似乎也不允许您在悬停或向上/向下箭头时“选择”它。所以事不宜迟,这是我的代码:
index.html
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>
<link rel="stylesheet" type="text/css" href="select2/select2.css" media="screen" />
<script src="select2/select2.js"></script>
<script src="select.js"></script>
</head>
<body>
<input type="text" style="width: 500px" class="select2">
</body>
</html>
select.js
jQuery(function() {
var formatSelection = function(bond) {
console.log(bond)
return bond.name
}
var formatResult = function(bond) {
return '<div class="select2-user-result">' + bond.name + '</div>'
}
var initSelection = function(elem, cb) {
console.log(elem)
return elem
}
$('.select2').select2({
placeholder: "Policy Name",
minimumInputLength: 3,
multiple: false,
quietMillis: 100,
ajax: {
url: "http://localhost:3000/search",
dataType: 'json',
type: 'POST',
data: function(term, page) {
return {
search: term,
page: page || 1
}
},
results: function(bond, page) {
return {results: bond.results, more: (bond.results && bond.results.length == 10 ? true: false)}
}
},
formatResult: formatResult,
formatSelection: formatSelection,
initSelection: initSelection
})
})
JSON 响应
{
error: null,
results: [
{
name: 'Some Name',
_id: 'Some Id'
},
{
name: 'Some Name',
_id: 'Some Id'
}
]
}
似乎一切都正确,但是我无法实际选择答案并将其输入框中。我的代码有问题吗?
【问题讨论】:
-
经过进一步调查,当我将下拉类从 select2-result-unselectable 更改为 select2-result-selectable 时,一切似乎都正常工作。
-
我会避免使用类进行 jquery 调用,而是使用 id。 $('#thisSelect').select2({......
-
@ganders 我不知道这有什么关系。
-
如果您碰巧在同一个表单/页面上使用了这些 select2 实现中的 2 个,那么输入一个会将结果放在两者中。类被设计为允许重复使用,而 id 应该是单一用途的。
标签: javascript jquery ajax jquery-select2 jquery-select2-3