select2 插件加载后端数据

复制代码
//html

  <select class="form-group form-control" name="roomId" id="roomList" data-op="eq" data-type="L" title="请选择租赁空间">
    <option value="">全部</option>
  </select>

function selectRoomId(select) {
    $(select).select2({
        ajax: {
            url: webroot + "/spaceRoom/listRoom?buildingId=&floor=",
            dataType: 'json',
            delay: 250,
            data: function(params) {
                var query = {
                    code: params.term
                }
                return query;
            },
            processResults: function(data, params) {
                //请求接口返回数据
                params.page = params.page || 1;
                return {
                    results: data.result
                };
            },
            cache: true
        },
        //options
        language: "zh-CN",
        placeholder: '请输入房间号',
        allowClear: true,
        width: '300px',
        //键盘选择事件
        escapeMarkup: function(markup) {
            return markup;
        },
        minimumInputLength: 1,
        templateResult: formatRepo,
        templateSelection: formatRepoSelection
    });
}
// 数据列表
function formatRepo(repo) {
    if (repo.loading) {
        return repo.text;
    }
    var markup = "<div></div>";
    markup += "<div class='select2-result-repository clearfix'>" +
        "<div class='select2-result-repository__title'>" + repo.roomPath + "</div>";
    return markup;

}
//选择填入内容和返回字段
function formatRepoSelection(repo) {
    return repo.text || repo.roomPath || repo.id;
}

//调用

var roomIds = $('#roomList');
selectRoomId(roomIds);

 
复制代码

 //这里是post请求,传参为json(上面是get请求)

复制代码
function selectRoomId(select) {
    $(select).select2({
        ajax: {
            url: webroot + '/spaceRoom/listRoom',
            dataType: 'json',
            delay: 250,
            type:'POST',
            contentType: "application/json",
            data: function(params) {
                var paramss = {
                    code: params.term
                };
                return JSON.stringify(paramss);
            },
            processResults: function(data, params) {
                //请求接口返回数据
                params.page = params.page || 1;
                return {
                    results: data.result
                };
            },
            cache: true
        },
        //options
        language: "zh-CN",
        placeholder: '请输入房间号',
        allowClear: true,
        width: '300px',
        //键盘选择事件
        escapeMarkup: function(markup) {
            return markup;
        },
        minimumInputLength: 1,
        templateResult: formatRepo,
        templateSelection: formatRepoSelection
    });
}
// 数据列表
function formatRepo(repo) {
    if (repo.loading) {
        return repo.text;
    }
    var markup = "<div></div>";
    markup += "<div class='select2-result-repository clearfix'>" +
        "<div class='select2-result-repository__title'>" + repo.roomPath + "</div>";
    return markup;

}
//选择填入内容和返回字段
function formatRepoSelection(repo) {
    return repo.text || repo.roomPath || repo.id;
}
复制代码

 

posted @   abcByme  阅读(1911)  评论(4编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示