搜索引擎跳转

简单的搜索引擎跳转

目前为 2017-08-19 提交的版本。查看 最新版本

// ==UserScript==
// @name         搜索引擎跳转
// @namespace    http://tampermonkey.net/
// @version      0.2
// @description  简单的搜索引擎跳转
// @author       tgxh
// @include	http://*
// @include	https://*
// @match   *://*/*
// @grant        none
// ==/UserScript==

(function (window, document) {
  'use strict';

  let href = window.location.href,
    css = ''
    , styles = `
    .t_search_list {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
    }
    
    .t_search_list a {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      margin-right: 10px;
      font-size: 16px;
      color: #666 !important;
      text-decoration: none;
    }
    
    .t_search_list a > img {
      margin-right: 2px;
      width: 16px;
      height: 16px;
    }
    body.vasq #hdtbMenus.hdtb-td-o {
      top: 90px !important;
    }
  `

  /*
  * name:显示名字
  * url:页面url匹配正则
  * id:输入框id
  * selector:插入位置选择器,jquery写法
  * link:跳转的搜索链接,用%s代替搜索关键词
  * icon:base64图标,20×20 */
  let siteInfos = [
    {
      name: 'Google',
      url: /^https?:\/\/(www|encrypted)\.google(?:\.\D{1,3}){1,2}\/(webhp|search|#|$|\?)/i,
      id: 'lst-ib',
      selector: '#before-appbar',
      link: 'https://www.google.com/search?hl=zh-CN&safe=off&q=%s',
      icon: ''
    },
    {
      name: 'Baidu',
      url: /^https?:\/\/www\.baidu\.com\/(?:s|baidu)/i,
      id: 'kw',
      selector: '#wrapper_wrapper',
      link: 'https://www.baidu.com/s?wd=%s',
      icon: ''
    },
    {
      name: 'Bing',
      url: /^https?:\/\/.*\.bing\.com\/search\?/i,
      id: 'sb_form_q',
      selector: '#b_tween',
      link: 'http://cn.bing.com/search?q=%s',
      icon: ''
    },
    {
      name: 'Zhihu',
      url: /^https?:\/\/www\.zhihu\.com\/search\?/i,
      id: 'q',
      selector: '.zg-wrap.zu-main',
      link: 'https://www.zhihu.com/search?type=content&q=%s',
      icon: ''
    }
  ]

  /*
  * id:输入框的id
  * selector:插入位置的选择器,jquery写法
  * type:插入方式appendChild、insertFirst,分别是selector的子元素第一个和最后的位置
  * css:搜索条自定义样式*/
  function createList(id, selector, type, css) {
    let word = document.getElementById(id).getAttribute('value')
    let styleEle = document.createElement('style')
    styleEle.innerHTML = styles
    document.querySelector('head').appendChild(styleEle)

    let wrap = document.createElement('div')
    wrap.className = 't_search_wrap'
    wrap.style.cssText += css
    wrap.innerHTML = '<div class="t_search_list"></div>'

    switch (type) { //插入方式,可以自定义
      case 'appendChild':
        document.querySelector(selector).appendChild(wrap)
        break
      case 'insertFirst':
        let p = document.querySelector(selector)
        p.insertBefore(wrap, p.firstChild)
        break
      default:
        break
    }

    let listele = document.querySelector('.t_search_list')
    listele.innerHTML = `<a href=""></a>`.repeat(siteInfos.length)
    let linklist = listele.querySelectorAll('.t_search_list a')
    linklist.forEach((item, i) => {
      item.innerHTML = `<img src="${siteInfos[i].icon}">${siteInfos[i].name}`
      item.href = siteInfos[i].link.replace(/%s/, word)
    })
  }

  siteInfos.some(item => {
    if (item.url.test(href)) {
      switch (item.name) {
        case 'Google':
          css = 'padding-left: 165px; padding-top: 10px;'
          createList(item.id, item.selector, 'appendChild', css)
          break
        case 'Baidu':
          css = 'padding-left: 121px; padding-top: 10px;'
          createList(item.id, item.selector, 'insertFirst', css)
          break
        case 'Zhihu':
          css = 'margin-top: -15px; margin-bottom: 10px;'
          createList(item.id, item.selector, 'insertFirst', css)
          break
        case 'Bing':
          css = 'margin-top: -18px;margin-bottom: 5px;'
          createList(item.id, item.selector, 'insertFirst', css)
          break
        default:
          break
      }
      return true
    }
  })
})(window, document);