select2使用

烟火_

select2使用

一、简介
  select2是Jquery用来代替选择框的一种组件。它让你可以定制下拉框,并且支持搜索、标记,远程数据源,无限滚动和其他更高级的功能。select2的下载地址为:https://select2.github.io/ 。这里使用到的是select2-4.0.0版本。下载该版本后,解压文件,在dist目录下有js与css文件。使用select就需要引用这些的文件。

二、使用
  1、引入jQuery与select2样式、js文件如下:

<link href="css/select2.min.css" rel="stylesheet" />
<script src="js/jquery.1.11.2.min.js"></script>
<script src="js/select2.min.js"></script>
<script src="js/i18n/zh-CN.js"></script>

  这里用到的Jquery是1.11.2版本,zh-CN.js为select2本地化的文件。其中select2.min.css、select2.min.js与zh-Cn.js文件都是dist目录下的文件。

  2、示例

复制代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8"/>
    <title>select2-4.0.0 示例</title>  
    <link href="css/select2.min.css" rel="stylesheet" />
</head>
<body>
    <div> 
        select2: <select id="test1"   style="width: 20%" multiple="multiple">
            <option ></option> 
            <option value="2">222222</option>  
            <option value="3">33223333</option>
            <option value="4">333333</option>
            <option value="5">223333</option>
            <option value="6">444444</option>
            <option value="7">555555</option>  
            <option value="8">666666</option>
            <option value="9">777777</option>
            <option value="10">98888888888888888888888888888888888777777</option>
        </select>
        <button id="clear2"  >清除</button>
        <button id="setValue"  >设置777777</button>
        <button id="getValue"  >获取</button>
        <button id="enable"  >enable</button>
        <button id="disable"  >disable</button>
    </div>    
    <div> 
        select2: <select id="test2"  style="width: 20%"  /><!-- 多选时加上multiple="multiple" 并在回显时,回传所选的值数组 -->
        <input id="personid" type="hidden" name="personid"  />
    </div>        

<script src="js/jquery.1.11.2.min.js"></script>
<script src="js/select2.min.js"></script>
<script src="js/i18n/zh-CN.js"></script>
<script type="text/javascript">
$(document).ready(function(){ 
    //静态select渲染
    $('#test1').select2({
        placeholder: "请选择",
        language: "zh-CN"
    });

    $("#clear2").on("click", function () { //置空
        $("#test1").val(null).trigger("change"); 
    });

    $("#setValue").on("click", function () { //设置某一个值
        $("#test1").val("9").trigger("change"); 
    });

    $("#getValue").on("click", function () { //获取选中值
        alert($("#test1").val());
    });

    $("#disable").on("click", function () { //启用
        $("#test1").prop("disabled", true); 
    });

    $("#enable").on("click", function () { //禁用
        $("#test1").prop("disabled", false); 
    });

    //select2动态加载数据
    $("#test2").select2({
        placeholder: "请选择",
        language: "zh-CN",
        ajax: {
            url: "${ctx}/person/list.action",
            dataType: 'json',
            delay: 250,
            data: function (term, page) {
                console.log(term);
                return {
                    keyword : term,//输入的内容,会发给服务器进行查找
                    //以下两行可以在数据量大的时候用到(当下拉框往下拉的时候会加载下一页),数据量不大的时候,可以直接注释
                    pagesize : 20,//页面大小
                    page : page //当前页
                 };
             },
            results: function (data, page) { 
          var more = (page * ${tpagesize}) < data.total;//判断是还有记录
                return {
                    results: data.rows , more : more
                };
            }
          },
        escapeMarkup: function (markup) { return markup; }, 
        //  minimumInputLength: 1,
        formatResult: function(row) {//选中后select2显示的 内容
            return row.name;
        }, 
        formatSelection: function(row) { //选择的时候,需要保存选中的id
            $("#personid").val(row.id);
            return row.name;//选择时需要显示的列表内容
        }, 
    });    
});
</script>                                            
</body>
</html>

复制代码

 

  对于动态渲染的下拉框,请求服务器后,服务器返回的数据是json数据。json数据格式如下:

{"total":200,"rows":[{"id":"10001", "name":"zhangsan"},{"id":"10001", "name":"zhangsan"},{"id":"10001", "name":"zhangsan"},{"id":"10001", 
"name":"zhangsan"},{"id":"10001", "name":"zhangsan"},{"id":"10001", "name":"zhangsan"}]}
Select2是一种基于jQuery库的下拉选择框,可以帮助你更快捷、更方便地处理复杂的下拉列表。在这里,我们将提供一个简单的使用教程,帮助您快速上手Select2。 1. 下载和引用Select2 首先,您需要从官方网站下载Select2插件。下载完成后,在您的HTML页面中引用Select2的CSS和JS文件: ```html <link href="select2.min.css" rel="stylesheet" /> <script src="jquery.min.js"></script> <script src="select2.min.js"></script> ``` 2. 创建下拉框 在你的HTML文件中,你需要创建一个下拉框元素: ```html <select id="mySelect"></select> ``` 3. 初始化Select2 初始化Select2非常简单,只需在您的JavaScript文件中添加以下代码: ```javascript $(document).ready(function() { $('#mySelect').select2(); }); ``` 现在你的Select2下拉框已经准备好了!但是它还是空的,接下来我们将介绍如何使用Select2来添加选项。 4. 添加选项 添加选项非常简单,只需在下拉框中添加option元素即可。例如: ```html <select id="mySelect"> <option value="1">选项1</option> <option value="2">选项2</option> <option value="3">选项3</option> </select> ``` 但是,如果您有大量的选项,手动添加它们会变得非常繁琐。在这种情况下,您可以使用Select2提供的AJAX加载选项的功能。我们将在下一步中介绍这个功能。 5. AJAX加载选项 使用AJAX加载选项,可以从服务器动态获取选项并将它们添加到Select2下拉框中。以下是一个简单的AJAX示例: ```javascript $(document).ready(function() { $('#mySelect').select2({ ajax: { url: 'http://example.com/api/options', dataType: 'json', processResults: function(data) { return { results: data }; } } }); }); ``` 在这个例子中,我们向Select2提供了一个AJAX请求的URL,并指定了响应数据的类型(JSON)。processResults函数用于处理服务器响应,并将结果返回给Select2。 6. 高级Select2 Select2插件还提供了许多高级功能,例如: - 主题 - 使用不同的主题来定制您的Select2下拉框 - 事件 - 使用事件来响应用户的行为,例如选中选项或打开下拉框 - 模板 - 使用模板来自定义选项的外观和行为 您可以在官方文档中了解更多关于这些高级功能的信息。 总结 在本教程中,我们介绍了如何使用Select2插件创建和自定义下拉框。我们介绍了如何添加选项,使用AJAX加载选项,并提供了一些高级功能的概述。希望这个教程能够帮助您更好地理解和使用Select2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值