select2中的ajax请求

简介: 本地数据方式 AJAX获取数据方式 代码本地数据方式:html的select中的option是可选的,如果不写一个空的option标签,则默认选择第一项;如果写了option标签,则默认为空,但调用的时候,最好设置placeholder属性,为了美观;AJ...
<h3>本地数据方式</h3>
<select class="form-control input-sm downList1">
    <option></option>
</select>

<h3>AJAX获取数据方式</h3>
<select class="form-control input-sm downList2">
    <option></option>
</select>
 

代码
本地数据方式:
html的select中的option是可选的,如果不写一个空的option标签,则默认选择第一项;如果写了option标签,则默认为空,但调用的时候,最好设置placeholder属性,为了美观;AJAX获取数据方式:
html的select中的option是必选的
javascript

<script type="text/javascript">
 //one 本地数据方式
 var dataList = [
     { id: 0, text: 'ljiong.com(老囧博客)' }, 
     { id: 1, text: 'Ants(蚂蚁)' }, 
     { id: 2, text: 'can you speak javascript(你能讲JavaScript嘛)' }, 
     { id: 3, text: 'vae(许嵩)' }, 
     { id: 4, text: 'Badminton(羽毛球)' }
 ];
 $(".downList1").select2({
     data: dataList,
     placeholder:'请选择',//默认文字提示
     language: "zh-CN",//汉化
     allowClear: true//允许清空
 })
 
 //two AJAX获取数据方式(请求一次)
 var oneReq = [];
 $.ajax({
     type:"post",
     url:"URL",
     dataType:"json",
     contentType:"application/json",
     success:function(data){
         oneReq = data;
     },
     error:function(data){

     }
 });
 $(".downList2").select2({
     data: oneReq,
     placeholder:'请选择',//默认文字提示
     language: "zh-CN",//汉化
     allowClear: true//允许清空
 })

 //two AJAX获取数据方式(每次请求)
 $(".downList2").select2({
     ajax: {
         type:'GET',
         url: "url",
         dataType: 'json',
         delay: 250,
         data: function (params) {
             return {
                 q: params.term, // search term 请求参数 , 请求框中输入的参数
                 page: params.page
             };
         },
         processResults: function (data, params) {
             params.page = params.page || 1;
             /*var itemList = [];//当数据对象不是{id:0,text:'ANTS'}这种形式的时候,可以使用类似此方法创建新的数组对象
             var arr = data.result.list
             for(item in arr){
                 itemList.push({id: item, text: arr[item]})
             }*/
             return {
                 results: data.items,//itemList
                 pagination: {
                     more: (params.page * 30) < data.total_count
                 }
             };
         },
         cache: true
     },
     placeholder:'请选择',//默认文字提示
     language: "zh-CN",
     tags: true,//允许手动添加
     allowClear: true,//允许清空
     escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入
     minimumInputLength: 1,//最少输入多少个字符后开始查询
     formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果
     formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择
 });
</script>

  

目录
相关文章
|
7月前
|
JSON 前端开发 JavaScript
axios请求成功而$.ajax却不行排错
axios请求成功而$.ajax却不行排错
62 2
|
7月前
|
前端开发
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
|
1月前
|
XML 前端开发 JavaScript
|
2月前
|
JSON JavaScript 前端开发
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
59 22
|
2月前
|
前端开发 JavaScript
回顾前端页面发送ajax请求方式
回顾前端页面发送ajax请求方式
38 18
|
2月前
|
前端开发 JavaScript Java
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
81 4
|
2月前
|
前端开发 JavaScript 数据处理
JQuery 拦截请求 | Ajax 请求拦截
【10月更文挑战第4天】
109 1
|
3月前
|
前端开发
React技术栈-react使用的Ajax请求库实战案例
这篇文章介绍了在React应用中使用Axios和Fetch库进行Ajax请求的实战案例,展示了如何通过这些库发送GET和POST请求,并处理响应和错误。
61 10
React技术栈-react使用的Ajax请求库实战案例
|
3月前
|
前端开发
React技术栈-react使用的Ajax请求库用户搜索案例
这篇文章展示了一个React技术栈中使用Ajax请求库(如axios)进行用户搜索的实战案例,包括React组件的结构、状态管理以及如何通过Ajax请求获取并展示GitHub用户数据。
36 7
React技术栈-react使用的Ajax请求库用户搜索案例
|
3月前
|
JSON JavaScript 前端开发
Jquery常用操作汇总,dom操作,ajax请求
本文汇总了jQuery的一些常用操作,包括DOM元素的选择、添加、移除,表单操作,以及如何使用jQuery发送Ajax请求,涵盖了GET、POST请求和文件上传等常见场景。