zoukankan      html  css  js  c++  java
  • 边搜索边显示

    事件逻辑:

    1.用户在输入框输入文字后

    obj.onkeyup = function (e) {
    
    }

    2.将输入的文字与后台数据做查询

    for (var i = 0; i < data.length; i++) {
                //indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。检索val
                if (val.trim().length > 0 && data[i].indexOf(val) > -1) {//val.trim()两端去空格处理
                    //如果要检索的字符串值没有出现,则该方法返回 -1。
                    srdata.push(data[i]);
                }
    }

    .push()

    push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。

    3.查询到后返回给客户端

    //获取到的数据准备追加显示, 前期要做的事情: 清空数据,然后显示数据列表
            var ele_datalist = document.getElementById("datalist");
            ele_datalist.style.visibility = "visible";
            ele_datalist.innerHTML = "";
            //如果获取到的数据为空,则不显示
            if (srdata.length == 0) {
                ele_datalist.style.visibility = "hidden";
            }

    4.然后将返回的数据显示在数据列表下

    ele_li.appendChild(ele_a);
    ele_datalist.appendChild(ele_li);

    完整案例:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .search {
                display: inline-flex;
                height: 35px;
                margin: 50px auto;
                position: relative;
            }
            .search input {
                border: #eee 1px solid;
                background-color: #fff;
                outline: none;
                width: 200px;
                padding: 0 5px;
            }
            .search button {
                background-color: #ff3300;
                color: #fff;
                border: none;
                width: 80px;
            }
    /*显示列表*/
            .search ul {
                position: absolute;
                left: 0;
                top: 35px;
                border: #eee 1px solid;
                min-width: calc(100% - 80px);
                text-align: left;
                visibility: hidden;
            }
            .search ul a {
                display: block;
                padding: 5px;
            }
        </style>
    </head>
    <body>
    <div class="search">
        <input type="text" value="" id="key">
        <button>搜索</button>
        <ul id="datalist">
            <!--<li><a href="#">武林外传</a> </li>-->
            <!--<li><a href="#">葵花宝典</a> </li>-->
            <!--<li><a href="#">如来佛掌</a> </li>-->
            <!--<li><a href="#">九阴白骨爪</a> </li>-->
        </ul>
    </div>
    
    </body>
    </html>
    <script type="text/javascript">
        //定义一些数据
        var data = ["15057187176", "15057187175", "15057187174", "15057187173", "武林江湖", "will"];
        var ele_key = document.getElementById("key");
        ele_key.onkeyup = function (e) {
    
            var val = this.value;
            console.log(val);
            //获取输入框里匹配的数据
            var srdata = [];
            for (var i = 0; i < data.length; i++) {
                console.log(data[i].indexOf(val))
                //indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。检索val
                if (val.trim().length > 0 && data[i].indexOf(val) > -1) {//val.trim()两端去空格处理
                    //如果要检索的字符串值没有出现,则该方法返回 -1。
                    srdata.push(data[i]);
                }
            }
            //获取到的数据准备追加显示, 前期要做的事情: 清空数据,然后显示数据列表
            var ele_datalist = document.getElementById("datalist");
            ele_datalist.style.visibility = "visible";
            ele_datalist.innerHTML = "";
            //如果获取到的数据为空,则不显示
            if (srdata.length == 0) {
                ele_datalist.style.visibility = "hidden";
            }
    
            //1.将搜索到的数据追加到显示数据列表, , ,
            var self = this;
            for (var i = 0; i < srdata.length; i++) {
                var ele_li = document.createElement("li");
                var ele_a = document.createElement("a");
                ele_a.setAttribute("href", "javascript:;");
                ele_a.textContent = srdata[i];
                //2.然后每一行加入点击事件
                ele_a.onclick = function () {
                    //3.点击后将数据放入搜索框内
                    self.value = this.textContent;
                    //4.数据列表隐藏
                    ele_datalist.style.visibility = "hidden";
                }
                ele_li.appendChild(ele_a);
                ele_datalist.appendChild(ele_li);
            }
    
        }
    </script>
  • 相关阅读:
    LeetCode 152. 乘积最大子数组 | Python
    LeetCode 31. 下一个排列 | Python
    LeetCode 136. 只出现一次的数字 | Python
    LeetCode 102. 二叉树的层序遍历 | Python
    LeetCode 155. 最小栈 | Python
    LeetCode 69. x 的平方根 | Python
    Python3 高阶函数
    Python3 装饰器
    Python3 递归函数
    Python3 函数
  • 原文地址:https://www.cnblogs.com/wang715100018066/p/6113752.html
Copyright © 2011-2022 走看看