Select2 ajax异步搜索数据

直接上代码

$(".aui-ajax-select").select2({
    ajax: {
        url: "/ajax_topics",
        method : "post",
        dataType: 'json',
        delay: 250,
        data: function (params) {
            return {
                id: "{{ $id }}", // search term
                title: params.term, // search term
                page: params.page,
                _token : '{{ csrf_token() }}'
            };
        },
        processResults: function (_data, params) {
            var data = _data.data;
            for (var i = 0; i < data.length; i++) {
                data[i].id = data[i].id;        //赋值id
                data[i].text = data[i].title;   //赋值标题
            }
            return {
                results: data
            };
        },
        cache: true
    },
    placeholder: "请输入名称搜索",
    escapeMarkup: function (markup) { return markup; }, // 让template的html显示效果,否则输出代码
    minimumInputLength: 2,
    templateResult: formatSubject, // 自定义下拉选项的样式模板
    templateSelection: formatSubjectSelection // 自定义选中选项的样式模板
});

function formatSubject(item) {
    if (item.loading) return item;
    var markup =  '
'; markup += '

' + item.text + '

'; //显示文本名 markup += '
'; return markup; } //反回选中的值 function formatSubjectSelection(item) { return item.text || item.id; }

 

php代码,具体业务自行查询。

/**
 * 搜索话题
 * @param Request $request
 * @return array
 * 话题,首次查询15条, 中山、瑞金抢头条,VR+医疗正在高速前进中?
 */
public function ajax_topics(Request $request) {
    if (!intval($request->id) && empty($request->title)) return response()->json(['info'=>'请输入用户名与密码!', 'code'=>201]);
    $topics_arr = Topic::SelectTopics(1, $request->id, $request->title);
    if (empty($topics_arr)) return response()->json(['info'=>'未查到数据!', 'code'=>201]);
    return response()->json(['info'=>'ok', 'data' => $topics_arr, 'code'=>200]);
}

完成。

 

 

 

 

 

你可能感兴趣的:(php)