写几个获取搜索引擎提示关键词列表的方法,方便以后使用

什么是关键词#

当你在搜索引擎中输入字符的时候,会有一个下拉框显示一些和关键词列表,用来提示你想搜啥。

直接上代码

javascript 复制代码
/**
 * 获取各大搜索引擎的关键字列表 
 */

/** 获取随机小写字母 */
function getRandomLetters(number) {
    const alphabet = 'abcdefghijklmnopqrstuvwxyz';
    let value = '';
    for (let i = 0; i < number; i++) {
        value = value + alphabet[Math.floor(Math.random() * alphabet.length)];
    }
    return value;
}
/** 获取百度关键词列表 */
let dataMap = {};  //缓存列表
function getBaiDuSug(searchValue){
    return new Promise((r)=>{
        if(dataMap[searchValue]){
            r(dataMap[searchValue]);
            return;
        }
        /** 创建一个唯一标识用于接受数据,防止数据对应不齐 */
        let sign = `sug_sign_${getRandomLetters(3)}_${new Date().getTime()}`;
        window[sign] = (data)=>{
            setTimeout(()=>{sug.remove();},1000);  //删除元素
            let list = data.s || [];
            dataMap[searchValue] = list;
            r(list);
        }
        let sug = document.createElement('script');
        sug.src = `https://suggestion.baidu.com/su?wd=${encodeURIComponent(searchValue || '')}&cb=window.${sign}`;
        document.getElementsByTagName('body')[0].appendChild(sug);
    });
}
/** 获取bing关键词列表 */
let dataMap_1 = {};  //缓存列表
function getBingSug(searchValue){
    return new Promise((r)=>{
        if(dataMap_1[searchValue]){
            r(dataMap_1[searchValue]);
            return;
        }
        /** 创建一个唯一标识用于接受数据,防止数据对应不齐 */
        let sign = `sug_sign_${getRandomLetters(3)}_${new Date().getTime()}`;
        window[sign] = (data)=>{
            setTimeout(()=>{sug.remove();},1000);  //删除元素
            let list = [];
            let list_1 = data.AS.Results || [];
            list_1.forEach(item=>{
                list.push(...item.Suggests.map(item_=>{
                    return item_.Txt;
                }));
            });
            dataMap_1[searchValue] = list;
            r(list);
        }
        let sug = document.createElement('script');
        sug.src = `https://api.bing.com/qsonhs.aspx?type=cb&q=${encodeURIComponent(searchValue || '')}&cb=window.${sign}`;
        document.getElementsByTagName('body')[0].appendChild(sug);
    });
}
/** 获取360关键词列表 */
let dataMap_2 = {};  //缓存列表
function get360Sug(searchValue){
    return new Promise((r)=>{
        if(dataMap_2[searchValue]){
            r(dataMap_2[searchValue]);
            return;
        }
        /** 创建一个唯一标识用于接受数据,防止数据对应不齐 */
        let sign = `sug_sign_${getRandomLetters(3)}_${new Date().getTime()}`;
        window[sign] = (data)=>{
            setTimeout(()=>{sug.remove();},1000);  //删除元素
            let list = [];
            let list_1 = data.result || [];
            list_1.forEach(item=>{
                list.push(item.word || '');
            });
            dataMap_2[searchValue] = list;
            r(list);
        }
        let sug = document.createElement('script');
        sug.src = `https://sug.so.360.cn/suggest?encodein=utf-8&encodeout=utf-8&format=json&word=${encodeURIComponent(searchValue || '')}&callback=window.${sign}`;
        document.getElementsByTagName('body')[0].appendChild(sug);
    });
}
/** 获取淘宝关键词列表 */
let dataMap_3 = {};  //缓存列表
function getTaoBaoSug(searchValue){
    return new Promise((r)=>{
        if(dataMap_3[searchValue]){
            r(dataMap_3[searchValue]);
            return;
        }
        /** 创建一个唯一标识用于接受数据,防止数据对应不齐 */
        let sign = `sug_sign_${getRandomLetters(3)}_${new Date().getTime()}`;
        window[sign] = (data)=>{
            setTimeout(()=>{sug.remove();},1000);  //删除元素
            let list = [];
            let list_1 = data.result || [];
            list_1.forEach(item=>{
                list.push(item[0] || '');
            });
            dataMap_3[searchValue] = list;
            r(list);
        }
        let sug = document.createElement('script');
        sug.src = `https://suggest.taobao.com/sug?code=utf-8&q=${encodeURIComponent(searchValue || '')}&callback=window.${sign}`;
        document.getElementsByTagName('body')[0].appendChild(sug);
    });
}

方便以后直接复制使用,使用例子

javascript 复制代码
getBingSug('苹果').then(e=>{
    console.log(e);
})

非常的好用哇,为什么要有个sign标识呢,因为多次调用会存在一个问题,就是不知道这次的列表是对应我输入的什么字符的,现在这个完美解决了这个问题。

原文

相关推荐
光影少年28 分钟前
react的hooks防抖和节流是怎样做的
前端·javascript·react.js
小毛驴85032 分钟前
Vue 路由示例
前端·javascript·vue.js
发现一只大呆瓜1 小时前
AI流式交互:SSE与WebSocket技术选型
前端·javascript·面试
m0_719084112 小时前
React笔记张天禹
前端·笔记·react.js
Ziky学习记录2 小时前
从零到实战:React Router 学习与总结
前端·学习·react.js
wuhen_n2 小时前
JavaScript链表与双向链表实现:理解数组与链表的差异
前端·javascript
wuhen_n2 小时前
JavaScript数据结构深度解析:栈、队列与树的实现与应用
前端·javascript
狗哥哥3 小时前
微前端路由设计方案 & 子应用管理保活
前端·架构
前端大卫3 小时前
Vue3 + Element-Plus 自定义虚拟表格滚动实现方案【附源码】
前端
却尘3 小时前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js