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

什么是关键词#

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

直接上代码

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标识呢,因为多次调用会存在一个问题,就是不知道这次的列表是对应我输入的什么字符的,现在这个完美解决了这个问题。

原文

相关推荐
橙子家2 小时前
浏览器缓存之【基础键值存储】:Local storage 和 Session storage
前端
星星在线5 小时前
MusicFree:一个「All in One」的个人音乐服务器,让听歌回归简单
前端·后端
IT_陈寒6 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
demo007x6 小时前
Docling 文档转换以及技术架构分析
前端·后端·程序员
京东云开发者7 小时前
京东市民服务又“上新”!这次是黑龙江“龙易办”
前端
袋鱼不重7 小时前
我的神奇同事,AI 用多了居然写了个 Open In Codex
前端·后端·ai编程
Fireworks8 小时前
深入vue3源码解读 -- 1、响应式的基础概念
前端
程序员黑豆8 小时前
JDK 下载安装与配置详细教程
java·前端·ai编程
hunterandroid8 小时前
文件存储:内部存储与外部存储
前端
NorBugs8 小时前
飞机大战 Low 版 (Made in AI)
前端