搜索引擎跳转

简单的搜索引擎跳转

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

  // ==UserScript==
  // @name         搜索引擎跳转
  // @namespace    http://tampermonkey.net/
  // @version      0.3
  // @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:hover {
        background-color: #fff !important;
      }
      
      .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: ''
      },
      {
        name: 'Douban',
        url: /^https?:\/\/www\.douban\.com\/search*/i,
        id: 'input[name="q"]:not(#inp-query)',
        selector: '.article',
        link: 'https://www.douban.com/search?q=%s',
        icon: ''
      },
      {
        name: 'Taobao',
        url: /^https?:\/\/s\.taobao.com\/search*/i,
        id: '#q',
        selector: '.grid-total:nth-of-type(3)',
        link: 'https://s.taobao.com/search?q=%s',
        icon: ''
      }
    ]

    /*
    * id:输入框的id
    * selector:插入位置的选择器,jquery写法
    * type:插入方式appendChild、insertFirst,分别是selector的子元素第一个和最后的位置
    * css:搜索条自定义样式*/
    function createList(id, selector, css, type, before) {
      let word = document.querySelector(id).getAttribute('value')
      // debugger
      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
        case 'insertBefore':
          let q = document.querySelector(selector)
          q.insertBefore(wrap, q.querySelector(before))
        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)
      })
    }

    function init() {
      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, css, 'appendChild')
              break
            case 'Baidu':
              css = 'padding-left: 121px; padding-top: 10px;'
              createList(item.id, item.selector, css, 'insertFirst')
              break
            case 'Zhihu':
              css = 'margin-top: -15px; margin-bottom: 10px;'
              createList(item.id, item.selector, css, 'insertFirst')
              break
            case 'Bing':
              css = 'margin-top: -18px;margin-bottom: 5px;'
              createList(item.id, item.selector, css, 'insertFirst')
              break
            case 'Douban':
              css = 'margin-top: -20px;margin-bottom: 8px;'
              createList(item.id, item.selector, css, 'insertBefore', '.search-cate')
              break
            case 'Taobao':
              css = 'padding-left: 258px;margin-top: 5px;'
              createList(item.id, item.selector, css, 'insertFirst')
            default:
              break
          }
          return true
        }
      })
    }

    window.addEventListener('load', init, false)
  })(window, document);