Greasy Fork

聚合搜索引擎切换导航[手机版][移动端]

在搜索顶部显示一个聚合搜索引擎切换导航,模拟M浏览器的综合搜索引擎。专注手机网页搜索引擎切换,纯粹的搜索。SearchJump、搜索跳转、聚合搜索。

目前为 2023-03-24 提交的版本。查看 最新版本

// ==UserScript==
// @name         聚合搜索引擎切换导航[手机版][移动端]
// @namespace    http://tampermonkey.net/
// @version      1.0.9
// @description  在搜索顶部显示一个聚合搜索引擎切换导航,模拟M浏览器的综合搜索引擎。专注手机网页搜索引擎切换,纯粹的搜索。SearchJump、搜索跳转、聚合搜索。
// @author       PunkJet
// @home-url     https://greasyfork.org/zh-CN/scripts/462130

// @match        *://www.baidu.com/s*
// @match        *://m.baidu.com/s*
// @match        *://m.baidu.com/*/s*
// @include      *://www.baidu.com/*/s*
// @include      *://m.baidu.com/*/s*
// @match        *://duckduckgo.com/*
// @match        *://www.google.com/search*
// @match        *://www.google.com.hk/search*
// @match        *://www.bing.com/search*
// @match        *://cn.bing.com/search*
// @match        *://www.zhihu.com/search*
// @match        *://m.sogou.com/web/searchList.jsp*

// @match        *//m.sogou.com/web/*
// @match        *://m.douban.com/search*
// @match        *://yandex.com/search*
// @match        *://quark.sm.cn/s*
// @match        *://m.so.com/s*
// @match        *://so.toutiao.com/*keyword*
// @match        *://fsoufsou.com/search*

// @grant        unsafeWindow
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_addStyle
// @run-at       document-start


// @license     MIT
// ==/UserScript==

const searchUrlMap = [
{
    name: "必应",
    searchUrl: "https://cn.bing.com/search?q=",
    searchkeyName: ["q"],
    matchUrl:"cn.bing.com",
    mark:"Bing",
},
{
    name: "百度",
    searchUrl: "https://baidu.com/s?wd=",
    searchkeyName: ["wd", "word"],
    matchUrl:"baidu.com",
    mark:"Baidu",
},
{
    name: "谷歌",
    searchUrl: "https://www.google.com/search?q=",
    searchkeyName: ["q"],
    matchUrl:"google.com",
    mark:"Google",
},
{
    name: "知乎",
    searchUrl: "https://www.zhihu.com/search?q=",
    searchkeyName: ["q"],
    matchUrl:"zhihu.com",
    mark:"Zhihu",
},
{
    name: "豆瓣",
    searchUrl: "https://m.douban.com/search/?query=",
    searchkeyName: ["query"],
    matchUrl:"m.douban.com",
    mark:"Douban",
},
{
    name: "F搜",
    searchUrl: "https://fsoufsou.com/search?q=",
    searchkeyName: ["q"],
    matchUrl:"fsoufsou.com",
    mark:"Fsou",
},
{
    name: "360",
    searchUrl: "https://m.so.com/s?q=",
    searchkeyName: ["q"],
    matchUrl:"m.so.com",
    mark:"360",
},
{
    name: "夸克",
    searchUrl: "https://quark.sm.cn/s?q=",
    searchkeyName: ["q"],
    matchUrl:"quark.sm.cn",
    mark:"Quark",
},
{
    name: "搜狗",
    searchUrl: "https://m.sogou.com/web/searchList.jsp?keyword=",
    searchkeyName: ["keyword"],
    matchUrl:"m.sogou.com/web",
    mark:"Sougou",
},
{
    name: "头条",
    searchUrl: "https://so.toutiao.com/search/?keyword=",
    searchkeyName: ["keyword"],
    matchUrl:"so.toutiao.com/",
    mark:"Toutiao",
},
{
  name: "Yandex",
  searchUrl: "https://yandex.com/search/touch/?text=",
  searchkeyName: ["text"],
  matchUrl:"yandex.com",
  mark:"Yandex",
},
{
    name: "DuckDuckGo",
    searchUrl: "https://duckduckgo.com/?q=",
    searchkeyName: ["q"],
    matchUrl:"duckduckgo.com",
    mark:"DuckDuckGo",
  }

];

const punkDeafultMark = "Bing-Baidu-Google-Zhihu-Douban-Fsou-360-Quark-Sougou-Toutiao-Yandex-DuckDuckGo";

function getSearchKeywords(name) {
    const url_string = window.location.href;
    const url = new URL(url_string);
    return url.searchParams.get(name);
}


function getKeywords() {
    let keywords = "";
    for (let urlItem of searchUrlMap) {
        if( window.location.href.indexOf(urlItem.matchUrl) >= 0 ) {
            for (let keyItem of urlItem.searchkeyName) {
                if ( window.location.href.indexOf(keyItem) >= 0 )
                {
                    keywords = getSearchKeywords(keyItem);
                    return keywords;
                }
            }
        }
    }
    return keywords;
}


