Select2-Ajax获取数据

Posted szhshp的第二边境中转站

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Select2-Ajax获取数据相关的知识,希望对你有一定的参考价值。

文章最初发表于szhshp的第三边境研究所
转载请注明

遇到一个需求: 在前端使用Select2设计一个联想输入dropdown, 通过Ajax动态抓取数据

如果用纯H5来实现极其简单, 这里需要用Select2插件来实现

可以也使用H5原生onChange来进行动态提交但是这太愚蠢了, 现成的Select有更好的API啊

花了俩小时完成了这个功能, 官方Doc说的很是模糊..

代码细节:

$(‘select‘).select2({
  ajax: {
    url: "https://api.github.com/search/repositories",
    dataType: ‘json‘,
    data: function (params) {
      var query = { //请求的参数, 关键字和搜索条件之类的
        search: params.term //select搜索框里面的value
      }

      // Query paramters will be ?search=[term]&page=[page]
      return query;
    },
    delay: 1500,
    processResults: function (data, params) {
      //返回的选项必须处理成以下格式
      //var results =  [{ id: 0, text: ‘enhancement‘ }, { id: 1, text: ‘bug‘ }, { id: 2, text: ‘duplicate‘ }, { id: 3, text: ‘invalid‘ }, { id: 4, text: ‘wontfix‘ }];

      return {
        results: results  //必须赋值给results并且必须返回一个obj
      };
    }

  }
});

参考文献

http://select2.github.io/options.html

http://select2.github.io/examples.html#data-array

 


以上是关于Select2-Ajax获取数据的主要内容,如果未能解决你的问题,请参考以下文章

使用片段从数据库 SQLite 获取数据时出错

如何从设置中获取数据并发送到此片段

Android 使用两个不同的代码片段获取当前位置 NULL

当我从用户获取数据并将其保存到 SQLite 数据库中时,我应该怎么做才能使列表视图在片段中工作

如何从片段中的 JSON 响应中的对象获取数据

常用python日期日志获取内容循环的代码片段