使用editableSelect实现可编辑选项框

效果如下,输入什么,只显示包含什么的选项

什么都没输入

输入0

这里的001002等数据是从后台获取的设备实体的设备序列号字段,

下面是代码的HTML部分代码

<select id="numUnit" name="numUnit"  class="form-control" 
    v-model="rMerchantDevice.deviceNum" autocomplete="off">
</select>

JS部分代码,需要导入以下资源,可以资源去https://www.cnblogs.com/hhg-2015/p/7654582.html这篇文章去找

<script type="text/javascript" src="${ contextPath }/res/sys/scripts/jquery.editable-select.min.js"></script>
<link href="${ contextPath }/res/sys/scripts/css/jquery.editable-select.min.css" rel="stylesheet">

JS部分代码

/**
 * 返回JSON形式的数据
 * @param url 地址
 * @param data 参数
 * @param func 返回函数
 * @param async 是否异步
 */
function ajaxDirect(url, data, func, async) {
    if (!async) {
        async = false;
    }
    $.ajax({
        url: url,
        type: "post",
        dataType: "json",
        async: async,
        data: data,
        success: func,
    });
}
ajaxDirect(baseURL+ "/business/tdevice/findFullDevice", {},
    function(data) {
        var htm = "";
        for (var int = 0; int < data.tDeviceEntities.length; int++) {
            var a=data.tDeviceEntities;
            htm += "<option value='" + a[int].deviceNum + "'>" + a[int].deviceNum + "</option>";
        }
        $('#numUnit').html(htm);
        $('#numUnit').editableSelect({
            effects: 'slide',
            //可选参数default、fade
            filter: true //false 不过滤,否则选中后其它选项消失
        });

        // $("#numUnit").attr("readonly","true"); // 设置不可编辑
        // setTimeout(function() {
        //         $('#numUnit').val(data[0].name); // 设置默认值,不延时则不生效。
        //     },
        //     300);
    });

以上可以实现从后台将数据传到选择下的选项中,并且实现输入过滤的功能,但是实现添加功能时获取不到V型= “rMerchantDevice.deviceNum” 里的值,原因应该是和可编辑选择插件有关,解决办法如下

点击确定添加设备实体时先在JS中给 “rMerchantDevice.deviceNum” 赋值即可,如下

saveOrUpdate: function (event) {
	var url = vm.isAdd ? "business/rmerchantdevice/save" : 
                         "business/rmerchantdevice/update";
	vm.rMerchantDevice.deviceNum=document.getElementById('numUnit').value;
         //重点是这一句,添加了这一句就给vm.rMerchantDevice.deviceNum赋值了。
			$.ajax({
				type: "POST",
			    url: baseURL + url,
                contentType: "application/json",
			    data: JSON.stringify(vm.rMerchantDevice),
			    success: function(r){
			    	if(r.code === 0){
						alert('操作成功', function(index){
							vm.reload();
						});
					}else{
						alert(r.msg);
					}
				}
			});
		},

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值