JS

JS+Html+Css 实现 自定义输入下拉框联动查询

2020-07-25  本文已影响0人  五岁小孩

<center><font size="5"> 自定义输入下拉框联动查询</center></font>

html

该div只有部分样式,其中input 中class为 input-select 必须有

该 ul 的class必须添加 ul下的li的内容及其自定义属性自行定义

   <script type="text/javascript" src="/assets/js/jquery-1.11.1.min.js"></script>
   <link href="input-select.css" rel="stylesheet" type="text/css" />
   <script src="input-select.js"></script>
   <script src="test-mail.js"></script>

<div class="form-group">
       <label for="Name" class="col-sm-2 control-label form-label">
           {{TPFunTi18nLang $.i18n.lang "data" "export.setting.tb.name"}}
       </label>
       <div class="col-sm-6">
           <input type="text" class="form-control input-select margin-b-5" value=""
                  id="input-select">

           <ul class="input-select-ul">
               <li value="" >没有数据</li>
           </ul>
       </div>
</div>

css

input-select.css

.input-select-ul{
    display: none;
    width: 96%;
    margin-left: 2px;
    list-style: none;
    position: absolute;
    padding: 5px 0;
    border: 0.1rem solid #0b87e3;
   /* border-top: 0;*/
    z-index: 1000;
    background-color: #ffffff;
}
.input-select-ul li{
    display: block;
    padding: 2px 5px;
    color: #000;
    text-decoration: none;
}
.input-select-ul li:hover{
    background-color: #399bff;
    color: #000;
}

js

input-select.js

$(function () {

    //监听输入框获取焦点事件
    // $(".input-select").focus(function () {
    //     $(this).siblings(".input-select-ul").show()
    // });
    //监听输入框的点击事件
    $(".input-select").on('click',function () {
        $(this).siblings(".input-select-ul").show()
    });
    //监听鼠标离开ul时监听事件
    $(".input-select-ul").mouseleave(function () {
        $(this).hide();
    });
    //监听li的点击事件
    // $(".input-select-ul li").on("click",function(){      //只需要找到你点击的是哪个ul里面的就行
    //     //输入框赋值
    //     $(this).parent().prev().val($(this).attr("value"));
    //     //隐藏下拉框
    //     $(this).parent().hide()
    // });
    $(document).on('click', '.input-select-ul li', function() {
        //输入框赋值
        $(this).parent().prev().val($(this).attr("value"));
        //隐藏下拉框
        $(this).parent().hide()
    });

});
/**
 * @function (通用方法,页面初始化时调用即可)根据指定搜索的值和指定搜索的字段从数组searchData中查询数据
 *@param domId  页面input的id
 *@param searchData 搜索的数据源
 * @param searchAttr 搜索的字段,多个字段以逗号分开
 * @param isLike   是否模糊查询;true-模糊匹配,false-完全匹配;默认false
 * @param showDefaultNum 当监听到input的值为空时显示默认条数,如果为0则默认不显示
 * @param noRewordTips  当搜索数据为空的提示信息
 * @param initUl  是否需要初始化Ul,默认不初始化,由于样式问题不建议初始化
 */
function initInputSelect(domId, searchData, searchAttr, isLike, showDefaultNum, noRewordTips,initUl) {

    //check input的id,搜索的原数据不能为空
    if (domId === "" || searchData === "" ||searchData.length===undefined || searchData.length <= 0 || searchAttr === "") {
        return
    }
    //默认模糊匹配
    if (isLike === "") {
        isLike = false
    }
    //默认当输入的值为空时显示5条,为0时不显示
    if (showDefaultNum === "" || parseInt(showDefaultNum) === undefined) {
        showDefaultNum = 5
    }
    //默认空记录显示信息
    if (noRewordTips===""){
        noRewordTips="没有检索到任何记录"
    }
    //默认不初始化
    if (initUl===""){
        initUl=false
    }
    //初始化 ul和li
    if (initUl===true){
        let ulHtml="<ul class=\"input-select-ul\" style=\"width: 99%;margin-top: -10px\">\n" +
            "<li value=\"\" >"+noRewordTips+"</li>\n" +
            "</ul>";
        $("#" + domId).after(ulHtml)
    }
    //默认li中的名称为搜索的字段的名称(多个时默认第一个)
    let defaultLiName = searchAttr.split(",")[0];
    //监听输入的输入的值的改变
    $("#" + domId).bind("input propertychange", function (event) {
        let inputVal = $(this).val();
        //没有值默认显示前5条
        if (isNull(inputVal) && showDefaultNum > 0) {
            //默认显示前5条
            $(searchData).each(function (i, v) {
                if (i === 0) {
                    $("#" + domId).next().children("li").remove();
                }
                if (i < showDefaultNum) {
                    let appendHtml = "<li  value=\"" + v[defaultLiName] + "\" >" + v[defaultLiName] + "</li>";
                    $("#" + domId).next().append(appendHtml)
                }
            });
            return
        }
        let searchArr = searchInputSelectData(searchData, searchAttr, inputVal, isLike);
        //清除下拉框的数据
        $(this).next().children("li").remove();
        if (searchArr.length) {
            for (let i = 0; i < searchArr.length; i++) {
                let v = searchArr[i];
                let appendHtml = "<li  value=\"" + v[defaultLiName] + "\" >" + v[defaultLiName] + "</li>";
                $(this).next().append(appendHtml)
            }

        } else {
            $(this).next().append("<li value=\"\" >" + noRewordTips + "</li>")
        }
    });
}


