js代码:
- <select class="form-control" id="inputBmid" name="info[b_mid]"></select>
- $("#inputBmid").select2({
- placeholder: data,
- ajax: {
- url: "{:U('CreditorAssets/getMember')}",
- dataType: 'json',
- delay: 250,
- data: function (params) {
- params.offset = 6;
- return {
- q: params.term,
- page: params.page,
- offset:params.offset
- };
- },
- processResults: function (data, params) {
- params.page = params.page || 1;
- var users = data.res || [];
- var options = [];
- for (var i = 0, len = users.length; i < len; i++) {
- var option = {
- "id": users[i]["id"],
- "text": (users[i]["mobile"] + " (" + users[i]["nickname"]+")")
- };
- options.push(option);
- }
- return {
- results: options,
- pagination: {
- more: (params.page * params.offset) < data.total
- }
- };
- },
- cache: true
- },
- escapeMarkup: function (markup) { return markup; },
- //minimumInputLength: 1
// templateResult: formatRepo, //templateSelection: formatRepoSelection
- });
说明:
1.q: params.term 查询参数(params.term表示输入框中内容,q发生到服务器的参数名;所以这里你可以添加自定义参数,如:stype:'person')
2.processResults中results: data返回数据(返回最终数据给results,如果我的数据在data.res下,则返回data.res。这个与服务器返回json有关)
3.minimumInputLength 最小需要输入多少个字符才进行查询,与之相关的maximumSelectionLength表示最大输入限制。
4.escapeMarkup字符转义处理
5.templateResult返回结果回调function formatRepo(repo){return repo.text},这样就可以将返回结果的的text显示到下拉框里,当然你可以return repo.text+"1";等
6.templateSelection选中项回调function formatRepoSelection(repo){return repo.text}
7.关于返回的 json的格式:select2默认json格式为[{id:1,text:'text'},{id:2,text:'text'}],新版严格要求这样的格式,当然你可以添加列,如:[{id:1,text:'text',name:'liu'}]
php 后台代码:
- //查询会员 B5教程网
- public function getMember(){
- $page = I('page',1,'intval');
- $q = I('q','','htmlspecialchars,trim');
- $offset = I('offset');
- $where=array();
- if($q){
- $where['mobile']=array('like',$q.'%');
- }
- $list = M('member')->field('id,mobile,nickname')->page($page,$offset)->where($where)->select();
- if($page == 1){
- array_unshift($list,array('id'=>-1,'mobile'=>'设置B角为空'));
- }
- $count=M('member')->count();
- echo json_encode(array('res'=>$list,'total'=>$count));exit;
- }