Как мы можем получить идентификатор выбранных тегов с помощью Jquery tagit?

StackOverflow https://stackoverflow.com//questions/11665291

Вопрос

У меня есть поле ввода тегов, и я хочу получить идентификатор выбранных тегов Поэтому я попытался http://jsfiddle.net/u8zj5/19/ Но моя проблема в том, что я хочу получить идентификатор, а не метку или значение для передачи в id="show" но я потерпел неудачу.

<input type="text" id="field1" name="field1" value=""/>
<span id="show">show ID here</span>

jQuery(document).ready(function(){
var availableTags = [{"id":"144","label":"Allicelabel","value":"Allice value"}];
jQuery("input#field1").each(function(){
    var target = jQuery(this);
    var currenttags = target.val();
    target.hide()        
          .after("<ul class=\"tags\"><li>"+currenttags+"</li></ul>");
    var instance = target.next();
    instance.tagit({
        tagSource:availableTags,
        tagsChanged:function () {
            var tags = instance.tagit('tags');
            var tagString = [];
            for (var i in tags){
                tagString.push(tags[i].value);
            }
            $("#show").html(tagString.join(','));
        },
        sortable:true,
        triggerKeys: ['enter', 'comma', 'tab']
    });
});

});

Есть здесь кто-нибудь, кто пользовался jQuery Tagit (демонстрационная страница) Могли бы помочь мне решить эту проблему

Это было полезно?

Решение

У меня была такая же проблема, и я что сделал, так это изменил tag-it.js.Когда вы вызываете функцию select, вам нужно отправить ID с помощью функции _addTag

self._addTag(ui.item.label, ui.item.value, ui.item.id);

Тогда вам просто нужно получить удостоверение личности:

_addTag: function(label, value, id) {
    ...
    this._addSelect(label, value, id);
    ...
}

И здесь добавьте следующее ID на скрытом экране Выберите

_addSelect: function(label, value, id) {
        var opt = $('<option>').attr({
            'selected':'selected',
            'value':id
        }).text(label);
        this.select.append(opt);

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

Другие советы

У меня была такая же проблема, но я не хотел изменять поведение плагина по умолчанию.Итак, вместо этого я использовал предоставленные крючки, чтобы добавить новое поведение.

var availableTags = [
    {
        label: "myTag",
        value: "myTag",
        id: 1
    },
    //etc...
];
var assignedTags = [];


$('#singleinputfield').tagit( {
                            tagSource: function (request, response) {
                                    //setup the search to search the label
                                    var matcher = new RegExp($.ui.autocomplete.escapeRegex(request.term), "i");
                                    response($.grep(availableTags, function (value) {
                                        return matcher.test(value.label);
                                    }));
                            },
                            beforeTagAdded: function(event, ui){
//get id for that tag and signal if it was in the tagSource list
                                var id, result = false;
                                $.each(availableTags, function(){
                                    if(ui.tagLabel === this.label){
                                        result = true;
                                        id=this.id;
                                        return false;
                                    }
                                });
                                if(result){
//put id in the list of ids we are using
                                    assignedTags.push(id);
                                }
                                return result;
                            },
                            afterTagAdded: function(event, ui){
//replace the values in the single input field with the assigned ids
                                    $('#singleinputfield').val(assignedTags.join(','));
                            },
                            afterTagRemoved: function(event, ui){
                                $('#singleinputfield').val(assignedTags.join(','));
                            },
                            beforeTagRemoved: function(event, ui){
                                var id;
//get the id for the removed tag and signal if it was in the tagSource list
                                $.each(availableTags, function(){
                                    if(ui.tagLabel === this.label){
                                        result = true;
                                        id = this.id;
                                        return false;
                                    }
                                });
                                if(result){
//remove the unassigned tag's id from our list
                                    assignedTags = $.grep(assignedTags, function(el){
                                        return el != id;
                                    });
                                }
                            }
                        });

Используйте какой-нибудь другой плагин, например Select2.На самом деле у него есть поддержка для этого.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top