/**
 * @function 根据指定搜索的值和指定搜索的字段从数组searchData中查询数据
 *@param searchData 搜索的数据源
 * @param searchAttr 搜索的字段,多个字段以逗号分开
 * @param searchVal 搜索的值
 * @param isLike   是否模糊查询;true-模糊匹配,false-完全匹配;默认false
 * @returns Array{Array|*} 返回搜索结果,数组类型
 */
function searchInputSelectData(searchData,searchAttr,searchVal,isLike) {
    //return
    var returnArr = [];

    //check
    if (searchVal === "" || searchAttr === "" ||searchData===""||searchData.length<=0) {
        return returnArr;
    }
    //转换搜索的字段为数组类型
    let searchAttrArr = searchAttr.split(",");
    //默认完全匹配
    if (isLike === "") {
        isLike=false
    }
    let likePattern = new RegExp(searchVal);
    for (let i = 0; i < searchData.length; i++) {
        if (isLike) {
            //模糊查询
            for (let k=0;k<searchAttrArr.length;k++){
                if (likePattern.test(searchData[i][searchAttrArr[k]])) {
                    returnArr.push(searchData[i]);
                }
            }
        } else {
            //完全匹配
            for (let k=0;k<searchAttrArr.length;k++){
                if (searchVal === searchData[i][searchAttrArr[k]]) {
                    returnArr.push(searchData[i]);
                }
            }
        }
    }

    return returnArr;
}


/**
 *@function 演示
 * */
//定义查询的元数据
var searchData=[{
    "name": "aliyun",
    "host": "smtp.aliyun.com",
    "port": 25,
    "ssl": 465
},
    {
        "name": "gmail",
        "host": "smtp.gmail.com",
        "port": 587,
        "ssl": 465
    },
    {
        "name": "exmail",
        "host": "smtp.exmail.qq.com",
        "port": 587,
        "ssl": 465
    },
    {
        "name": "qq",
        "host": "smtp.qq.com",
        "port": 25,
        "ssl": 465
    },
    {
        "name": "qq",
        "host": "smtp.163.com",
        "port": 25,
        "ssl": 465
    }
];
    //页面加载完成时 添加input的焦点获取事件
    $("#input-select").bind("input propertychange", function (event) {
        //获取输入框输入的值
        let inputVal = $(this).val();

        //没有值默认显示前5条
        if (isNull(inputVal)) {
            //默认显示前5条
            $(mailDefaultData).each(function (i, v) {
                if (i === 0) {
                    $("#input-select").next().children("li").remove();
                }
                if (i < 5) {
                    let appendHtml = "<li  value=\"" + v.host + "\" >" + v.host + "</li>";
                    $("#input-select").next().append(appendHtml)
                }
            });
            return
        }
        //调用方法搜索数据
        let searchArr = searchInputSelectData(searchData,"host",inputVal, true);

        //清除下拉框的原有数据
        $(this).next().children("li").remove();
        if (searchArr.length) {
            for (let i = 0; i < searchArr.length; i++) {
                let v = searchArr[i];
                let appendHtml = "<li  value=\"" + v.host + "\" >" + v.host + "</li>";
                $(this).next().append(appendHtml)
            }

        } else {
            $(this).next().append("<li value=\"\" >没有检索到任何记录</li>")
        }
    });


上一篇 下一篇

猜你喜欢

热点阅读