20

jsonで応答を取得していますが、これはjson応答を解析しません。私は何を間違っていますか?ドキュメントhttp://docs.jquery.com/Plugins/Autocompleteで何も見つかりませんでした

$("#users-allowed").autocomplete("/people/following.json", {
  width: 320,
  //max: 4,
  highlight: false,
  scroll: true,
  scrollHeight: 300,
  formatItem: function(response, i, max) {
    console.log(response);
    console.log(response['items']);
    console.log(response.items);
    return i + "/" + max + ": \"" + response.status_code + "\" [" + response.status_description + "]";

    //return "<img src='images/" + value + "'/> " + value.split(".")[0];
  },
  formatResult: function(response) {
    //return value.split(".")[0];
    return response.status_description;
  }
});
4

3 に答える 3

33
$("#users-allowed").autocomplete("/people/following.json", {
  width: 320,
  dataType: 'json',
  highlight: false,
  scroll: true,
  scrollHeight: 300,
  parse: function(data) {
    var array = new Array();
    for(var i=0;i<data.items.length;i++) {
      array[array.length] = { data: data.items[i], value: data.items[i], result: data.items[i].username };
    }
    return array;
  },
  formatItem: function(row) {               
    var name = '';
    if (row.first_name && row.last_name)
      name = '('+row.first_name+', '+row.last_name+')';
    else if (row.first_name)
      name = '('+row.first_name+')';
    else if (row.last_name)
      name = '('+row.last_name+')';

    return row.username+' '+name;
  }
});

dataType と parse オプションを確認してください。

于 2009-10-20T02:24:21.430 に答える
6

オプションを入力するだけでよいと思います。オートコンプリートでのオプションのdataTypeいずれかを使用できるように準備したことを覚えています。$.ajax

$("#users-allowed").autocomplete("/people/following.json", {
    dataType: "json",
    ...
于 2009-10-20T01:45:53.727 に答える