我正在使用select2进行标记
我对 select2 有这些要求:
- 我需要使用 select2 ajax 搜索一些标签
- 我还需要在 select2 中使用“标签”,它允许不在列表中的值(Ajax 结果)。
这两种情况都独立工作。但是连接在一起的 aJax 值只会被填充。如果我们键入不在列表中的任何其他值,那么它会显示“未找到匹配项”
我的场景如果用户键入任何不在列表中的新值,允许他们组成自己的标签。
有什么办法可以使这项工作?
我正在使用select2进行标记
我对 select2 有这些要求:
这两种情况都独立工作。但是连接在一起的 aJax 值只会被填充。如果我们键入不在列表中的任何其他值,那么它会显示“未找到匹配项”
我的场景如果用户键入任何不在列表中的新值,允许他们组成自己的标签。
有什么办法可以使这项工作?
Select2 具有“createSearchChoice”功能:
从用户的搜索词中创建一个新的可选选项。允许创建通过查询功能不可用的选项。当用户可以动态创建选择时很有用,例如“标记”用例。
您可以通过以下方式实现您想要的:
createSearchChoice:function(term, data) {
  if ($(data).filter(function() {
    return this.text.localeCompare(term)===0;
  }).length===0) {
    return {id:term, text:term};
  }
},
multiple: true
这是一个更完整的答案,它将 JSON 结果返回给 ajax 搜索,并允许从术语创建标签,如果术语没有返回结果:
$(".select2").select2({
  tags: true,
  tokenSeparators: [",", " "],
  createSearchChoice: function(term, data) {
    if ($(data).filter(function() {
      return this.text.localeCompare(term) === 0;
    }).length === 0) {
      return {
        id: term,
        text: term
      };
    }
  },
  multiple: true,
  ajax: {
    url: '/path/to/results.json',
    dataType: "json",
    data: function(term, page) {
      return {
        q: term
      };
    },
    results: function(data, page) {
      return {
        results: data
      };
    }
  }
});
http://jsfiddle.net/8qL47c1x/2/
HTML:
<select multiple="multiple" class="form-control" id="tags" style="width: 400px;">
    <option value="tag1">tag1</option>
    <option value="tag2">tag2</option>
</select>
JavaScript:
$('#tags').select2({
    tags: true,
    tokenSeparators: [','],
    ajax: {
        url: 'https://api.myjson.com/bins/444cr',
        dataType: 'json',
        processResults: function(data) {
          return {
            results: data
          }
        }
    },
    // Some nice improvements:
    // max tags is 3
    maximumSelectionLength: 3,
    // add "(new tag)" for new tags
    createTag: function (params) {
      var term = $.trim(params.term);
      if (term === '') {
        return null;
      }
      return {
        id: term,
        text: term + ' (new tag)'
      };
    },
});
有一些改进的示例:
html:
<input type="hidden" id="tags" value="tag1,tag2" style="width: 400px;">
js:
$('#tags').select2({
    tags: true,
    tokenSeparators: [','],
    createSearchChoice: function (term) {
        return {
            id: $.trim(term),
            text: $.trim(term) + ' (new tag)'
        };
    },
    ajax: {
        url: 'https://api.myjson.com/bins/444cr',
        dataType: 'json',
        data: function(term, page) {
            return {
                q: term
            };
        },
        results: function(data, page) {
            return {
                results: data
            };
        }
    },
    // Take default tags from the input value
    initSelection: function (element, callback) {
        var data = [];
        function splitVal(string, separator) {
            var val, i, l;
            if (string === null || string.length < 1) return [];
            val = string.split(separator);
            for (i = 0, l = val.length; i < l; i = i + 1) val[i] = $.trim(val[i]);
            return val;
        }
        $(splitVal(element.val(), ",")).each(function () {
            data.push({
                id: this,
                text: this
            });
        });
        callback(data);
    },
    // Some nice improvements:
    // max tags is 3
    maximumSelectionSize: 3,
    // override message for max tags
    formatSelectionTooBig: function (limit) {
        return "Max tags is only " + limit;
    }
});
JSON:
[
  {
    "id": "tag1",
    "text": "tag1"
  },
  {
    "id": "tag2",
    "text": "tag2"
  },
  {
    "id": "tag3",
    "text": "tag3"
  },
  {
    "id": "tag4",
    "text": "tag4"
  }
]
2015 年 1 月 22 日更新:
修复 jsfiddle:http: //jsfiddle.net/X6V2s/66/
2015 年 9 月 9 日更新:
使用 Select2 v4.0.0+ 变得更容易。
https://jsfiddle.net/59Lbxvyc/
HTML:
<select class="tags-select" multiple="multiple" style="width: 300px;">
  <option value="tag1" selected="selected">tag1</option>
  <option value="tag2" selected="selected">tag2</option>
</select>
JS:
$(".tags-select").select2({
  // enable tagging
  tags: true,
  // loading remote data
  // see https://select2.github.io/options.html#ajax
  ajax: {
    url: "https://api.myjson.com/bins/444cr",
    processResults: function (data, page) {
      return {
        results: data
      };
    }
  }
});
createSearchChoice : function (term) { return {id: term, text: term}; }
只需添加此选项
您可以通过让您的 ajax 函数也返回搜索词作为结果列表中的第一个结果来完成这项工作。然后用户可以选择该结果作为标签。