function addSearchBox() {
    const searchBox = document.createElement("div");
    searchBox.id = "punk-search-navi-box";

    const appBoxDiv = document.createElement("div");
    appBoxDiv.id = "punk-search-app-box";
    searchBox.appendChild(appBoxDiv);

    var ulList = document.createElement('ul');
    appBoxDiv.appendChild(ulList);

    let fragment = document.createDocumentFragment();//创建一个文档碎片,减少DOM渲染次数

    let showList = GM_getValue("punk_setup_search").split('-');
    for (let showListIndex in showList) {
        for (let index in searchUrlMap) {
            let item = searchUrlMap[index];
            if (item.mark == showList[showListIndex]) {
                let liItem = document.createElement('li');
                let a = document.createElement("a");
                a.innerText = item.name;

                if ( window.location.href.indexOf(item.matchUrl) >= 0 ) {
                    a.className = "search-engine-highlight";
                }
                a.href = item.searchUrl + getKeywords();

                liItem.appendChild(a);
                fragment.appendChild(liItem);
                break;
            }
        }
    }
    ulList.appendChild(fragment);

    const setBoxDiv = document.createElement("div");
    setBoxDiv.id = "search-setting-box";
    //setBoxDiv.innerHTML = `<span id="punkBtnSet"><svg width="18" height="18" viewBox="0 0 48 48" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M34.0003 41L44 24L34.0003 7H14.0002L4 24L14.0002 41H34.0003Z" fill="none" stroke="#444444" stroke-width="4" stroke-linejoin="round"/><path d="M24 29C26.7614 29 29 26.7614 29 24C29 21.2386 26.7614 19 24 19C21.2386 19 19 21.2386 19 24C19 26.7614 21.2386 29 24 29Z" fill="none" stroke="#444444" stroke-width="4" stroke-linejoin="round"/></svg></span>`;
    setBoxDiv.innerHTML = `<span id="punkBtnSet"><p></p > </span>`;

    searchBox.appendChild(setBoxDiv);

    const closeBoxDiv = document.createElement("div");
    closeBoxDiv.id = "search-close-box";
    closeBoxDiv.innerHTML = `<span id="punkBtnClose"><p></p ></span>`;
    searchBox.appendChild(closeBoxDiv);

    document.getElementsByTagName('head')[0].after(searchBox);


    let btnSet = document.querySelector("#search-setting-box");
    btnSet.onclick = function () {
        let sss = prompt("输入需要显示的搜索引擎。格式:" + punkDeafultMark);
        if (sss) {
            GM_setValue("punk_setup_search", sss);
        }
        //alert("用户设置" + GM_getValue("punk_setup_search"));
    }

    let btnClose = document.querySelector("#search-close-box");
    btnClose.onclick = function () {
        searchBox.style = `display:none;`;
    }
}


(function () {
  "use strict";

  const css =
    `
    #punk-search-navi-box {
      opacity:1 !important;
      position: fixed;
      display: -webkit-flex;
      display:flex;
      top: 0px;
      left: 0px;
      width: 100%;
      background-color: #FFFFFF !important;
      font-size: 15px;
      border-radius: 1px;
      z-index: 99999;
    }

    #punk-search-app-box {
      flex:1;
      width: 0;
    }
    #search-setting-box {
      flex: 0 0 30px;
      text-align: center;
      margin: auto;
      background:url() no-repeat center;
      background-size:contain;
      width:100%;
      height:20px;
    }
    #search-close-box {
      flex: 0 0 29px;
      text-align: center;
      margin: auto;
      background:url() no-repeat center;
      background-size:contain;
      width:100%;
      height:20px;
    }

    #punk-search-app-box ul {
      margin: 0;
      padding: 0;
      overflow: hidden;
      overflow-x: auto;
      list-style: none;
      white-space:nowrap;
    }

    #punk-search-app-box ul::-webkit-scrollbar {
      display: none !important;
    }

    #punk-search-app-box li {
      margin-left: 0px;
      display: inline-block;
    }

    #punk-search-app-box ul li a {
      display: block;
      /*color: #767676 !important;*/
      color: #666666 !important;
      padding: 8px;
      text-decoration: none;
      font-weight:bold;
      /*background-color: hsla(211, 60%, 35%, .1);*/
      font-family:Helvetica Neue,Helvetica,Arial,Microsoft Yahei,Hiragino Sans GB,Heiti SC,WenQuanYi Micro Hei,sans-serif;
    }

    .search-engine-highlight  {
      background-color: hsla(211, 60%, 35%, .1) !important;
    }

    #search-setting-box img{
      width: 60%;
      height: 60%;
      object-fit: cover;
    }

    #search-close-box img{
      width: 60%;
      height: 60%;
      object-fit: cover;
    }

    body{
      margin-top: 35px !important;
    }

    .his-wrap-new .fix-wrap {
       top:35px !important;
    }

  `
    if (!GM_getValue("punk_setup_search")) {
        GM_setValue("punk_setup_search", punkDeafultMark);
    }
    GM_addStyle(css);
    addSearchBox();

})();