题解 | #智能提示#

智能提示

http://www.nowcoder.com/practice/efccf73b4ceb4446b6d71127f874e6d3

思路

动态生成正则表达式

由于下面的转义之后前面会带\所以这里要连\一起捕获

const re = new RegExp(
    value
      .replace(/(\\.)/g, "$1.*?")
  )

用正则表达式去过滤结果

这里题目故意挖了个坑,正则表达式的符号要转义

replace(/([\\\/\(\)\+\*\?\:\\[\]\^\$])/g, "\\$1")

完整代码如下

        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) return s.classList.add("hide");
        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("change", onInput);
        el.addEventListener("input", onInput);
        onInput({ currentTarget: el });
      }
全部评论

相关推荐

07-02 18:09
门头沟学院 Java
苍穹外卖和谷粒商城这俩是不是烂大街了,还能做吗?
想去重庆的鸽子在吐槽:你不如把这俩做完自己搞明白再优化点再来问 何必贩卖焦虑
点赞 评论 收藏
分享
06-12 10:50
门头沟学院 Java
你的不定积分没加C:我怎么在学院群看到了同样的话
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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