题解 | 智能提示

function listSuggests(value) {
        if (!value) return [];
        const re = new RegExp(
          value
            .replace(/([\\\/\(\)\+\*\?\:\\[\]\^\$])/g, '\\$1')
            .replace(/(\\.)/g, '$1.*?')
        );
        const items = window.items;
        const result = items.filter((i) => re.test(i));
        return result;
      }

      function onInput(evt) {
        const suggests = listSuggests(evt.currentTarget.value.trim());
        const s = document.getElementsByClassName('js-suggest')[0];
        const ul = s.children[0];
        ul.innerHTML = '';
        if (!suggests.length) {
          s.classList.add('hide');
        } else {
          s.classList.remove('hide');
          ul.innerHTML = suggests.map((i) => `<li>${i}</li>`).join('');
        }
      }

      function suggest(items) {
        window.items = items;
        const el = document.getElementsByClassName('js-input')[0];
        el.addEventListener('input', onInput);
        onInput({ currentTarget: el });
      }

      // 初始化 suggest 函数
      suggest(['不匹配数据', '根据输入框的值', '从给定字符串数组中筛选出匹配的数据,依次显示在li节点中', '如果没有匹配的数据,请移除所有li节点,并隐藏.js-suggest节点']);
全部评论

相关推荐

KKorz:是这样的,还会定期默写抽查
点赞 评论 收藏
分享
02-14 12:40
门头沟学院 Java
程序员花海:1.面试要求必须Java笔试不一定 2.难度对等秋招 远超于日常实习是因为同一批次且转正很多 竞争压力大 3.第一个加点指标,上线了就把接口性能加上去 使用本地缓存这个不算亮点 只是技术选型,要把为什么采用这个和背后的思考写出来而不是单纯堆叠技术没意义 4.八股要一直看 很容易忘记 5.拼团交易这个老问题 堆积技术 另外建议你把奖项合并到教育背景 没必要拆出来放最后
我的简历长这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务