Выборочный рендеринг Selectize.js со статическим html

Я использую блестящую библиотеку selectize.js для создания привлекательного блока выбора с группами опций. Это все работает, но я застрял в точке, что я не могу использовать пользовательский рендерер на странице примеров (контакты электронной почты) http://brianreavis.github.io/selectize.js/, потому что "элемент" не знает атрибута "email". Я знаю, как это сделать в javascript, но как я могу определить два атрибута в static html?

В js это будет

$('#id').selectize({
  ...
  options: [
    { name: "Martin", email: "[email protected]" }
  ],
  ....
}

Я попробовал следующее:

<select>
  <option value="Martin|[email protected]" data-name="Martin" data-email="[email protected]">
    Martin
  </option>
</select>

Но это не работает... Наконец, функция рендеринга взята из примеров:

render: {
    item: function(item, escape) {
        return '<div>' +
            (item.name ? '<span class="name">' + escape(item.name) + '</span>' : '') +
            (item.email ? '<span class="email">' + escape(item.email) + '</span>' : '') +
        '</div>';
    },
    option: function(item, escape) {
        var label = item.name || item.email;
        var caption = item.name ? item.email : null;
        return '<div>' +
            '<span class="label">' + escape(label) + '</span>' +
            (caption ? '<span class="caption">' + escape(caption) + '</span>' : '') +
        '</div>';
    }
}

Я был бы благодарен за любые подсказки!

С уважением, Мартин

Ответ 1

Используйте этот пример:

var clearhack = $('.selectized').selectize({
    valueField: 'id',
    labelField: 'name',
    searchField: ['name'],
    sortField: 'score',//this is set to 'name' on my version, but seems sortField is only used together with load-function and score-function
    sortDirection: 'desc',
    maxItems: 1,
    //only using options-value in jsfiddle - real world it using the load-function
    options: [
        {"id":861,"name":"Jennifer","score":6},
        {"id":111,"name":"Jenny","score":6},
        {"id":394,"name":"Jorge","score":6},
        {"id":1065,"name":"Jorge Carlson","score":6},
        {"id":389,"name":"Ann Jennifer","score":3},
        {"id":859,"name":"Bobby Jenkins","score":3},
        {"id":264,"name":"Peter Jenkins","score":3},
        {"id":990,"name":"Fred","score":1},
        {"id":349,"name":"Kal","score":1},
        {"id":409,"name":"Louis","score":1}
    ],
    create: false,
    render: {
        option: function(item, escape) {
            return '<div>'
            + '<span>ID:'+item.id+'</span> '
            + '<span>Name:'+item.name+'</span> '
            + '<span>DEBUG:'+item.score+'</span>'
            + '</div>';
        }
    },
    score: function(search) {
        return function(item) {
            return parseInt(item.score);
        };
    }
});

Ответ 2

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

html параметры:

<option data-data='<?php echo json_encode($obj, JSON_FORCE_OBJECT) ?>' value="<?php echo $obj->id ?>"><?php echo $obj->name ?></option>

а затем выберите код:

$('select#my-select').selectize({
  valueField: 'id',
  labelField: 'name',
  searchField: ['name'],
  render: {
    option: function(item, escape) {
      var label = item.name;
      var caption = item.description;
      return '<div>' +
      '<span style="display: block; color: black; font-size: 14px;">' + escape(label) + '</span>' +
      (caption ? '<span style="display: block; color: gray; font-size: 12px;">' + escape(caption) + '</span>' : '') +
      '</div>';
    }
  }
});

Не читал много документов, но это будет работать для $obj, например:

{ 'id': '1', 'name': 'fred', 'description': 'fred person'}

Просто добавьте дополнительные атрибуты и укажите их в своей функции отображения.

Кажется, selectize читает json из атрибута data-data, чтобы заполнить их, но я считаю, что вы можете изменить, какой атрибут он читает json, передав параметр dataAttr в инициализации.

Ответ 3

У меня была такая же проблема пару минут назад. Я добавляю немного кода в selectize.js

В функции init_select и следующем addOption после кода по умолчанию добавляется:

    /// iterate on data attr on <option>
    $.each($option.data(), function(i, v) {
       option[i] = v;
    });

Вставьте этот код под исходными строками:

var option             = readData($option) || {};
option[field_label]    = option[field_label] || $option.text();
option[field_value]    = option[field_value] || value;
option[field_optgroup] = option[field_optgroup] || group;

После этого мой метод render в selectize отлично работает со статическими атрибутами данных:)