// ==UserScript==
// @name 搜索引擎切换
// @namespace http://tampermonkey.net/
// @version 0.1.3
// @description 切换搜索引擎
// @match *://www.baidu.com/*/s*
// @match *://m.baidu.com/*/s*
// @match *://www.baidu.com/s*
// @match *://www.baidu.com/s*
// @match *://www.baidu.com/baidu*
// @match *://m.baidu.com/baidu*
// @match *://duckduckgo.com/*
// @match *://search.brave.com/search*
// @match *://www.google.com/search*
// @match *://www.google.com.hk/search*
// @match *://weixin.sogou.com/weixin*
// @match *://www.bing.com/search*
// @match *://cn.bing.com/search*
// @match *://www.zhihu.com/search*
// @match *://search.cnki.com.cn/Search/Result*
// @match *://www.sogou.com/web*
// @match *://m.sogou.com/web*
// @grant unsafeWindow
// @grant GM_getValue
// @grant GM_setValue
// @run-at document-body
// @license MIT
// ==/UserScript==
(function () {
"use strict";
// 搜索网址配置
const urlMapping = {
'google': {
name: "Google",
searchUrl: "https://www.google.com/search?q=",
keyName: "q",
},
'baidu': {
name: "百度",
searchUrl: "https://www.baidu.com/s?wd=",
keyName: ["wd", 'word'],
},
'bing': {
name: "Bing",
searchUrl: "https://www.bing.com/search?q=",
keyName: "q",
},
'sogou': {
name: "搜狗",
searchUrl: "https://www.sogou.com/web?query=",
keyName: ["keyword", 'query'],
},
'brave': {
name: "Brave",
searchUrl: "https://search.brave.com/search?q=",
keyName: "q",
},
'duckduckgo': {
name: "DuckDuckGo",
searchUrl: "https://duckduckgo.com/?q=",
keyName: "q",
},
'weixin': {
name: "微信文章",
searchUrl: "https://weixin.sogou.com/weixin?type=2&s_from=input&query=",
keyName: "query",
},
'zhihu': {
name: "知乎",
searchUrl: "https://www.zhihu.com/search?q=",
keyName: "q",
},
'cnki': {
name: "知网",
searchUrl: "https://search.cnki.com.cn/Search/Result?content=",
keyName: "content",
},
};
const extraReg = {
'weixin.sogou.com': 'weixin',
}
const iconBase64 = ''
// 从url中获取搜索关键词
function getKeywords() {
const urlInfo = new URL(window.location.href)
const domain = urlInfo.host.replace('www.', '')
let current = extraReg[domain];
if (!current) {
for (const [index,item] of Object.entries(urlMapping)) {
if (domain.indexOf(index) !== -1) {
current = index;
break;
}
}
}
console.log({current})
let keyword = "";
const urlParser = new URL(window.location.href);
const keyName = urlMapping[current].keyName;
if (Array.isArray(keyName)) {
keyName.map(key=> {
const v = urlParser.searchParams.get(key);
if (v) {
keyword = v;
}
});
} else {
keyword = urlParser.searchParams.get(keyName);
}
return keyword;
}
const style = `
<style>
#search-app-box {
position: fixed;
top: 140px;
left: 0px;
background-color: hsla(200, 40%, 96%, .9);
font-size: 12px;
border-radius: 6px;
z-index: 99999;
}
#search-app-box .search-engine-icon {
width: 20px;
padding: 8px;
}
#search-app-box .search-engine-title {
display: block;
white-space: nowrap;
color: hsla(211, 60%, 35%, .8);
text-align: center;
margin-top: 10px;
margin-bottom: 5px;
font-size: 12px;
font-weight: bold;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
#search-app-box .search-engine-a {
display: block;
white-space: nowrap;
color: #132d4a;
padding: 8px;
text-decoration: none;
}
#search-app-box .hide {
display: none;
}
#search-app-box .search-engine-a:hover {
background-color: hsla(211, 60%, 35%, .1);
}
</style>`;
// 添加节点
function addBox() {
// 主元素
const div = document.createElement("div");
div.innerHTML = style
div.id = 'search-app-box'
document.body.insertAdjacentElement("afterbegin", div);
let icon = document.createElement("img");
icon.className = "search-engine-icon";
icon.src = iconBase64
div.appendChild(icon);
const searchItemsBox = document.createElement("div");
searchItemsBox.className = "search-engine-items-box hide";
let title = document.createElement("span");
title.innerText = "搜索引擎";
const toggleBox = () => {
const isHideBox = searchItemsBox.classList.contains('hide')
if (isHideBox) {
searchItemsBox.classList.remove('hide')
icon.classList.add('hide')
} else {
searchItemsBox.classList.add('hide')
icon.classList.remove('hide')
}
}
title.className = "search-engine-title";
searchItemsBox.appendChild(title);
div.addEventListener("click", (event) => {
const classList = event.target.classList
if (classList.contains('search-engine-icon') || classList.contains('search-engine-title')) {
toggleBox()
}
});
// 搜索列表
const keyword = getKeywords()
for (const [index,item] of Object.entries(urlMapping)) {
// 设置搜索引擎链接
let a = document.createElement("a");
a.innerText = item.name;
a.className = "search-engine-a";
a.href = item.searchUrl + keyword;
searchItemsBox.appendChild(a);
}
div.appendChild(searchItemsBox)
}
window.addEventListener("load", (event) => {
addBox()
});
})();