HTML中input输入框动态模糊匹配

HTML中的input输入框根据后台返回的动态模糊匹配输入的内容,可以选择,也可以输入,此处是使用的是HTML5新增的标签datalist来实现,不需要插件,页面加载完时直接将后台查询到的所有值赋给datalist,还有一种是输入框中有改变时都调用接口向后台查询一次,返回给前台,这里先不做介绍。

代码如下:

test.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--#include file="/saleweb/npage/public_title_name.html" -->
</head>
<body>
<div class="c-row pdt-l pdb-l">
    <div class="col-4">
        <div class="c-form-item">
            <p class="c-form-name">模板名称</p>
            <div class="c-form-info">
                <input type="text" name="tempName" id="tempName"  list="batch_list" autocomplete="off" placeholder="请输入" class="c-input"/>
                <datalist id="batch_list">
                </datalist>
            </div>
        </div>
    </div>
</div>
<div class="col-12" style="text-align: center; padding: 10px;">
    <div class="c-form-item">
        <button class="c-btn-l" onclick="qryseDiscountTempList(1)">查询</button>
        <button class="c-btn-l" type="reset" id="btn_reset">重置</button>
        <button class="c-btn-l" onclick="addDiscountTempMsg()">新建</button>
    </div>
</div>
</body>
</html>
<script src="./js/test.js"></script>

 test.js      我这里后台返回的是一个json数组,

$(document).ready(function () {
    queryList();
});

function queryList() {
    var seDiscountTempMsg=[{NAME: "测试一", STATE_DATE: "20191115104955", STATE: "1", TEMP_ID: "104955011000001"},
        {NAME: "专线一", STATE_DATE: "20191115104918", STATE: "0", TEMP_ID: "104918011000000"},
        {NAME: "5G一", STATE_DATE: "20191114174557", STATE: "0", TEMP_ID: "174558011470000"}];
    var add_options;
    for(var i=0;i<seDiscountTempMsg.length;i++) {
        add_options += '<option value="' + seDiscountTempMsg[i].NAME + '">'+ seDiscountTempMsg[i].NAME + '</option>';
    }
    $("datalist#batch_list").append(add_options);
}

效果如下: 

 

注意:要引入jQuery:jquery-1.11.3.min.js,不然$(document)识别不出来,我这里是通过公共页面引入的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值