实现CSS,显示自动完成芯片的图像

时间:2017-07-21 21:09:10

标签: javascript jquery css autocomplete materialize

Materialize chips的文档显示您可以使用图像制作芯片:

<div class="chip">
    <img src="images/yuna.jpg" alt="Contact Person">
    Jane Doe
</div>

这很好 - 当我们来到自动完成选项时,这也有效:

$('.chips-autocomplete').material_chip({
    autocompleteOptions: {
        data: {
            'Apple': null,
            'Microsoft': null,
            'Google': 'images/juna.jpg'
        },
        limit: Infinity,
        minLength: 1
    }
});

由于我们已将“images / juna.jpg”指定为对象中“Google”属性的值,因此当我们开始输入“Goo”时,此图像会显示在自动完成下拉列表旁边。

但是,当选择此下拉项时,它只会添加一个芯片,上面写着“Google”,并带有关闭按钮,没有图像。是否可以在创建后将图像与芯片中的文本一起显示出来?

1 个答案:

答案 0 :(得分:1)

在我的情况下,我使用chip.add事件在输入芯片时显示图像。基本上我不得不复制传递给autocompleteOptions的数据,并使用chip.tag作为匹配正确图像的密钥。

$('.chips').on('chip.add', function(e, chip){

  var data = {
    'Kyle Robinson': 'dist/images/user-01.jpg',
    'Rebecca Smith': 'dist/images/user-02.jpg',
    'Aaron Lloyd': 'dist/images/user-03.jpg'
  } //same data passed to autocompleteOptions

  var key = chip.tag;
  $(this).children('.chip').append('<img src="' + data[key] + '">');

});

实例:jsFiddle

编辑:无需复制数据,您可以使用:

$('.chips-initial').material_chip('data');