4

我尝试通过使用 jquery ajax 调用更新 datalist 本身来通过 datalist 更新 html 表单中的输入。在使用 ajax 的情况下,输入不会显示选项,但是当我再次单击输入字段时。没有 ajax 的静态测试版本确实按预期工作,在输入字段中输入时显示选项。

HTML 标记

<form id="formID" class="form-horizontal">
  <div class="control-group">
    <label class="control-label" for="input">Location</label>
    <div class="controls">
      <input type="text" list="LIST_CITIES" id="inputCity" 
      placeholder="Enter your location..">
    </div>
  </div>
  <!-- submit -->
  <button type="submit" class="btn">Submit</button>
</form>

<datalist id="LIST_CITIES"></datalist>

没有ajax(确实有效):

$('.controls').on("input click", "#inputCity", function(e) {
var val = $(this).val();

dataList.empty();

if(val === "" || val.length < 3) return;

if(testObj.results.length) {
  for(var i=0, len=testObj.results.length; i<len; i++) {
    var opt = $("<option></option>").attr("value", testObj.results[i]['city']);
    tempObj[testObj.results[i]['city']] = testObj.results[i]['id'];

    dataList.append(opt);
  }
}

  });

使用 ajax(键入时不起作用):

$('.controls').on("input click", "#inputCity", function(e) {
var val = $(this).val();

dataList.empty();

if(val === "" || val.length < 3) return;

$.ajax({
  type: "GET",
  url: GET_cities,
  data: {startswith: val, maxRows: 5},
  success:function(data){
    if(data.results.length) {
      for(var i=0, len=data.results.length; i<len; i++) {
        var opt = $("<option></option>").attr("value", data.results[i]['city']);
        tempObj[data.results[i]['city']] = data.results[i]['id'];

        dataList.append(opt);
      }
    }
  }
});
4

3 回答 3

2

“打字时不起作用”——这是因为 ajax 是异步的。因此,当有人在输入框中输入数据时,它正在对您的服务器进行 ajax 调用,并且在响应返回之前它将无法显示输出。您仍然可以在 ajax 调用中尝试 async:false 。它会锁定浏览器,直到您的响应从服务器返回,但这不是一个好主意。

$.ajax({
      type: "GET",
      url: GET_cities,
      **async:false,**
      data: {startswith: val, maxRows: 5},
      success:function(data){
        if(data.results.length) {
          for(var i=0, len=data.results.length; i<len; i++) {
            var opt = $("<option></option>").attr("value", data.results[i]['city']);
            tempObj[data.results[i]['city']] = data.results[i]['id'];

            dataList.append(opt);
          }
        }
      }
    });
于 2013-04-04T20:02:23.167 回答
0

你需要这样做:

消除

var opt = $("<option></option>").attr("value", data.results[i]['city']);

并替换:

dataList.append(opt);

和:

dataList.append("<option value='" + data.results[i]['city'] + "'>");

并添加:

$.ajax({
    ...
    async:false,
    ...
});

对我来说它有效!

于 2013-05-03T21:21:34.750 回答
0

您可能想尝试 setInterval 和 clearInterval。

例如:

var wait = false;
$('.controls').on("input click", "#inputCity", function() {
    var val = this.value; // All hail Vanilla JS
    dataList.empty();
    var tempObj = []; // This wasn't in your question, but I had to declare it to get rid of undefined variable errors

    if(val === "" || val.length < 3) return;
    if(wait) window.clearInterval(wait);
    wait = setInterval(function(){
        $.get(GET_cities,{startsWith:val,maxRows: 5},function(result){
            // If what you get is already an array, you can skip this line
            result = JSON.parse(result);
            if(result.results.length){
                for(var city in data.results){
                    if(data.results.hasOwnProperty(city){
                        var opt = $("<option></option>").attr("value",city['city']);
                        tempObj[city['city']] = city['id'];
                        dataList.append(opt);
                    }
                }
            }
        });
    },200); // Change 200 mili-seconds to a delay of your desire
}
于 2014-10-28T23:22:37.220 回答