Подтвердить что ты не робот

Автозаполнение jQuery UI с помощью JSON

Хорошо ломал голову над этим (я ужасен в этом), но да, я пробовал читать все, что могу, и все же не могу заставить его работать.

пытается выполнить автозаполнение с помощью jquery ui

my json выглядит следующим образом

{"dealers":
     {
         "1156":"dealer 1",
         "1122":"dealer 2",
         "1176":"dealer 3",
         "1491":"dealer 4",
         "1463":"dealer 5",
         "269":"dealer 6"
    }
}

Я пытаюсь использовать эту информацию в качестве источника для автозаполнения. Я получаю объект ответа просто отлично, мне просто не удается получить его в правильном формате, чтобы я мог поместить "###" в скрытое поле, привязанное к "значению", которое должно отображаться как часть выпадающий.

пробовал миллион разных способов, но недавняя попытка была ниже

function ajaxCall() {
    $.getJSON("/example/location/example.json?term=" + $('#dealerName').val(),
        function(data) {
        $.each(data.dealers, function(k, v) {                
                alert(k + ' : ' + v);
        });
    });        
}

$('#dealerName').autocomplete({
    source: ajaxCall,
    minLength: 2,
    delay: 100
});

Пожалуйста, большое спасибо!

4b9b3361

Ответ 1

Вам нужно преобразовать объект, который вы возвращаете в массив, в формате, который ожидает jQueryUI.

Вы можете использовать $.map, чтобы преобразовать объект dealers в этот массив.

$('#dealerName').autocomplete({
    source: function (request, response) {
        $.getJSON("/example/location/example.json?term=" + request.term, function (data) {
            response($.map(data.dealers, function (value, key) {
                return {
                    label: value,
                    value: key
                };
            }));
        });
    },
    minLength: 2,
    delay: 100
});

Обратите внимание, что при выборе элемента "ключ" будет помещен в текстовое поле. Вы можете изменить это, изменив свойства label и value, возвращающие функцию обратного вызова $.map.

В качестве альтернативы, если у вас есть доступ к серверному коду, который генерирует JSON, вы можете изменить способ возврата данных. Пока данные:

  • Является массивом объектов, которые имеют свойство label, свойство value или оба, или
  • Является простым массивом строк

Другими словами, если вы можете отформатировать данные следующим образом:

[{ value: "1463", label: "dealer 5"}, { value: "269", label: "dealer 6" }]

или это:

["dealer 5", "dealer 6"]

Тогда ваш JavaScript станет намного проще:

$('#dealerName').autocomplete({
    source: "/example/location/example.json"
});

Ответ 2

Я понимаю, что на него уже был дан ответ. но я надеюсь, что это поможет кому-то в будущем и сэкономит столько времени и боли.

полный код приведен ниже: Это я сделал для текстового поля, чтобы сделать его автозаполненным в CiviCRM. Надеюсь, что это поможет кому-то.

CRM.$( 'input[id^=custom_78]' ).autocomplete({
            autoFill: true,
            select: function (event, ui) {
                    var label = ui.item.label;
                    var value = ui.item.value;
                    // Update subject field to add book year and book product
                    var book_year_value = CRM.$('select[id^=custom_77]  option:selected').text().replace('Book Year ','');
                    //book_year_value.replace('Book Year ','');
                    var subject_value = book_year_value + '/' + ui.item.label;
                    CRM.$('#subject').val(subject_value);
                    CRM.$( 'input[name=product_select_id]' ).val(ui.item.value);
                    CRM.$('input[id^=custom_78]').val(ui.item.label);
                    return false;
            },
            source: function(request, response) {
                CRM.$.ajax({
                    url: productUrl,
                        data: {
                                        'subCategory' : cj('select[id^=custom_77]').val(),
                                        's': request.term,
                                    },
                    beforeSend: function( xhr ) {
                        xhr.overrideMimeType( "text/plain; charset=x-user-defined" );
                    },

                    success: function(result){
                                result = jQuery.parseJSON( result);
                                //console.log(result);
                                response(CRM.$.map(result, function (val,key) {
                                                         //console.log(key);
                                                         //console.log(val);
                                                         return {
                                                                 label: val,
                                                                 value: key
                                                         };
                                                 }));
                    }
                })
                .done(function( data ) {
                    if ( console && console.log ) {
                     // console.log( "Sample of dataas:", data.slice( 0, 100 ) );
                    }
                });
            }
  });

PHP-код о том, как я возвращаю данные в этот jQuery-вызов ajax в автозаполнении:

/**
 * This class contains all product related functions that are called using AJAX (jQuery)
 */
class CRM_Civicrmactivitiesproductlink_Page_AJAX {
  static function getProductList() {
        $name   = CRM_Utils_Array::value( 's', $_GET );
    $name   = CRM_Utils_Type::escape( $name, 'String' );
    $limit  = '10';

        $strSearch = "description LIKE '%$name%'";

        $subCategory   = CRM_Utils_Array::value( 'subCategory', $_GET );
    $subCategory   = CRM_Utils_Type::escape( $subCategory, 'String' );

        if (!empty($subCategory))
        {
                $strSearch .= " AND sub_category = ".$subCategory;
        }

        $query = "SELECT id , description as data FROM abc_books WHERE $strSearch";
        $resultArray = array();
        $dao = CRM_Core_DAO::executeQuery( $query );
        while ( $dao->fetch( ) ) {
            $resultArray[$dao->id] = $dao->data;//creating the array to send id as key and data as value
        }
        echo json_encode($resultArray);
    CRM_Utils_System::civiExit();
  }
}

Ответ 3

Я использую этот script для автозаполнения...

$('#custmoers_name').autocomplete({
    source: function (request, response) {

        // $.getJSON("<?php echo base_url('index.php/Json_cr_operation/autosearch_custmoers');?>", function (data) {
          $.getJSON("Json_cr_operation/autosearch_custmoers?term=" + request.term, function (data) {
          console.log(data);
            response($.map(data, function (value, key) {
                console.log(value);
                return {
                    label: value.label,
                    value: value.value
                };
            }));
        });
    },
    minLength: 1,
    delay: 100
});

My json return: - [{"label":"Mahesh Arun Wani","value":"1"}] после поиска m

но он отображается в раскрывающемся списке [object object]...