searchEngineJump 搜索引擎快捷跳转

方便的在各个搜索引擎之间跳转,增加可视化设置菜单,能更友好的自定义设置,修复百度搜索样式丢失的问题

安装此脚本?
作者推荐脚本

您可能也喜欢网页限制解除(改)

安装此脚本
  1. // ==UserScript==
  2. // @name searchEngineJump 搜索引擎快捷跳转
  3. // @author NLF&锐经(修改) & iqxin(修改)
  4. // @contributor iqxin
  5. // @description 方便的在各个搜索引擎之间跳转,增加可视化设置菜单,能更友好的自定义设置,修复百度搜索样式丢失的问题
  6. // @version 5.26.7
  7. // @created 2011-07-02
  8. // @lastUpdated 2024-12-22
  9.  
  10. // @namespace https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump
  11. // @homepage https://github.com/qxinGitHub/searchEngineJump
  12. // @require https://gf.qytechs.cn/scripts/408009-togbk/code/toGBK.js?version=832799
  13. // @icon 
  14. // @license MIT
  15.  
  16. // @match *://**/*
  17. // @exclude *://mega.nz/*
  18.  
  19. // @grant GM_getValue
  20. // @grant GM_setValue
  21. // @grant GM_addStyle
  22. // @grant GM_deleteValue
  23. // @grant GM_setClipboard
  24. // @grant GM_registerMenuCommand
  25. // @grant GM_openInTab
  26. // @grant GM_xmlhttpRequest
  27. // @run-at document-end
  28.  
  29. // ==/UserScript==
  30.  
  31. (function () {
  32. 'use strict';
  33.  
  34. console.log("脚本: 搜索引擎快捷跳转 --- 开始执行 --- 发布者: qxin --- GitHub:https://github.com/qxinGitHub/searchEngineJump ← 问题反馈地址")
  35. function iqxinstart(){
  36. // 根据规则把搜索引擎列表插入到指定网站
  37. var rules = [
  38. // 网页搜索/////////////第一个可以当模板看
  39. {name: "google网页搜索",// 你要加载的网站的名字(方便自己查找)
  40. // 是否启用.
  41. enabled: true,
  42. // 在哪个网站上加载,正则.
  43. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^?]+\?(?!tbm=)(?:&?q=|(?:[^#](?!&tbm=))+?&q=)(?:.(?!&tbm=))*$|(^https?:\/\/xn--flw351e\.ml\/search\?q=)/,
  44. // 加载哪个类型的列表:
  45. // ['web'|'music'|'video'|'image'|'download'|'shopping'|'translate'|'knowledge'|'sociality']
  46. engineList: 'web',
  47. // 添加一个class, 用来使用目标网站的样式
  48. class: "s6JM6d",
  49. // 若固定到顶栏,是否给一个高度
  50. fixedTop: 52,
  51. // 固定到顶栏, 兼容ac百度用
  52. // fixedTop2:88,
  53. // 给引擎列表的样式
  54. style: '\
  55. z-index: 100;\
  56. margin-top:5px;\
  57. margin-left:-10px;\
  58. ',
  59. // 给引擎列表的样式 (“style_ACBaidu” 可选,是为了兼容 “AC Baidu” 脚本)
  60. style_ACBaidu: '\
  61. text-align: center;\
  62. z-index: 100;\
  63. margin-top:-5px;\
  64. ',
  65. // 插入文档,相关
  66. // target 将引擎跳转工具栏插入到文档的某个元素
  67. // (请使用xpath匹配,比如: '//*[@id="subform_ctrl"]' 或者 css匹配(请加上 'css;' 的前缀),比如: 'css;#subform_ctrl' );
  68. // keyword 使用 xpath 或者 css选中一个form input元素 或者 该项是一个函数,使用返回值
  69. // where 四种:
  70. // 'beforeBegin'(插入到给定元素的前面) ;
  71. // 'afterBegin'(作为给定元素的第一个子元素) ;
  72. // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  73. // 'afterEnd'(插入到给定元素的后面);.
  74. insertIntoDoc: {
  75. target: 'css;.ufC5Cb',
  76. // 若 keyword 使用函数获取
  77. // keyword: function () {
  78. // var input = document.getElementById('lst-ib');
  79. // if (input) return input.value;
  80. // },
  81. keyword: '//textarea[@name="q"]',
  82. where: 'afterBegin',
  83. },
  84. // 修改源网页用来适应跳转栏(可选)
  85. // stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important;} #hdtbMenus{top:92px;margin-top:30px;}'
  86. stylish: '#appbar.hdtb-ab-o{height:0px !important;} #hdtbMenus{position:unset}'
  87. },
  88. {name: "google-hash-query",// 不刷新页面显示搜索结果的google
  89. enabled: true,
  90. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^#]*#(?:&?q=|.+?&q=).+/,
  91. engineList: 'web',
  92. style: '\
  93. margin-left: 142px;\
  94. z-index: 100;\
  95. margin-top:5px;\
  96. ',
  97. style_ACBaidu: '\
  98. text-align: center;\
  99. z-index: 100;\
  100. margin-top:5px;\
  101. ',
  102. insertIntoDoc: {
  103. target: 'css;#appbar',
  104. keyword: function () {
  105. var input = document.getElementById('lst-ib');
  106. if (input) return input.value;
  107. },
  108. where: 'beforeBegin',
  109. },
  110. stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important}'
  111. },
  112. {name: "百度网页搜索",
  113. url: /^https?:\/\/www\.baidu\.com\/(?:s|baidu)/,
  114. enabled: true,
  115. engineList: "web",
  116. fixedTop:70,
  117. fixedTop2:88,
  118. // fixedTopTarget: "css;.s_form ",
  119. fixedTopTarget: "css;#wrapper_wrapper",
  120. // fixedTopWhere:"beforeEnd",
  121. fixedTopWhere:"beforeBegin",
  122. style: '\
  123. margin-top:8px;\
  124. margin-bottom: -5px;\
  125. z-index: 101;\
  126. margin-left: 144px;\
  127. ',
  128. style_ACBaidu: '\
  129. margin-top: 8px;\
  130. margin-bottom: -5px;\
  131. z-index: 99;\
  132. text-align: center;\
  133. padding-left:0px !important;\
  134. background: rgba(248,248,248,0.4);\
  135. backdrop-filter: blur(10px);\
  136. ',
  137. insertIntoDoc: {
  138. keyword: 'css;input#kw',
  139. target: 'css;#s_tab',
  140. where: 'afterEnd',
  141. },
  142. stylish:".headBlock,.se_common_hint{display:none !important} #wrapper>.result-molecule{z-index:300 !important} #searchTag{position:unset}"
  143. },
  144. {name: "必应网页搜索",
  145. url: /^https?:\/\/[^.]*\.bing\.com\/search/,
  146. enabled: true,
  147. engineList: "web",
  148. style: '\
  149. padding-left:15px;\
  150. margin-top:6px;\
  151. margin-left: 148px;\
  152. margin-bottom:-10px;\
  153. ',
  154. style_ACBaidu: '\
  155. text-align: center;\
  156. margin-left: -120px;\
  157. margin-right: 0px;\
  158. margin-bottom:-20px;\
  159. ',
  160. insertIntoDoc: {
  161. keyword: 'css;#sb_form_q',
  162. target: 'css;#b_content',
  163. where: 'beforeBegin',
  164. },
  165. },
  166. {name: "DDG",
  167. url: /^https?:\/\/duckduckgo\.com\/*/i,
  168. enabled: true,
  169. engineList: "web",
  170. style: '\
  171. margin-top:5px;\
  172. ',
  173. insertIntoDoc: {
  174. keyword: '//input[@name="q"]',
  175. target: 'css;.results--main',
  176. where: 'beforeBegin',
  177. },
  178. },
  179. {name:"雅虎网页搜索",
  180. url:/^https?:\/\/search\.yahoo\.com\/search/i,
  181. engineList:"web",
  182. enabled:true,
  183. fixedTop:54,
  184. style:"\
  185. margin-left:122px;\
  186. ",
  187. insertIntoDoc:{
  188. keyword:'css;#yschsp',
  189. target:'css;#horizontal-bar',
  190. where:'afterBegin',
  191. },
  192. },
  193. {name:"雅虎日本网页搜索",
  194. url:/^https?:\/\/search\.yahoo\.co\.jp\/search/i,
  195. engineList:"web",
  196. enabled:true,
  197. style:"\
  198. margin-left:0px;\
  199. width:1050px;\
  200. display:flex;\
  201. -webkit-box-orient: vertical;\
  202. -webkit-box-direction: normal;\
  203. margin: auto;\
  204. ",
  205. insertIntoDoc:{
  206. keyword:'//input[@name="p"]',
  207. target:'css;.Header__inner',
  208. where:'afterEnd',
  209. },
  210. },
  211. {name:"台湾雅虎网页搜索",
  212. url:/^https?:\/\/tw\.search\.yahoo\.com\/search/i,
  213. engineList:"web",
  214. enabled:true,
  215. fixedTop:52,
  216. style:"\
  217. margin-left:-10px;\
  218. margin-bottom:10px;\
  219. ",
  220. insertIntoDoc:{
  221. keyword:'css;#yschsp',
  222. target:'css;#results',
  223. where:'afterBegin',
  224. },
  225. },
  226. {name:"searx",
  227. url:/^https?:\/\/searx\.me\/\?q/i,
  228. engineList:"web",
  229. enabled:true,
  230. style:"\
  231. margin-left:-10px;\
  232. margin-bottom:10px;\
  233. ",
  234. insertIntoDoc:{
  235. keyword:'css;#q',
  236. target:'css;#categories',
  237. where:'beforeBegin',
  238. },
  239. },
  240. {name: "搜狗",
  241. url: /^https?:\/\/www\.sogou\.com\/(?:web|s)/,
  242. enabled: true,
  243. engineList: "web",
  244. fixedTop:60,
  245. style: "\
  246. top:-46px;\
  247. z-index:99;\
  248. margin-left:-5px;\
  249. ",
  250. style_ACBaidu: "\
  251. top:-46px;\
  252. z-index:99;\
  253. margin-left:60px;\
  254. padding-left: 0px !important;\
  255. ",
  256. insertIntoDoc: {
  257. keyword: "css;#upquery",
  258. target: "css;#wrapper",
  259. where: "afterBegin",
  260. },
  261. stylish:"#float_uphint{display:none;}",
  262. },
  263. {name:"yandex",
  264. url:/^https?:\/\/yandex\.(?:com|ru)\/search/i,
  265. engineList:"web",
  266. enabled:true,
  267. fixedTop:96,
  268. class:"main__center",
  269. style:"\
  270. padding-left:0px;\
  271. ",
  272. insertIntoDoc:{
  273. keyword:'css;.input__control',
  274. target:'css;.main',
  275. where:'beforeBegin',
  276. },
  277. stylish:".main .main__center{padding-top:0px}"
  278. },
  279. {name: "google网页分类搜索",
  280. enabled: true,
  281. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^?]+\?(?:tbm=)(?:&?q=|(?:[^#](?!&tbm=))+?&q=)(?:.(?!&tbm=))*$/,
  282. engineList: 'web',
  283. style: '\
  284. margin-left: 142px;\
  285. z-index: 100;\
  286. margin-top:5px;\
  287. ',
  288. insertIntoDoc: {
  289. target: 'css;#appbar',
  290. keyword: '//input[@name="q"]',
  291. where: 'beforeBegin',
  292. },
  293. stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important}'
  294. },
  295. {name: "startpage",
  296. enabled: true,
  297. url:/^https?:\/\/(www\.)?startpage\.com\/[a-zA-Z]{2,3}\/search/,
  298. engineList: 'web',
  299. fixedTop:103,
  300. style: '\
  301. z-index: 100;\
  302. ',
  303. insertIntoDoc: {
  304. target: 'css;.layout-web__mainline',
  305. keyword: '//input[@name="query"]',
  306. // where: 'beforeBegin',
  307. where: 'afterBegin',
  308. },
  309. },
  310. {name: "startpage2",
  311. enabled: true,
  312. url:/^https?:\/\/www\.startpage\.com\/do\/asearch/,
  313. engineList: 'web',
  314. fixedTop: 102,
  315. fixedTopColor:"#202c46",
  316. nightMode: true,
  317. style: '\
  318. z-index: 100;\
  319. margin-left: 135px;\
  320. color:#ccc;\
  321. ',
  322. insertIntoDoc: {
  323. target: 'css;.layout-web__header',
  324. keyword: '//input[@name="query"]',
  325. // where: 'beforeBegin',
  326. where: 'beforeEnd',
  327. },
  328. stylish:".layout-web__body{margin-top:110px;}",
  329. },
  330. {name: "infinitynewtab",
  331. enabled: true,
  332. url:/^https?:\/\/google\.infinitynewtab\.com\/\?q/i,
  333. engineList: 'web',
  334. style: '\
  335. z-index: 100;\
  336. margin-top: 20px;\
  337. ',
  338. insertIntoDoc: {
  339. target: 'css;.search-types',
  340. // keyword: 'css;input.gsc-input',
  341. keyword: '//input[@name="search"]',
  342. where: 'afterBegin',
  343. },
  344. },
  345. {name: "ecosia",
  346. enabled: true,
  347. url:/^https?:\/\/www\.ecosia\.org\/search\?/i,
  348. engineList: 'web',
  349. style: '\
  350. margin-left: -10px;\
  351. margin-top: -20px;\
  352. z-index:1;\
  353. background-color:#fff;\
  354. ',
  355. insertIntoDoc: {
  356. target: 'css;.mainline',
  357. keyword: '//input[@name="q"]',
  358. where: 'afterBegin',
  359. },
  360. },
  361. {name: "f搜",
  362. enabled: true,
  363. url: /^https?:\/\/fsoufsou\.com\/search/,
  364. engineList: 'web',
  365. fixedTop: 111,
  366. style: '\
  367. margin-left: 50px;\
  368. z-index: -99999;\
  369. margin-top:5px;\
  370. ',
  371. style_ACBaidu: '\
  372. text-align: center;\
  373. z-index: -99999;\
  374. margin-top:5px;\
  375. ',
  376. insertIntoDoc: {
  377. target: 'css;.input-with-suggestion',
  378. keyword: function () {
  379. var input = document.getElementById('search-input');
  380. if (input) return input.value;
  381. },
  382. where: 'beforeEnd',
  383. },
  384. stylish: '.tabs-bottom-border{transform: translate(0, 32px); !important}'
  385. },
  386. {name: "brave",
  387. enabled: true,
  388. // https://search.brave.com/search?q=0
  389. url:/^https?:\/\/search\.brave\.com\/search\?/i,
  390. engineList: 'web',
  391. class: "container-80",
  392. style: '\
  393. z-index:1;\
  394. ',
  395. insertIntoDoc: {
  396. target: 'css;#search-main',
  397. keyword: '//input[@name="q"]',
  398. where: 'beforeBegin',
  399. },
  400. },
  401. {name: "neeva",
  402. enabled: true,
  403. // https://neeva.com/search?q=0
  404. url:/^https?:\/\/neeva\.com\/search\?/i,
  405. engineList: 'web',
  406. fixedTop: 80,
  407. style: '\
  408. z-index:1;\
  409. ',
  410. insertIntoDoc: {
  411. target: 'css;#search header',
  412. keyword: '//input[@name="q"]',
  413. where: 'afterEnd',
  414. },
  415. },
  416.  
  417. // 知识
  418. {name: "百度百科词条",
  419. url: /^https?:\/\/baike\.baidu\.com\/item/,
  420. engineList: "knowledge",
  421. fixedTop:65,
  422. enabled: true,
  423. style: "\
  424. text-align: center;\
  425. background: #fff;\
  426. ",
  427. insertIntoDoc: {
  428. keyword: 'css;#query',
  429. target: 'css;.navbar-wrapper',
  430. where: 'beforeBegin',
  431. },
  432. },
  433. {name: "百度百科搜索",
  434. url: /^https?:\/\/baike\.baidu\.com\/search/,
  435. engineList: "knowledge",
  436. enabled: true,
  437. fixedTop:56,
  438. style: "\
  439. padding-left: 120px;\
  440. margin: 5px 0 -10px 0px;\
  441. ",
  442. insertIntoDoc: {
  443. keyword: 'css;#query',
  444. target: 'css;.header-wrapper',
  445. where: 'afterEnd',
  446. },
  447. },
  448. {name: "百度文库",
  449. url: /^https?:\/\/wenku\.baidu\.com\/search/i,
  450. engineList: "knowledge",
  451. enabled: true,
  452. fixedTop: 96,
  453. style: "\
  454. margin-bottom: 6px;\
  455. margin-top:-16px;\
  456. padding:0;\
  457. ",
  458. insertIntoDoc: {
  459. keyword: function(){
  460. var str = document.querySelector("#kw").value;
  461. return str;
  462. },
  463. target: 'css;.bd-wrap',
  464. where: 'afterBegin',
  465. },
  466. },
  467. {name: "百度知道",
  468. url: /^https?:\/\/zhidao\.baidu\.com\/search/i,
  469. engineList: "knowledge",
  470. enabled: true,
  471. style: "\
  472. border-top: 1px solid #e5e5e5;\
  473. border-bottom: 1px solid #e5e5e5;\
  474. margin-bottom: 1px;\
  475. margin-left:112px;\
  476. ",
  477. insertIntoDoc: {
  478. keyword: 'css;#kw',
  479. target: 'css;#header',
  480. where: 'afterEnd',
  481. },
  482. },
  483. {name: "维基百科",
  484. url: /^https?:\/\/\D{2,5}\.wikipedia\.org\/wiki/i,
  485. engineList: "knowledge",
  486. enabled: true,
  487. style: "\
  488. position: absolute;\
  489. padding-left: 14em;\
  490. ",
  491. insertIntoDoc: {
  492. keyword: function(){
  493. var url = window.location.href.substring(window.location.href.lastIndexOf("/")+1);
  494. return decodeURIComponent(url);
  495. },
  496. target: 'css;#mw-head',
  497. where: 'afterBegin',
  498. },
  499. },
  500. {name: "知乎",
  501. url: /^https?:\/\/www\.zhihu\.com\/search\?/i,
  502. engineList: "knowledge",
  503. enabled: true,
  504. fixedTop:52,
  505. style: "\
  506. margin: 5px auto 0px;\
  507. width:960px;\
  508. z-index:19;\
  509. background: #fff;\
  510. box-shadow: 0 1px 3px 0 rgba(0,34,77,.05); \
  511. padding: 5px 20px; \
  512. ",
  513. // 兼容“知乎排版优化”
  514. // https://gf.qytechs.cn/zh-CN/scripts/21659
  515. style_ZhihuChenglinz: "\
  516. margin: 5px auto 0px;\
  517. width:654px;\
  518. z-index:19;\
  519. background: #fff;\
  520. box-shadow: 0 1px 3px 0 rgba(0,34,77,.05); \
  521. padding: 5px 20px; \
  522. ",
  523. insertIntoDoc: {
  524. keyword: 'css;.Input',
  525. target:"css;.App-main .SearchTabs",
  526. where: 'afterEnd', //beforeBegin
  527. },
  528. stylish:".TopSearch.Card{margin:30px auto;}",
  529. },
  530. {name: "互动百科搜索页",
  531. url: /^https?:\/\/so\.baike\.com\/doc/i,
  532. engineList: "knowledge",
  533. enabled: true,
  534. style: "\
  535. border-top: 1px solid #e5e5e5;\
  536. text-align: center;\
  537. border-bottom: 1px solid #e5e5e5;\
  538. margin-bottom: 1px;\
  539. ",
  540. insertIntoDoc: {
  541. keyword: 'css;.ac_input',
  542. target: 'css;.bk-head',
  543. where: 'afterEnd',
  544. },
  545. },
  546. {name: "互动百科词条页",
  547. url: /^https?:\/\/www\.baike\.com\/wiki/i,
  548. engineList: "knowledge",
  549. enabled: true,
  550. style: "\
  551. border-top: 1px solid #e5e5e5;\
  552. text-align: center;\
  553. border-bottom: 1px solid #e5e5e5;\
  554. margin-bottom: 1px;\
  555. ",
  556. insertIntoDoc: {
  557. keyword: 'css;.ac_input',
  558. target: 'css;.bk-head',
  559. where: 'afterEnd',
  560. },
  561. },
  562. {name: "豆丁文档",
  563. url: /^https?:\/\/www\.docin\.com\/search\.do/,
  564. engineList: "knowledge",
  565. enabled: true,
  566. style: "\
  567. text-align: center;\
  568. margin:0 auto;\
  569. padding-top:1px;\
  570. border-top:1px solid #00000;\
  571. border-bottom:1px solid #D9E1F7;\
  572. ",
  573. insertIntoDoc: {
  574. keyword: 'css;#topsearch',
  575. target: 'css;.doc_hd_mini',
  576. where: 'afterEnd',
  577. },
  578. },
  579. {name: "知乎(搜狗)",
  580. url: /^https?:\/\/zhihu\.sogou\.com\/zhihu/,
  581. enabled: true,
  582. engineList: 'web',
  583. fixedTop:55,
  584. style: "\
  585. margin: auto;\
  586. width: 1000px;\
  587. z-index:99;\
  588. ",
  589. insertIntoDoc: {
  590. keyword: 'css;#upquery',
  591. target: 'css;#header',
  592. where: 'afterEnd',
  593. },
  594. stylish: '.header{ margin-bottom: 5px; }'
  595. },
  596. {name: "微信搜狗",
  597. url: /^https?:\/\/weixin\.sogou\.com\/weixin\?/,
  598. enabled: true,
  599. engineList: "web",
  600. fixedTop:55,
  601. style: "width: 1000px;margin: 8px auto -5px;z-index:99;",
  602. insertIntoDoc: {
  603. keyword: "//input[@name='query']",
  604. target: "css;.header-box",
  605. where: "afterEnd",
  606. },
  607. },
  608. {name: "Quora",
  609. // https://www.quora.com/search?q=china
  610. url: /^https?:\/\/www\.quora\.com\/search\?/i,
  611. enabled: true,
  612. engineList: "knowledge",
  613. fixedTop:53,
  614. style: "width: 1000px;margin: 0px auto 0px; padding-left:180px;",
  615. insertIntoDoc: {
  616. keyword: function(){
  617. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  618. return decodeURIComponent(url);
  619. },
  620. target: "css;.SiteHeader",
  621. where: "beforeEnd",
  622. },
  623. },
  624. {name: "stackoverflow",
  625. url: /^https?:\/\/stackoverflow\.com\/search\?/i,
  626. enabled: true,
  627. engineList: "knowledge",
  628. fixedTop:50,
  629. style: "width: 1000px;margin: 8px auto 0px;z-index:99;",
  630. insertIntoDoc: {
  631. keyword: "//input[@name='q']",
  632. target: "css;.top-bar",
  633. where: "afterEnd",
  634. },
  635. },
  636.  
  637.  
  638. // 视频网站
  639. {name: "优酷",
  640. url: /^https?:\/\/www\.soku\.com\/search_video\//,
  641. engineList: "video",
  642. enabled: true,
  643. fixedTop:54,
  644. style: "\
  645. width:1190px;\
  646. margin:0 auto;\
  647. z-index:99999;\
  648. ",
  649. insertIntoDoc: {
  650. keyword: 'css;#headq',
  651. target: 'css;.sk_container',
  652. where: 'beforeBegin',
  653. },
  654. },
  655. {name: "土豆",
  656. url: /^https?:\/\/www\.soku\.com\/t\/nisearch\//,
  657. enabled: true,
  658. engineList: "video",
  659. style: "\
  660. padding-left: 10px;\
  661. border-top: 1px solid #FC6500;\
  662. border-bottom: 1px solid #FC6500;\
  663. text-align: center;\
  664. ",
  665. insertIntoDoc: {
  666. keyword: 'css;#headq',
  667. target: 'css;body > .sk_container',
  668. where: 'beforeBegin',
  669. },
  670. },
  671. {name: "哔哩哔哩",
  672. url: /^https?:\/\/search\.bilibili\.com\/all/,
  673. enabled: true,
  674. engineList: "video",
  675. // fixedTop:62,
  676. style: "\
  677. width:980px;\
  678. margin:10px auto -5px;\
  679. text-align:center;\
  680. ",
  681. insertIntoDoc: {
  682. // keyword: 'css;#search-keyword', //旧
  683. // target: 'css;.filter-wrap', //旧
  684. // keyword: 'css;.search-input-el',
  685. keyword: function(){
  686. if(document.querySelector("#search-keyword")){
  687. return document.querySelector("#search-keyword").value;
  688. } else{
  689. return document.querySelector(".search-input-el").value;
  690. }
  691. },
  692. // target: 'css;.search-input',
  693. target: function(){
  694. if(document.querySelector(".head-contain")){
  695. return document.querySelector(".head-contain");
  696. } else{
  697. return document.querySelector(".search-input");
  698. }
  699. },
  700. where: 'afterEnd',
  701. },
  702. },
  703. {name: "AcFun",
  704. url: /^https?:\/\/www\.acfun\.cn\/search/,
  705. enabled: true,
  706. engineList: "video",
  707. fixedTop:46,
  708. style: "\
  709. width:980px;\
  710. margin: -30px 0 10px 0;\
  711. text-align:center;\
  712. ",
  713. insertIntoDoc: {
  714. keyword: 'css;#search-text--standalone',
  715. target: 'css;.search__main__container',
  716. where: 'afterEnd',
  717. },
  718. },
  719. {name: "YouTube",
  720. url: /^https?:\/\/www\.youtube\.com\/results/,
  721. enabled: true,
  722. engineList: "video",
  723. fixedTop:56,
  724. style: "\
  725. z-index:9;\
  726. margin-top: 62px;\
  727. margin-bottom: -80px;\
  728. text-align: center;\
  729. backgroud:#fff;\
  730. ",
  731. insertIntoDoc: {
  732. keyword: 'css;input#search',
  733. target: 'css;#page-manager',
  734. where: 'beforeBegin',
  735. },
  736. },
  737. {name: "niconico",
  738. url: /^https?:\/\/www\.nicovideo\.jp\/search\//,
  739. enabled: true,
  740. engineList: "video",
  741. style: "\
  742. border-top: 1px solid #E8E8E8;\
  743. border-bottom: 1px solid #E8E8E8;\
  744. text-align: center;\
  745. ",
  746. insertIntoDoc: {
  747. keyword: 'css;#search_united',
  748. target: 'css;.tagListBox',
  749. where: 'beforeBegin',
  750. },
  751. },
  752. {name: "Iqiyi",
  753. url: /^https?:\/\/so\.iqiyi\.com\/so\/q/,
  754. enabled: true,
  755. engineList: "video",
  756. fixedTop:60,
  757. style: '\
  758. margin:0 auto;\
  759. width:1180px;\
  760. ',
  761. insertIntoDoc: {
  762. keyword: 'css;#data-widget-searchword',
  763. target: 'css;.mod_search_header',
  764. where: 'afterEnd'
  765. },
  766. },
  767. {name: "腾讯视频",
  768. url: /^https?:\/\/v\.qq\.com\/x\/search/i,
  769. engineList: "video",
  770. enabled: true,
  771. fixedTop:60,
  772. style: "width:1140px;margin:0 auto;",
  773. insertIntoDoc: {
  774. keyword: 'css;#keywords',
  775. target: 'css;.site_head_simple',
  776. where: 'afterEnd',
  777. },
  778. },
  779. {name: "樱花动漫",
  780. url: /^https?:\/\/www\.imomoe\.ai\/search/,
  781. engineList: "video",
  782. enabled: true,
  783. style: " \
  784. width:1140px;\
  785. margin:-10px auto 10px;,\
  786. ",
  787. insertIntoDoc: {
  788. keyword: '//input[@name="searchword"]',
  789. target: 'css;.head',
  790. where: 'afterEnd',
  791. },
  792. },
  793.  
  794.  
  795. // 音乐
  796. {name: "百度音乐",
  797. url: /^https?:\/\/music\.baidu\.com\/search/,
  798. enabled: true,
  799. engineList: "music",
  800. style: "\
  801. border-top: 0px solid #0064C4;\
  802. margin-bottom: 5px;\
  803. ",
  804. insertIntoDoc: {
  805. keyword: 'css;#ww',
  806. target: 'css;.nav-wrapper',
  807. where: 'beforeBegin',
  808. },
  809. },
  810. {name: "一听音乐",
  811. url: /^https?:\/\/so\.1ting\.com\/all\.do/,
  812. enabled: true,
  813. engineList: "music",
  814. style: "\
  815. text-align: center;\
  816. border-bottom: 1px solid #13B310;\
  817. border-top: 1px solid #13B310;\
  818. ",
  819. insertIntoDoc: {
  820. keyword: 'css;#keyword',
  821. target: 'css;.nav',
  822. where: 'beforeBegin',
  823. },
  824. },
  825. {name: "xiami",
  826. url: /^https?:\/\/www\.xiami\.com\/search/,
  827. enabled: true,
  828. engineList: "music",
  829. style: "\
  830. border-top: 1px solid #93D3FF;\
  831. text-align: center;\
  832. ",
  833. insertIntoDoc: {
  834. keyword: 'css;#search_text',
  835. target: 'css;.search_result',
  836. where: 'beforeBegin',
  837. },
  838. },
  839. {name: 'QQ音乐',
  840. url: /^https?:\/\/s\.music\.qq\.com/i,
  841. enabled: true,
  842. engineList: 'music',
  843. style:"\
  844. border-bottom: 1px solid #2B6DAE;\
  845. border-top: 1px solid #2B6DAE;\
  846. text-align: center;\
  847. ",
  848. insertIntoDoc: {
  849. keyword: 'css;#keyword',
  850. target: 'css;.mod_soso',
  851. where: 'afterEnd',
  852. },
  853. },
  854. {name: '网易云音乐',
  855. url: /^https?:\/\/music\.163\.com\/.*?#\/search/i,
  856. enabled: true,
  857. engineList: 'music',
  858. fixedTop:80,
  859. style:"\
  860. text-align: center;\
  861. padding-top:8px;\
  862. ",
  863. insertIntoDoc: {
  864. keyword: (function(){return decodeURI(document.URL.match(/s=(.+?)(&|$)/)[1]);}),
  865. target: 'css;.m-subnav.m-subnav-up.f-pr.j-tflag',
  866. where: 'afterEnd',
  867. },
  868. },
  869. {name: '音悦台',
  870. url: /^https?:\/\/so\.yinyuetai\.com\/\?keyword/,
  871. enabled: true,
  872. engineList: 'music',
  873. style:"\
  874. border-bottom: 1px solid #2B6DAE;\
  875. border-top: 1px solid #2B6DAE;\
  876. text-align: center;\
  877. ",
  878. insertIntoDoc: {
  879. keyword:function(){
  880. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  881. return decodeURIComponent(url);
  882. },
  883. target: 'css;.content',
  884. where: 'afterEnd'
  885. },
  886. },
  887.  
  888.  
  889. // 图片
  890. {name: "百度图片",
  891. url: /^https?:\/\/image\.baidu\.com\/search/i,
  892. enabled: true,
  893. engineList: "image",
  894. fixedTop:70, //关闭关联联想的情况下
  895. // fixedTop:135, //
  896. style: '\
  897. margin-left:127px;\
  898. ',
  899. insertIntoDoc: {
  900. keyword: 'css;input#kw',
  901. target: 'css;.s_tab',
  902. where: 'afterEnd',
  903. },
  904. },
  905. {name: "谷歌图片",
  906. url: /^https?:\/\/\w{2,10}\.google(?:\.\D{1,3}){1,2}\/[^?]+\?.*&tbm=isch/i,
  907. enabled: true,
  908. engineList: "image",
  909. fixedTop:52,
  910. style: '\
  911. margin-left:136px;\
  912. padding: 10px 5px 1px 22px;\
  913. ',
  914. insertIntoDoc: {
  915. keyword: 'css;input[name=q]',
  916. // target: 'css;#ucs',
  917. target: 'css;.ndYZfc',
  918. where: 'afterBegin',
  919. // where: 'beforeEnd',
  920. },
  921. },
  922. {name: "必应图片",
  923. url: /^https?:\/\/.*\.bing\.com\/images\/search/i,
  924. enabled: true,
  925. engineList: "image",
  926. style: '\
  927. padding-left:90px;\
  928. margin-top:-6px;\
  929. ',
  930. insertIntoDoc: {
  931. keyword: 'css;#sb_form_q',
  932. target: 'css;#rfPaneIn',
  933. where: 'afterBegin',
  934. },
  935. },
  936. {name: "flickr",
  937. url: /^https?:\/\/www\.flickr\.com\/search\//,
  938. engineList: "image",
  939. enabled: true,
  940. style: '\
  941. z-index:1999;\
  942. width:100%;\
  943. border-top:1px solid #EBF1FF;\
  944. border-bottom:0px solid #EBF1FF;\
  945. ',
  946. insertIntoDoc: {
  947. keyword: function() {
  948. var input = document.getElementById("autosuggest-input");
  949. if (input) {
  950. return input.value;
  951. } else {
  952. var m = location.search.match(/q=([^&]+)/i);
  953. if (m) {
  954. return decodeURIComponent(m[1]);
  955. }
  956. }
  957. },
  958. target: 'css;.using-slender-advanced-panel',
  959. where: 'afterBegin'
  960. },
  961. },
  962. {name: "pixiv",
  963. url: /^http:\/\/www\.pixiv\.net\/search\.php/i,
  964. engineList: "image",
  965. enabled: true,
  966. style: '\
  967. margin: 0 auto;\
  968. text-align: center;\
  969. font-family: 微软雅黑;\
  970. ',
  971. insertIntoDoc: {
  972. keyword: 'css;input[name=word]',
  973. target: 'css;body',
  974. where: 'beforeBegin'
  975. },
  976. },
  977. {name: "花瓣",
  978. url: /^https?:\/\/huaban\.com\/search\/\?/,
  979. engineList: "image",
  980. enabled: true,
  981. style: '\
  982. border-top:1px solid #EBF1FF;\
  983. text-align: center;\
  984. ',
  985. insertIntoDoc: {
  986. keyword: 'css;#query',
  987. target: 'css;#search_switch',
  988. where: 'afterEnd'
  989. },
  990. },
  991. {name: "Pinterest",
  992. url: /^https?:\/\/www\.pinterest\.com\/search\//,
  993. engineList: "image",
  994. enabled: true,
  995. style: '\
  996. text-align: center;\
  997. margin-top:-11px;\
  998. ',
  999. insertIntoDoc: {
  1000. keyword: '//input[@name="q"]',
  1001. target: 'css;.headerContainer',
  1002. where: 'afterEnd'
  1003. },
  1004. },
  1005.  
  1006.  
  1007. // 资源下载
  1008. {
  1009. name: '海盗湾thepiratebay',
  1010. url: /^https?:\/\/thepiratebay\.org\/search/i,
  1011. engineList: 'bittorrent',
  1012. enabled: true,
  1013. style: '\
  1014. text-align: center;\
  1015. z-index: 9999;\
  1016. ',
  1017. insertIntoDoc: {
  1018. keyword: 'css;.inputbox',
  1019. target: 'css;#SearchResults',
  1020. where: 'beforeBegin',
  1021. },
  1022. },
  1023. {
  1024. name: '动漫花园',
  1025. url: /^https?:\/\/share\.dmhy\.org\/topics\/list\?keyword\=/i,
  1026. engineList: 'download',
  1027. enabled: true,
  1028. style: '\
  1029. text-align: center;\
  1030. ',
  1031. insertIntoDoc: {
  1032. keyword: 'css;#keyword',
  1033. target: 'css;.table.clear',
  1034. where: 'beforeBegin',
  1035. },
  1036. },
  1037. {
  1038. name: 'ED2K',
  1039. url: /^https?:\/\/www\.ed2000\.com\/filelist\.asp/i,
  1040. engineList: 'download',
  1041. enabled: true,
  1042. insertIntoDoc: {
  1043. keyword: 'css;.searchtxt',
  1044. target: 'css;.topsearch',
  1045. where: 'afterEnd',
  1046. },
  1047. },
  1048. {name: "人人影视",
  1049. url: /^https?:\/\/www\.zimuzu\.tv\/search\//,
  1050. engineList: "download",
  1051. enabled: true,
  1052. style: '\
  1053. border-bottom: 1px solid #00AFFF;\
  1054. text-align: center;\
  1055. ',
  1056. insertIntoDoc: {
  1057. keyword: '//input[@name="q"]',
  1058. target: 'css;.Header',
  1059. where: 'afterEnd',
  1060. },
  1061. },
  1062. {name: "subHD字幕",
  1063. url: /^https?:\/\/subhd\.com\/search/i,
  1064. engineList: "download",
  1065. enabled: true,
  1066. style: "\
  1067. border-bottom: 0px solid #CAD9EA;\
  1068. border-top: 0px solid #CAD9EA;\
  1069. text-align: center;\
  1070. top: -20px;\
  1071. ",
  1072. insertIntoDoc: {
  1073. keyword: 'css;#sn',
  1074. target: 'css;.navbar.navbar-inverse',
  1075. where: 'afterEnd',
  1076. },
  1077. },
  1078.  
  1079.  
  1080. //翻译词典
  1081. {name: "谷歌翻译",
  1082. url: /^https?:\/\/translate\.google(?:\.\D{1,4}){1,2}/i,
  1083. enabled: true,
  1084. engineList: "translate",
  1085. style: '\
  1086. margin:10px 0px 0px 0px;\
  1087. ',
  1088. insertIntoDoc: {
  1089. keyword: 'css;.D5aOJc ',
  1090. target: 'css;.MOkH4e ',
  1091. where: 'afterBegin',
  1092. },
  1093. },
  1094. {name: "百度翻译",
  1095. url: /^https?:\/\/fanyi\.baidu\.com/i,
  1096. enabled: true,
  1097. engineList: "translate",
  1098. style: '\
  1099. margin: -20px 0 10px 0;\
  1100. ',
  1101. insertIntoDoc: {
  1102. keyword: function(){
  1103. return document.querySelector("#baidu_translate_input").value;
  1104. },
  1105. target: 'css;.inner',
  1106. where: 'afterBegin',
  1107. },
  1108. },
  1109. {name: "必应词典",
  1110. url: /^https?:\/\/.*\.bing\.com\/dict\/search\?q\=/i,
  1111. enabled: true,
  1112. engineList: "translate",
  1113. style: '\
  1114. padding-left:15px;\
  1115. margin-top:6px;\
  1116. margin-left: 148px;\
  1117. ',
  1118. insertIntoDoc: {
  1119. keyword: 'css;#sb_form_q',
  1120. target: 'css;#b_header',
  1121. where: 'beforeEnd',
  1122. },
  1123. },
  1124. {name: "有道翻译",
  1125. url: /^https?:\/\/dict\.youdao\.com\/search/i,
  1126. enabled: true,
  1127. engineList: "translate",
  1128. fixedTop:64,
  1129. style: '\
  1130. padding-left:0px;\
  1131. margin-top:2px;\
  1132. text-align:center;\
  1133. ',
  1134. insertIntoDoc: {
  1135. keyword: 'css;#query',
  1136. target: 'css;.c-topbar-wrapper',
  1137. where: 'beforeEnd',
  1138. },
  1139. },
  1140. {name: "有道翻译2",
  1141. url: /^https?:\/\/dict\.youdao\.com\/w/i,
  1142. enabled: true,
  1143. engineList: "translate",
  1144. fixedTop:64,
  1145. style: '\
  1146. padding-left:0px;\
  1147. margin-top:2px;\
  1148. text-align:center;\
  1149. ',
  1150. insertIntoDoc: {
  1151. keyword: 'css;#query',
  1152. target: 'css;.c-topbar-wrapper',
  1153. where: 'beforeEnd',
  1154. },
  1155. },
  1156. {name: "海词",
  1157. url: /^https?:\/\/dict\.cn\/./,
  1158. enabled: true,
  1159. engineList: "translate",
  1160. style: "\
  1161. z-index : 99;\
  1162. margin : -30px auto 0;\
  1163. position : absolute;\
  1164. width : 100%;\
  1165. text-align : center;\
  1166. ",
  1167. insertIntoDoc: {
  1168. keyword: 'css;#q',
  1169. target: 'css;.top',
  1170. where: 'afterEnd'
  1171. }
  1172. },
  1173. {name: "金山词霸",
  1174. // https://www.iciba.com/word?w=test
  1175. url: /^https?:\/\/www\.iciba\.com\/word/i,
  1176. enabled: true,
  1177. engineList: "translate",
  1178. fixedTop:122,
  1179. style: '\
  1180. z-index : 0;\
  1181. ',
  1182. insertIntoDoc: {
  1183. keyword: '//input[@type="search"]',
  1184. target: 'css;.Search_input__1qgiU',
  1185. where: 'afterEnd',
  1186. },
  1187. },
  1188.  
  1189. // 购物
  1190. {name: "淘宝搜索",
  1191. url: /^https?:\/\/s\.taobao\.com\/search/,
  1192. enabled: true,
  1193. engineList: "shopping",
  1194. style: "\
  1195. margin:0px 0 -10px 170px;\
  1196. text-align: center;\
  1197. z-index: 99;\
  1198. ",
  1199. insertIntoDoc: {
  1200. keyword: function() {
  1201. var input = document.querySelector('#q');
  1202. if (input) {
  1203. return input.value;
  1204. } else {
  1205. var m = location.search.match(/q=([^&]+)/);
  1206. if (m) {
  1207. return decodeURIComponent(m[1]);
  1208. }
  1209. }
  1210. },
  1211. target: 'css;.header-wraper',
  1212. where: 'afterEnd',
  1213. },
  1214. },
  1215. {name: "天猫超市搜索",
  1216. url: /^https?:\/\/list\.tmall\.com\/search_product\.htm.*from=chaoshi/i,
  1217. enabled: true,
  1218. engineList: "shopping",
  1219. fixedTop:37,
  1220. style: "\
  1221. z-index:9999;\
  1222. margin: 2px auto -10px;\
  1223. left:0;\
  1224. right:0;\
  1225. text-align:center;\
  1226. position:absolute;\
  1227. ",
  1228. insertIntoDoc: {
  1229. keyword: 'css;#mq',
  1230. target: 'css;.headerCon',
  1231. where: 'beforeBegin',
  1232. },
  1233. },
  1234. {name: "天猫搜索",
  1235. url: /^https?:\/\/list\.tmall\.com\/search_product\.htm/i,
  1236. enabled: true,
  1237. engineList: "shopping",
  1238. fixedTop:34,
  1239. style: "\
  1240. margin: 10px auto -10px;\
  1241. text-align:center;\
  1242. ",
  1243. insertIntoDoc: {
  1244. keyword: 'css;#mq',
  1245. target: 'css;.headerCon',
  1246. where: 'beforeBegin',
  1247. },
  1248. },
  1249. {name: "京东",
  1250. url: /^https?:\/\/search\.jd\.com\/Search/,
  1251. enabled: true,
  1252. engineList: "shopping",
  1253. style:"\
  1254. text-align:center; \
  1255. margin-top: 5px; \
  1256. margin-bottom: -20px; \
  1257. ",
  1258. insertIntoDoc: {
  1259. keyword: 'css;#key',
  1260. target: 'css;#o-header-2013',
  1261. where: 'afterEnd',
  1262. },
  1263. },
  1264. {name: "苏宁",
  1265. url: /^https?:\/\/search\.suning\.com/i,
  1266. enabled: true,
  1267. engineList: "shopping",
  1268. style: "\
  1269. border-bottom: 1px solid #E5E5E5;\
  1270. border-top: 1px solid #E5E5E5;\
  1271. text-align: center;\
  1272. ",
  1273. insertIntoDoc: {
  1274. keyword: 'css;#searchKeywordsHidden',
  1275. target: 'css;.ng-toolbar',
  1276. where: 'afterEnd',
  1277. },
  1278. },
  1279. {name: "1号店",
  1280. url: /^https?:\/\/search\.yhd\.com\/c0-0\/k/i,
  1281. enabled: true,
  1282. engineList: "shopping",
  1283. style: "\
  1284. border-bottom: 1px solid #E5E5E5;\
  1285. border-top: 1px solid #E5E5E5;\
  1286. text-align: center;\
  1287. ",
  1288. insertIntoDoc: {
  1289. keyword: 'css;#keyword',
  1290. target: 'css;#global_top_bar',
  1291. where: 'afterEnd',
  1292. },
  1293. },
  1294. {name: "什么值得买",
  1295. // http://search.smzdm.com/?c=home&s=%E8%A5%BF%E6%B8%B8%E8%AE%B0
  1296. url: /^https?:\/\/search\.smzdm\.com\/\?/i,
  1297. enabled: true,
  1298. engineList: "shopping",
  1299. fixedTop:40,
  1300. style: "\
  1301. text-align: center;\
  1302. margin: -15px 0 10px 0;\
  1303. ",
  1304. insertIntoDoc: {
  1305. keyword: 'css;#J_search_input',
  1306. target: 'css;.search-inner',
  1307. where: 'afterEnd',
  1308. },
  1309. },
  1310. {name: "亚马逊",
  1311. // https://www.amazon.cn/s?k=%E4%BA%9A%E9%A9%AC%E9%80%8A%E7%BD%91
  1312. url: /^https?:\/\/www\.amazon\.cn\/s\?k/i,
  1313. enabled: true,
  1314. engineList: "shopping",
  1315. style: "\
  1316. margin:2px 0 -10px 0;\
  1317. ",
  1318. insertIntoDoc: {
  1319. keyword: 'css;#twotabsearchtextbox',
  1320. target: 'css;.sg-row',
  1321. where: 'afterBegin',
  1322. },
  1323. },
  1324. {name: "1688",
  1325. // https://s.1688.com/selloffer/offer_search.htm?keywords=%
  1326. url: /^https?:\/\/s\.1688\.com\/selloffer\/offer_search/i,
  1327. enabled: true,
  1328. engineList: "shopping",
  1329. fixedTop:88,
  1330. class:"tab-container",
  1331. style: "\
  1332. margin:-10px auto 5px;\
  1333. ",
  1334. insertIntoDoc: {
  1335. keyword: '//input[@name="keywords"]',
  1336. target: 'css;.header-container',
  1337. where: 'afterEnd',
  1338. },
  1339. },
  1340. {name: "慢慢买",
  1341. // http://ss.manmanbuy.com/Default.aspx?key=%s
  1342. url: /^https?:\/\/ss\.manmanbuy\.com\/Default\.aspx\?key/i,
  1343. enabled: true,
  1344. engineList: "shopping",
  1345. style: "\
  1346. text-align:center;\
  1347. ",
  1348. insertIntoDoc: {
  1349. keyword: '//input[@name="key"]',
  1350. target: 'css;#resultcomment',
  1351. where: 'beforeBegin',
  1352. },
  1353. },
  1354.  
  1355.  
  1356. //社交
  1357. {name: "新浪微博",
  1358. url: /^https?:\/\/s\.weibo\.com\/weibo\//i,
  1359. enabled: true,
  1360. engineList: "sociality",
  1361. fixedTop:48,
  1362. style: "\
  1363. // border-bottom: 1px solid #E5E5E5;\
  1364. // border-top: 1px solid #E5E5E5;\
  1365. // text-align: center;\
  1366. ",
  1367. insertIntoDoc: {
  1368. keyword: 'css;.searchInp_form',
  1369. target: 'css;#pl_common_searchTop',
  1370. where: 'afterEnd',
  1371. },
  1372. },
  1373. {name: "百度贴吧",
  1374. url: /^https?:\/\/tieba\.baidu\.com\/f\/search/i,
  1375. enabled: true,
  1376. engineList: "sociality",
  1377. style: "\
  1378. border-top: 1px solid #e5e5e5;\
  1379. text-align: center;\
  1380. border-bottom: 1px solid #e5e5e5;\
  1381. margin-bottom: 1px;\
  1382. ",
  1383. insertIntoDoc: {
  1384. keyword: 'css;#wd1',
  1385. target: 'css;.s_container.clearfix',
  1386. where: 'beforeBegin',
  1387. },
  1388. },
  1389. {name: "豆瓣1",
  1390. url: /^https?:\/\/(movie|music|book)\.douban\.com\/subject_search?/,
  1391. enabled: true,
  1392. engineList: "sociality",
  1393. style: "\
  1394. border-top: 1px solid #e5e5e5;\
  1395. text-align: center;\
  1396. border-bottom: 1px solid #e5e5e5;\
  1397. margin-bottom: 1px;\
  1398. ",
  1399. insertIntoDoc: {
  1400. keyword: 'css;#inp-query',
  1401. target: 'css;.nav-secondary',
  1402. where: 'afterEnd'
  1403. },
  1404. },
  1405. {name: "豆瓣2",
  1406. url: /^https?:\/\/www\.douban\.com\/search/i,
  1407. enabled: true,
  1408. engineList: "sociality",
  1409. style: "\
  1410. border-top: 1px solid #e5e5e5;\
  1411. text-align: center;\
  1412. border-bottom: 1px solid #e5e5e5;\
  1413. margin-bottom: 1px;\
  1414. ",
  1415. insertIntoDoc: {
  1416. keyword: 'css;#inp',
  1417. target: 'css;#db-global-nav',
  1418. where: 'afterEnd'
  1419. },
  1420. },
  1421.  
  1422.  
  1423. //学术搜索列表
  1424. {name: "百度学术",
  1425. url: /^https?:\/\/xueshu\.baidu\.com\/(?:s|baidu)/,
  1426. enabled: true,
  1427. engineList: "scholar",
  1428. style: '\
  1429. text-align: center;\
  1430. margin:0px;\
  1431. top:0px;\
  1432. z-index:99999;\
  1433. ',
  1434. insertIntoDoc: {
  1435. keyword: 'css;input#kw',
  1436. target: 'css;#head_wr',
  1437. where: 'afterEnd',
  1438. },
  1439. },
  1440. {name: "谷歌学术",
  1441. enabled: true,
  1442. url: /^https?:\/\/scholar\.google(?:\.\D{1,3}){1,2}\/scholar\?/,
  1443. engineList: "scholar",
  1444. style: '\
  1445. z-index:999;\
  1446. position:relative;\
  1447. ',
  1448. insertIntoDoc: {
  1449. target: 'css;#gs_ab',
  1450. keyword: '//input[@name="q"]',
  1451. where: 'beforeBegin'
  1452. }
  1453. },
  1454. {name: "cnki",
  1455. url: /^http:\/\/search\.cnki\.net\/search\.aspx/i,
  1456. enabled: true,
  1457. engineList: "scholar",
  1458. style: '\
  1459. padding-left:15px;\
  1460. border-top:1px solid #D9E1F7;\
  1461. border-bottom:1px solid #D9E1F7;\
  1462. margin-top:-1px;\
  1463. ',
  1464. insertIntoDoc: {
  1465. keyword:'css;#txtSearchKey',
  1466. target:'css;.main',
  1467. where:'afterBegin',
  1468. },
  1469. },
  1470. {name: "知网",
  1471. enabled: true,
  1472. url: /^http:\/\/epub\.cnki\.net\/kns\/brief\/default_result\.aspx/i,
  1473. engineList: "scholar",
  1474. style: '\
  1475. border-bottom:1px solid #E5E5E5;\
  1476. border-top:1px solid #E5E5E5;\
  1477. z-index:999;\
  1478. position:relative;\
  1479. ',
  1480. insertIntoDoc: {
  1481. keyword:'css;#txt_1_value1',
  1482. target:'css;#TopSearchBar',
  1483. where:'afterEnd',
  1484. }
  1485. },
  1486. {name: "万方",
  1487. enabled: true,
  1488. url: /^https?:\/\/s\.g\.wanfangdata\.com\.cn\/Paper\.aspx/i,
  1489. engineList: "scholar",
  1490. style: '\
  1491. border-bottom:1px solid #E5E5E5;\
  1492. border-top:1px solid #E5E5E5;\
  1493. z-index:999;\
  1494. position:relative;\
  1495. ',
  1496. insertIntoDoc: {
  1497. keyword:'css;#queryBox',
  1498. target:'css;#content',
  1499. where:'beforeBegin',
  1500. }
  1501. },
  1502. {name: "EBSCO",
  1503. enabled: true,
  1504. url: /^http:\/\/.*?ebscohost\.com\/.*?results/i,
  1505. engineList: "scholar",
  1506. style: '\
  1507. border-bottom:1px solid #E5E5E5;\
  1508. border-top:1px solid #E5E5E5;\
  1509. position:relative;\
  1510. ',
  1511. insertIntoDoc: {
  1512. keyword:'css;#SearchTerm1',
  1513. target:'css;#findFieldOuter',
  1514. where:'afterend',
  1515. }
  1516. },
  1517. {name: "Springer",
  1518. enabled: true,
  1519. url: /^http:\/\/link\.springer\.com\/search\?query=/i,
  1520. engineList: "scholar",
  1521. style: '\
  1522. border-bottom:1px solid #E5E5E5;\
  1523. border-top:1px solid #E5E5E5;\
  1524. position:relative;\
  1525. ',
  1526. insertIntoDoc: {
  1527. keyword:'css;#query',
  1528. target:'css;#content',
  1529. where:'beforeBegin',
  1530. }
  1531. },
  1532. {name: "JSTOR",
  1533. enabled: true,
  1534. url: /^https?:.*?jstor.org\/action\/doAdvancedSearch/i,
  1535. engineList: "scholar",
  1536. style: '\
  1537. border-bottom:1px solid #E5E5E5;\
  1538. border-top:1px solid #E5E5E5;\
  1539. position:relative;\
  1540. ',
  1541. insertIntoDoc: {
  1542. keyword:'css;#searchBox',
  1543. target:'css;.tabs-search-results',
  1544. where:'beforeBegin',
  1545. }
  1546. },
  1547.  
  1548. //html 列表
  1549. {name: "w3c",
  1550. enabled:true,
  1551. url:/^https?:.*?runoob\.com\//i,
  1552. engineList:"mine",
  1553. style: '\
  1554. border-bottom:1px solid #E5E5E5;\
  1555. border-top:1px solid #E5E5E5;\
  1556. position:relative;\
  1557. text-align:center;\
  1558. ',
  1559. insertIntoDoc: {
  1560. keyword:function(){
  1561. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  1562. return decodeURIComponent(url);
  1563. },
  1564. target:'css;.navigation',
  1565. where:'afterEnd',
  1566. }
  1567. },
  1568. {
  1569. name: "GitHub",
  1570. enabled:true,
  1571. url:/^https?:\/\/github\.com\/search/,
  1572. engineList:"mine",
  1573. style:'\
  1574. position:relative;\
  1575. text-align:center;\
  1576. ',
  1577. insertIntoDoc: {
  1578. keyword:'//input[@name="q"]',
  1579. target:'css;.Header',
  1580. where:'afterEnd',
  1581. }
  1582. },
  1583. {
  1584. name: "MDN",
  1585. enabled:true,
  1586. url:/^https?:\/\/developer\.mozilla\.org\/.{2,5}\/search/,
  1587. engineList:"mine",
  1588. style:'\
  1589. position:relative;\
  1590. text-align:center;\
  1591. ',
  1592. insertIntoDoc: {
  1593. keyword:function(){
  1594. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  1595. return decodeURIComponent(url);
  1596. },
  1597. target:'css;.results-search-form',
  1598. where:'afterEnd',
  1599. }
  1600. },
  1601.  
  1602. // 其他补充, 这个脚本将会朝重型方向发展,如果嫌弃代码过多,可自行删减无用代码
  1603. {
  1604. name: "infinitynewtab",
  1605. enabled:true,
  1606. //https://google.infinitynewtab.com/?q=苹果
  1607. url:/^https?:\/\/google\.infinitynewtab\.com\/\?q/,
  1608. engineList:"web",
  1609. style:'\
  1610. text-align:center;\
  1611. position:fixed;\
  1612. z-index:99999;\
  1613. top:0;\
  1614. ',
  1615. insertIntoDoc: {
  1616. target: 'css;.searchbox-results',
  1617. // keyword: '//input[@name="search"]',
  1618. keyword: 'css;input.gsc-input',
  1619. where: 'beforeBegin',
  1620. }
  1621. },
  1622. {
  1623. name: "头条搜索",
  1624. //https://so.toutiao.com/search
  1625. url:/^https?:\/\/so\.toutiao\.com\/search/,
  1626. engineList:"web",
  1627. enabled:true,
  1628. fixedTop:75,
  1629. style:'\
  1630. margin-left:146px;\
  1631. z-index:99999;\
  1632. ',
  1633. insertIntoDoc: {
  1634. target: 'css;.result-content',
  1635. // keyword: '//input[@name="search"]',
  1636. keyword: '//input[@type="search"]',
  1637. where: 'beforeEnd',
  1638. }
  1639. },
  1640. {
  1641. name: "抖音搜索",
  1642. url:/^https?:\/\/www\.douyin\.com\/search/,
  1643. engineList:"web",
  1644. enabled:true,
  1645. fixedTop:128,
  1646. fixedTopColor:"rgb(22 23 34)",
  1647. style:`
  1648. position:fixed;
  1649. z-index:99999;
  1650. margin-right:280px;
  1651. `,
  1652. insertIntoDoc: {
  1653. target: 'css;.FtarROQM',
  1654. // keyword: '//input[@name="search"]',
  1655. keyword: function () {
  1656. var input = document.querySelector('input[type="text"]');
  1657. if (input) return input.value;
  1658. },
  1659. where: 'afterBegin',
  1660. },
  1661. stylish:`.J122YuOM{padding-top:14px}
  1662. body {
  1663. --font-color-qxin:#ccc;
  1664. --background-color-qxin: #161722;
  1665. --background-avtive-color-qxin: #424242;
  1666. --background-active-enable-qxin:#274144;
  1667. --background-active-disable-qxin:#583535;
  1668. --background-hover-color-qxin: #424242;
  1669. --trigger-shown-qxin: #424242 !important;
  1670. --sej-drop-list-background-qxin:rgba(0,0,0,0.7);
  1671. --background-btn-qxin:#292f36;
  1672. --background-setting-qxin: #161722;
  1673. }
  1674. .OZ_3F0lc{
  1675. margin-top:10px;
  1676. }
  1677. `,
  1678. },
  1679. // 用户补充: kidzgy
  1680. // https://gf.qytechs.cn/zh-CN/scripts/27752/discussions/90497
  1681. {
  1682. name: "企查查",
  1683. url: /^https?:\/\/www\.qcc\.com\/(?:web|firm|)/,
  1684. engineList: 'enterprise',
  1685. enabled: true,
  1686. fixedTop:56,
  1687. style: '\
  1688. width:1250px;\
  1689. margin: 0 auto;\
  1690. padding-left: 15px;\
  1691. ',
  1692. insertIntoDoc: {
  1693. keyword: 'css;#searchKey',
  1694. target: 'css;.app-nheader',
  1695. where: 'AfterEnd',
  1696. },
  1697. stylish: ' .bigsearch-nav.fixed > .nav-wrap { position: static !important; }',
  1698. },
  1699. {
  1700. name: "天眼查",
  1701. url: /^https?:\/\/www\.tianyancha\.com\/(?:search|company)/,
  1702. engineList: 'enterprise',
  1703. enabled: true,
  1704. fixedTop:73,
  1705. style: '\
  1706. top:80px;\
  1707. margin: 0 auto;\
  1708. width:1248px;\
  1709. ',
  1710. insertIntoDoc: {
  1711. keyword: 'css;#header-company-search',
  1712. target: 'css;.tyc-header',
  1713. where: 'AfterEnd',
  1714. },
  1715. stylish: '#web-content.mt122{margin-top:90px !important} .search-bar{position:static !important}',
  1716. },
  1717.  
  1718.  
  1719. // 回家没网,用8090端口离线测试使用。
  1720. {
  1721. name:"test",
  1722. enabled:true,
  1723. url:/^https?:\/\/127\.0\.0\.1:8090\/./,
  1724. style:"\
  1725. margin:150px;\
  1726. ",
  1727. insertIntoDoc: {
  1728. keyword:function(){return false},
  1729. target:'css;body',
  1730. where:'beforeEnd',
  1731. }
  1732. }
  1733. ];
  1734. // 有些图标需要重复使用
  1735. var icon ={};
  1736. icon = {
  1737. google:"',
  1740. edit:"",
  1741. del:"",
  1742. web : "",
  1743. translate: "",
  1746. video:"",
  1747. music:"",
  1749. sociality:"",
  1752. news:"",
  1753. mine:"data:image/svg+xml,%3Csvg t='1666874111000' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='27179' width='32' height='32'%3E%3Cpath d='M949.888 457.258667c26.069333-29.824 13.866667-67.52-24.789333-76.309334L681.728 325.546667l-127.786667-214.677334c-20.266667-34.069333-59.925333-34.090667-80.213333 0l-127.786667 214.677334-243.370666 55.381333c-38.442667 8.746667-50.858667 46.506667-24.789334 76.309333l164.394667 188.053334-22.613333 248.917333c-3.584 39.466667 28.458667 62.805333 64.896 47.146667l237.781333-102.037334a21.333333 21.333333 0 0 0-16.810667-39.210666L267.626667 902.186667c-6.698667 2.88-6.229333 3.221333-5.568-4.096l24.277333-267.093334-176.426667-201.813333c-4.757333-5.461333-4.906667-5.034667 2.133334-6.634667l261.205333-59.434666 137.152-230.4c3.733333-6.293333 3.136-6.293333 6.869333 0l137.173334 230.4 261.205333 59.434666c7.125333 1.621333 6.954667 1.088 2.133333 6.613334l-176.426666 201.813333 24.256 267.093333a21.333333 21.333333 0 1 0 42.496-3.84l-22.613334-248.917333 164.394667-188.053333z' fill='%233D3D3D' p-id='27180'%3E%3C/path%3E%3C/svg%3E",
  1754. };
  1755.  
  1756. // 搜索引擎列表
  1757. var engineList = {};
  1758.  
  1759. // 网页搜索列表
  1760. engineList.web = [];
  1761.  
  1762. engineList.web[0] = {
  1763. name: '百度',
  1764. url: 'https://www.baidu.com/s?wd=%s&ie=utf-8',
  1765. favicon: icon.baidu,
  1766. };
  1767. // engineList.web[0] 中间的数字表示排序(数字不能重复,否则后面的会覆盖掉前面的),越小数字越靠前,小于0该引擎不会显示在页面上
  1768. engineList.web[1] = {
  1769. // 搜索引擎名称
  1770. name: 'Google',
  1771. // 搜索引擎地址,关键字变量用%s代替
  1772. url: 'https://www.google.com/search?q=%s&ie=utf-8&oe=utf-8',
  1773. // 搜索引擎的站点图标
  1774. // favicon: '',
  1775. favicon: icon.google,
  1776. // 弃用;搜索引擎编码(默认utf-8)如果跳转后乱码可以填写 'gbk'
  1777. // 弃用:encoding: 'utf-8',
  1778. // 如果网站使用的gbk编码
  1779. gbk:false,
  1780. // 新标签页打开
  1781. // blank:true,
  1782. // 禁用该搜索, 只在设置中显示该搜索
  1783. // disable:true,
  1784. };
  1785. engineList.web[2] = {
  1786. name: '必应',
  1787. url: 'https://cn.bing.com/search?q=%s',
  1788. favicon: icon.bing,
  1789. };
  1790. engineList.web[3] = {
  1791. name: '360',
  1792. url: 'https://www.so.com/s?ie=utf-8&q=%s',
  1793. favicon: '',
  1794. // disable:true,
  1795. };
  1796. engineList.web[4] = {
  1797. name: 'yahoo',
  1798. url: 'https://search.yahoo.com/search;?p=%s',
  1799. favicon: "data:image/svg+xml,%3Csvg t='1666872979419' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='13466' width='32' height='32'%3E%3Cpath d='M513.216 69.568C332.224 69.568 161.216 45.76 0 0v1024c161.408-45.824 332.416-69.632 513.216-69.632 178.816 0 349.376 23.232 510.784 69.632V0c-161.408 46.4-331.776 69.568-510.784 69.568z m283.584 87.424l-6.208 9.792c-5.824 9.216-11.008 17.024-18.176 28.032-9.6 14.4-27.584 43.008-49.216 79.808-6.016 10.176-13.376 22.4-20.992 35.584l-44.032 74.368-16.384 28.608-43.392 75.584c-14.592 25.792-28.992 51.2-43.392 76.416v25.408c0 35.2 0.768 73.6 1.984 107.776 0.576 15.616 1.216 43.392 1.984 72.768 0.768 35.008 1.6 71.232 2.624 89.6l0.192 5.632v0.576l-6.016-1.6-6.976-1.792a197.952 197.952 0 0 0-22.592-3.584 172.224 172.224 0 0 0-28.416 0 195.712 195.712 0 0 0-29.568 5.376l-6.016 1.6v-0.576l0.192-5.632c0.832-18.176 1.792-54.592 2.624-89.6 0.576-29.376 1.408-57.216 1.984-72.768a2721.92 2721.92 0 0 0 1.984-107.776v-25.408L425.6 488.768c-14.208-25.024-28.992-50.624-43.2-75.584-5.632-9.6-11.008-19.2-16.384-28.608-12.8-22.208-29.376-49.984-44.032-74.368a2038.784 2038.784 0 0 1-20.992-35.584 1986.112 1986.112 0 0 0-49.216-79.808c-7.168-11.008-12.416-18.816-18.176-28.032l-6.208-9.792 11.2 3.2c14.208 4.032 28.8 6.016 44.416 6.016s30.592-1.984 44.608-6.016l3.392-1.024 1.792 3.008c27.584 49.792 101.824 171.776 146.176 244.8 15.168 25.216 27.392 44.992 33.408 55.168v-0.192 0.192l33.408-55.168c44.416-72.832 118.592-194.816 146.176-244.8l1.792-3.008 3.392 1.024c14.016 4.032 28.992 6.016 44.608 6.016s30.208-1.984 44.416-6.016l10.624-3.2z' p-id='13467' fill='%234C07A2'%3E%3C/path%3E%3C/svg%3E",
  1800. disable:true,
  1801. };
  1802. engineList.web[5] = {
  1803. name: '搜狗',
  1804. url: 'https://www.sogou.com/web?query=%s',
  1805. favicon: "data:image/svg+xml,%3Csvg t='1666872860655' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='11496' width='32' height='32'%3E%3Cpath d='M716.8 0c169.664 0 307.2 137.536 307.2 307.2v409.6c0 169.664-137.536 307.2-307.2 307.2H307.2C137.536 1024 0 886.464 0 716.8V307.2C0 137.536 137.536 0 307.2 0h409.6z m91.904 305.536c-18.304-22.016-176.1792-92.8384-333.8496-87.6672-157.6704 5.1712-277.568 84.3904-277.568 155.6864 0 71.3088 22.5408 161.3824 277.568 192.5632 221.4912 30.336 114.3424 113.8944 0 113.8944s-180.0832-41.1776-228.8256-41.1776c-48.7424 0-81.856 42.3808-21.2224 96.5888 55.36 49.4976 158.6304 62.1056 252.8512 69.568C571.8784 812.4544 832 794.88 832 638.8352c0-152.9088-205.8624-196.3776-294.5024-206.0416-88.6272-9.6768-131.1232-44.0064-131.1232-59.2384 0-15.5264 37.5552-54.0544 123.2512-44.096 85.696 9.9584 182.6304 44.096 221.696 44.096 39.0784 0 75.6992-46.0032 57.3824-68.0192z' fill='%23FF7D2A' p-id='11497'%3E%3C/path%3E%3C/svg%3E",
  1806. disable:true,
  1807. };
  1808. engineList.web[6] = {
  1809. name: 'Startpage',
  1810. url: 'https://www.startpage.com/do/asearch$post$query',
  1811. favicon: '',
  1812. disable:true,
  1813. };
  1814. engineList.web[7] = {
  1815. name: 'Yandex',
  1816. url: 'https://yandex.com/search/?text=%s',
  1817. favicon: "data:image/svg+xml,%3Csvg t='1666872628734' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='10516' width='200' height='200'%3E%3Cpath d='M451 1024V691.8L229 96h111.6l163.6 459.4L692.4 0h102.6L553.6 695.6V1024h-102.6z' p-id='10517' fill='%23FC401D'%3E%3C/path%3E%3C/svg%3E",
  1818. };
  1819. engineList.web[8] = {
  1820. name: 'DDG',
  1821. url: 'https://duckduckgo.com/?q=%s',
  1822. favicon: '',
  1823. disable:true,
  1824. };
  1825.  
  1826.  
  1827. // 视频搜索列表
  1828. engineList.video = [];
  1829.  
  1830. engineList.video[0] = {
  1831. name: 'bilibili',
  1832. url: 'http://search.bilibili.com/all?keyword=%s',
  1833. favicon: '',
  1834. };
  1835. engineList.video[1] = {
  1836. name: 'YouTube',
  1837. url: 'https://www.youtube.com/results?search_query=%s',
  1838. favicon: "data:image/svg+xml,%3Csvg t='1666872437167' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='8429' width='32' height='32'%3E%3Cpath d='M426.666667 682.666667V384l256 149.845333L426.666667 682.666667z m587.093333-355.541334s-10.026667-71.04-40.704-102.357333c-38.954667-41.088-82.602667-41.258667-102.613333-43.648C727.168 170.666667 512.213333 170.666667 512.213333 170.666667h-0.426666s-214.954667 0-358.229334 10.453333c-20.053333 2.389333-63.658667 2.56-102.656 43.648-30.677333 31.317333-40.661333 102.4-40.661333 102.4S0 410.538667 0 493.952v78.293333c0 83.456 10.24 166.912 10.24 166.912s9.984 71.04 40.661333 102.357334c38.997333 41.088 90.154667 39.765333 112.938667 44.074666C245.76 893.568 512 896 512 896s215.168-0.341333 358.442667-10.752c20.053333-2.432 63.658667-2.602667 102.613333-43.690667 30.72-31.317333 40.704-102.4 40.704-102.4s10.24-83.413333 10.24-166.869333v-78.250667c0-83.456-10.24-166.912-10.24-166.912z' fill='%23FF0000' p-id='8430'%3E%3C/path%3E%3C/svg%3E",
  1839. };
  1840. engineList.video[2] = {
  1841. name: '抖音搜索',
  1842. url: 'https://www.douyin.com/search/%s',
  1843. favicon: "data:image/svg+xml,%3Csvg t='1666873215809' class='icon' viewBox='0 0 1029 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='17442' width='32' height='32'%3E%3Cpath d='M259.3792 385.3312m-170.5984 0a170.5984 170.5984 0 1 0 341.1968 0 170.5984 170.5984 0 1 0-341.1968 0Z' fill='%2303F9AD' p-id='17443'%3E%3C/path%3E%3Cpath d='M403.968 568.4224m-170.5984 0a170.5984 170.5984 0 1 0 341.1968 0 170.5984 170.5984 0 1 0-341.1968 0Z' fill='%23F9F90B' p-id='17444'%3E%3C/path%3E%3Cpath d='M631.3984 622.2848m-88.6784 0a88.6784 88.6784 0 1 0 177.3568 0 88.6784 88.6784 0 1 0-177.3568 0Z' fill='%230FF420' p-id='17445'%3E%3C/path%3E%3Cpath d='M753.0496 565.248m-88.6784 0a88.6784 88.6784 0 1 0 177.3568 0 88.6784 88.6784 0 1 0-177.3568 0Z' fill='%23DA0DF7' p-id='17446'%3E%3C/path%3E%3Cpath d='M594.0224 369.3568m-223.0272 0a223.0272 223.0272 0 1 0 446.0544 0 223.0272 223.0272 0 1 0-446.0544 0Z' fill='%23FF0000' p-id='17447'%3E%3C/path%3E%3Cpath d='M901.12 1024h-778.24c-67.584 0-122.88-55.296-122.88-122.88V122.88c0-67.584 55.296-122.88 122.88-122.88h778.24c67.584 0 122.88 55.296 122.88 122.88v778.24c0 67.584-55.296 122.88-122.88 122.88z' fill='%23070103' p-id='17448'%3E%3C/path%3E%3Cpath d='M829.44 268.0832c-89.7024-0.1024-162.304-72.8064-162.304-162.4064 0-1.024 0.1024-2.048 0.1024-3.072h-72.4992v-19.456c-0.7168 7.3728-1.1264 14.9504-1.1264 22.528s0.4096 15.0528 1.1264 22.528v576.7168h-1.7408c0 89.7024-72.704 162.4064-162.4064 162.4064s-162.4064-72.704-162.4064-162.4064 72.704-162.4064 162.4064-162.4064c36.7616 0 70.5536 12.1856 97.792 32.768v-85.0944a234.496 234.496 0 0 0-97.792-21.1968c-130.3552 0-235.9296 105.6768-235.9296 235.9296 0 130.3552 105.6768 235.9296 235.9296 235.9296s235.9296-105.6768 235.9296-235.9296c0-0.7168 0-1.4336-0.1024-2.1504h0.1024V276.1728a235.4176 235.4176 0 0 0 162.9184 65.536v-73.6256z' fill='%23FFFFFF' p-id='17449'%3E%3C/path%3E%3C/svg%3E",
  1844. };
  1845. engineList.video[3] = {
  1846. name: '优酷',
  1847. url: "http://www.soku.com/search_video/q_%s",
  1848. favicon: '',
  1849. };
  1850. engineList.video[4] = {
  1851. name: '腾讯视频',
  1852. url: 'https://v.qq.com/x/search/?q=%s',
  1853. favicon: '',
  1854. };
  1855. engineList.video[5] = {
  1856. name: 'AcFun',
  1857. url: 'https://www.acfun.cn/search/?type=complex&keyword=%s',
  1858. favicon: '',
  1859. };
  1860. engineList.video[6] = {
  1861. name: '搜狐',
  1862. url: 'http://so.tv.sohu.com/mts?wd=%s',
  1863. favicon: '',
  1864. blank:true,
  1865. };
  1866. engineList.video[7] = {
  1867. name: 'niconico',
  1868. url: 'http://www.nicovideo.jp/search/%s',
  1869. favicon: '',
  1870. };
  1871. engineList.video[8] = {
  1872. name: '爱奇艺',
  1873. url: 'http://so.iqiyi.com/so/q_%s',
  1874. favicon: '',
  1875. };
  1876. engineList.video[9] = {
  1877. name: "樱花动漫",
  1878. url: "http://www.imomoe.in/search.asp?searchword=%s",
  1879. favicon: "",
  1880. gbk: "true",
  1881. disable:true,
  1882. }
  1883.  
  1884. // 音乐搜索列表
  1885. engineList.music = [];
  1886.  
  1887. engineList.music[0] = {
  1888. name: '网易音乐',
  1889. url: 'http://music.163.com/#/search/m/?s=%s',
  1890. favicon: "data:image/svg+xml,%3Csvg t='1666873073102' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='14673' width='200' height='200'%3E%3Cpath d='M604.71296 63.911253c-53.548373 19.667627-95.06816 77.038933-95.06816 132.222293 0 16.390827 3.822933 43.165013 8.741547 59.55584 4.911787 16.390827 7.645867 30.59712 6.557013 31.143253-0.546133 1.092267-18.03264 9.28768-38.792533 18.57536-72.669867 33.3312-124.576427 101.07904-134.956373 176.479573-18.029227 126.76096 60.101973 230.57408 173.202773 230.57408 72.666453 0 134.95296-43.165013 160.631467-110.36672 16.940373-45.89568 11.47904-104.905387-20.21376-204.89216-8.192-25.678507 54.64064 9.28768 95.617707 54.091093 50.26816 54.637227 68.297387 135.502507 46.987947 214.17984-19.124907 69.389653-77.03552 136.598187-146.428587 168.28416-184.674987 84.691627-385.737387-11.472213-440.920747-210.899627-20.763307-74.8544-13.66016-145.33632 22.401707-222.921387 27.86304-60.101973 86.326613-120.203947 146.97472-150.254933 48.626347-24.040107 58.463573-32.23552 62.83264-52.452693 3.826347-18.57536-8.741547-45.89568-25.678507-55.18336-36.061867-19.67104-118.019413 21.30944-192.8704 96.160427-68.84352 68.84352-101.625173 128.39936-119.657813 216.91392-38.792533 187.948373 57.91744 387.92192 227.84 470.429013 61.740373 30.59712 112.551253 42.06592 182.490453 42.06592 154.077867 0 289.57696-78.67392 355.689813-206.527147 32.781653-62.83264 40.977067-100.532907 37.700267-175.93344-2.73408-72.123733-10.92608-102.720853-40.98048-152.439467-49.718613-82.50368-134.406827-142.05952-216.364373-152.9856l-27.316907-3.280213-9.84064-32.781653c-13.653333-45.349547-12.56448-60.101973 4.37248-73.212587 18.029227-14.206293 37.700267-14.752427 62.286507-1.092267 46.441813 26.22464 54.64064 28.409173 73.216 22.398293 19.124907-6.007467 36.05504-30.047573 36.05504-51.357013 0-19.67104-26.76736-48.080213-63.924907-66.112853C696.507733 55.169707 639.68256 50.797227 604.71296 63.911253zM574.65856 460.032c19.12832 71.031467 20.76672 91.245227 9.291093 113.646933-18.57536 34.966187-72.666453 46.987947-99.44064 21.85216-22.401707-20.759893-29.50144-39.8848-29.50144-78.677333 0-40.434347 10.92608-67.20512 36.604587-90.699093 18.578773-17.483093 57.91744-38.2464 62.28992-33.327787C555.54048 395.014827 564.82816 425.065813 574.65856 460.032z' p-id='14674' fill='%23d81e06'%3E%3C/path%3E%3C/svg%3E",
  1891. };
  1892. engineList.music[1] = {
  1893. name: 'QQ音乐',
  1894. url: 'https://y.qq.com/portal/search.html#page=1&searchid=1&remoteplace=txt.yqq.top&t=song&w=%s',
  1895. favicon: '',
  1896. blank:true,
  1897. };
  1898. engineList.music[2] = {
  1899. name: '百度音乐',
  1900. url: 'http://music.baidu.com/search?ie=utf-8&oe=utf-8&key=%s',
  1901. favicon: icon.baidu,
  1902. };
  1903. engineList.music[3] = {
  1904. name: '酷我音乐',
  1905. url: 'http://sou.kuwo.cn/ws/NSearch?type=all&key=%s',
  1906. favicon: '',
  1907. blank:true,
  1908. };
  1909. engineList.music[4] = {
  1910. name: '5sing',
  1911. url: 'http://search.5sing.kugou.com/?keyword=%s',
  1912. favicon: '',
  1913. blank:true,
  1914. };
  1915. engineList.music[5] = {
  1916. name: '一听',
  1917. url: 'http://so.1ting.com/all.do?q=%s',
  1918. favicon: '',
  1919. };
  1920.  
  1921. // 图片搜索列表
  1922. engineList.image = [];
  1923.  
  1924. engineList.image[0] = {
  1925. name: '百度图片',
  1926. url: 'http://image.baidu.com/search/index?tn=baiduimage&ie=utf-8&word=%s',
  1927. favicon: icon.baidu,
  1928. };
  1929. engineList.image[1] = {
  1930. name: '谷歌图片',
  1931. url: 'https://www.google.com/search?q=%s&tbm=isch',
  1932. favicon: icon.google,
  1933. };
  1934. engineList.image[2] = {
  1935. name: '必应图片',
  1936. url: 'https://www.bing.com/images/search?q=%s',
  1937. favicon: icon.bing
  1938. };
  1939. engineList.image[3] = {
  1940. name: 'pixiv',
  1941. url: 'http://www.pixiv.net/search.php?word=%s',
  1942. favicon: '',
  1943. };
  1944. engineList.image[4] = {
  1945. name: 'flickr',
  1946. url: 'http://www.flickr.com/search/?q=%s',
  1947. favicon: '',
  1948. };
  1949. engineList.image[5] = {
  1950. name: '花瓣',
  1951. url: 'http://huaban.com/search/?q=%s',
  1952. favicon: '',
  1953. };
  1954. engineList.image[6] = {
  1955. name: 'Pinterest',
  1956. url: 'https://www.pinterest.com/search/pins/?q=%s&rs=typed&term_meta',
  1957. favicon: '',
  1958. };
  1959. engineList.image[7] = {
  1960. name: 'Yandex',
  1961. url: 'https://yandex.com/images/search?from=tabbar&text=%s',
  1962. favicon: "data:image/svg+xml,%3Csvg t='1666872628734' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='10516' width='200' height='200'%3E%3Cpath d='M451 1024V691.8L229 96h111.6l163.6 459.4L692.4 0h102.6L553.6 695.6V1024h-102.6z' p-id='10517' fill='%23FC401D'%3E%3C/path%3E%3C/svg%3E",
  1963. };
  1964.  
  1965. // 下载资源
  1966. engineList.download = [];
  1967.  
  1968. engineList.download[0] = {
  1969. name: '海盗湾',
  1970. url: 'https://thepiratebay.org/search/%s',
  1971. favicon: ''
  1972. };
  1973. engineList.download[1] = {
  1974. name: '谷歌搜索',
  1975. blank:true,
  1976. url: 'https://cse.google.com/?q=%s&newwindow=1&cx=006100883259189159113%3Atwgohm0sz8q',
  1977. favicon: icon.google,
  1978. };
  1979. engineList.download[2] = {
  1980. name: '动漫花园',
  1981. url: 'https://share.dmhy.org/topics/list?keyword=%s',
  1982. favicon: ''
  1983. };
  1984.  
  1985.  
  1986. // 购物列表
  1987.  
  1988. engineList.shopping = [];
  1989. engineList.shopping[0] = {
  1990. name: '淘宝',
  1991. url: 'http://s.taobao.com/search?q=%s',
  1992. favicon: "data:image/svg+xml,%3Csvg t='1666880201701' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='32068' width='32' height='32'%3E%3Cpath d='M228.96 172.16a76.64 76.64 0 1 0 75.84 76.64 76.32 76.32 0 0 0-75.84-76.64zM317.76 535.52C307.52 458.24 160 360.48 160 360.48l-57.6 82.24s123.84 61.92 134.08 112S66.56 753.28 66.56 753.28l128 94.4s133.28-235.04 123.2-312.16z' fill='%23FE5100' p-id='32069'%3E%3C/path%3E%3Cpath d='M957.44 380.96c0-66.88-66.4-152.32-174.72-171.52s-263.04 60-286.88 64-30.56-3.52-30.56-3.52l27.2-53.12L400 178.56A416 416 0 0 1 355.04 288a425.28 425.28 0 0 1-74.72 92.64L338.08 432l76.32-90.88 50.88 5.12L372 464s3.36 39.52 32 41.28 72.96-67.04 72.96-67.04l52.48 10.4 1.76 68.64H360.16v46.24l169.6 5.12v145.92s-48.96 7.36-70.56-23.2-12.96-78.72-12.96-78.72L336 609.28s-6.88 84.64 22.56 126.88 90.24 57.12 152 51.84 215.84-70.72 215.84-70.72l10.08 46.4 81.44-37.76-49.12-130.4-66.24 13.76 6.88 56.64-81.6 36v-130.4L800 564.64v-48H624.8V448h168v-54.88H517.92l40.8-80A562.88 562.88 0 0 1 679.2 272c48-6.88 69.44-10.24 113.6 17.12a108.48 108.48 0 0 1 50.88 67.04v381.76a96 96 0 0 1-60.96 53.12c-48 16-124-1.6-124-1.6l-6.72 53.12s128 25.76 210.4-8.48 95.04-132.16 95.04-132.16z' fill='%23FE5100' p-id='32070'%3E%3C/path%3E%3C/svg%3E",
  1993. };
  1994. engineList.shopping[1] = {
  1995. name: '京东',
  1996. url: 'http://search.jd.com/Search?keyword=%s&enc=utf-8',
  1997. favicon: '',
  1998. };
  1999. engineList.shopping[2] = {
  2000. name: '苏宁',
  2001. url: 'http://search.suning.com/%s/',
  2002. favicon: '',
  2003. };
  2004. engineList.shopping[3] = {
  2005. name: '亚马逊',
  2006. url: 'http://www.amazon.cn/s/ref=nb_sb_noss?field-keywords=%s',
  2007. favicon: '',
  2008. };
  2009. engineList.shopping[4] = {
  2010. name: '天猫',
  2011. url: 'http://list.tmall.com/search_product.htm?q=%s',
  2012. favicon: '',
  2013. };
  2014. engineList.shopping[5] = {
  2015. name: '值得买',
  2016. url: 'http://search.smzdm.com/?c=home&s=%s',
  2017. favicon: '',
  2018. blank:true,
  2019. };
  2020. engineList.shopping[6] = {
  2021. name: '当当网',
  2022. url: 'http://search.dangdang.com/?key=%s',
  2023. favicon: '',
  2024. blank:true,
  2025. };
  2026. engineList.shopping[7] = {
  2027. name: '1688',
  2028. url: 'https://s.1688.com/selloffer/offer_search.htm?keywords=%s',
  2029. favicon: '',
  2030. blank:true,
  2031. gbk:true,
  2032. };
  2033.  
  2034. //翻译列表
  2035. engineList.translate = [];
  2036.  
  2037. engineList.translate[0] = {
  2038. name: '百度翻译',
  2039. url: 'http://fanyi.baidu.com/#auto/zh/%s',
  2040. favicon: "data:image/svg+xml,%3Csvg t='1666877034366' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='29943' width='32' height='32'%3E%3Cpath d='M938.666667 981.333333c-17.066667 0-29.866667-8.533333-38.4-25.6l-59.733334-119.466666h-277.333333l-59.733333 119.466666c-8.533333 21.333333-34.133333 29.866667-55.466667 17.066667-25.6-8.533333-34.133333-34.133333-21.333333-51.2l72.533333-140.8 145.066667-290.133333c12.8-21.333333 34.133333-38.4 59.733333-38.4s46.933333 12.8 59.733333 38.4l145.066667 290.133333 72.533333 140.8c8.533333 21.333333 0 46.933333-17.066666 55.466667-12.8 4.266667-17.066667 4.266667-25.6 4.266666z m-332.8-226.133333h192l-98.133334-192-93.866666 192zM85.333333 844.8c-17.066667 0-29.866667-8.533333-38.4-25.6-8.533333-21.333333 0-46.933333 21.333334-55.466667 93.866667-46.933333 179.2-110.933333 247.466666-187.733333-46.933333-64-85.333333-128-110.933333-192-8.533333-21.333333 4.266667-46.933333 25.6-55.466667 21.333333-8.533333 46.933333 4.266667 55.466667 25.6 21.333333 51.2 46.933333 102.4 81.066666 149.333334 59.733333-85.333333 102.4-179.2 128-281.6H85.333333c-25.6 0-42.666667-17.066667-42.666666-42.666667s17.066667-42.666667 42.666666-42.666667h243.2V85.333333c0-25.6 17.066667-42.666667 42.666667-42.666666s42.666667 17.066667 42.666667 42.666666v51.2h238.933333c25.6 0 42.666667 17.066667 42.666667 42.666667s-17.066667 42.666667-42.666667 42.666667h-68.266667c-25.6 128-85.333333 247.466667-162.133333 349.866666l25.6 25.6c17.066667 17.066667 17.066667 42.666667 0 59.733334-17.066667 17.066667-42.666667 17.066667-59.733333 0l-17.066667-17.066667c-72.533333 81.066667-162.133333 149.333333-264.533333 200.533333-8.533333 0-17.066667 4.266667-21.333334 4.266667z' p-id='29944' fill='%231296db'%3E%3C/path%3E%3C/svg%3E",
  2041. };
  2042. engineList.translate[1] = {
  2043. name: '谷歌翻译',
  2044. url: 'https://translate.google.com/?q=%s',
  2045. favicon: '',
  2046. };
  2047. engineList.translate[2] = {
  2048. name: '有道词典',
  2049. url: 'http://dict.youdao.com/search?q=%s',
  2050. favicon: '',
  2051. blank:true,
  2052. };
  2053. engineList.translate[3] = {
  2054. name: '必应词典',
  2055. url: 'http://cn.bing.com/dict/search?q=%s',
  2056. favicon: icon.bing
  2057. };
  2058. engineList.translate[4] = {
  2059. name: 'Forvo发音',
  2060. url: 'https://zh.forvo.com/search/%s',
  2061. favicon: '',
  2062. blank:true,
  2063. };
  2064. engineList.translate[5] = {
  2065. name: 'CNKI翻译',
  2066. url: 'http://dict.cnki.net/dict_result.aspx?searchword=%s',
  2067. favicon: '',
  2068. disable:true,
  2069. };
  2070. engineList.translate[6] = {
  2071. name: '汉典',
  2072. url: 'http://www.zdic.net/sousuo/?q=%s',
  2073. favicon: '',
  2074. disable:true,
  2075. };
  2076. engineList.translate[7] = {
  2077. name: '海词',
  2078. url: 'http://dict.cn/%s',
  2079. favicon: "",
  2080. };
  2081. engineList.translate[8] = {
  2082. name: 'DeepL',
  2083. url: 'https://www.deepl.com/translator#zh/en/%s',
  2084. favicon: "",
  2085. disable:true,
  2086. };
  2087. engineList.translate[9] = {
  2088. name: '金山词霸',
  2089. url: 'https://www.iciba.com/word?w=%s',
  2090. favicon: "",
  2091. blank:true,
  2092. };
  2093.  
  2094. //知识列表
  2095. engineList.knowledge = [];
  2096. engineList.knowledge[0] = {
  2097. name: '知乎',
  2098. url: 'http://www.zhihu.com/search?q=%s',
  2099. favicon: "data:image/svg+xml,%3Csvg t='1666873123741' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='15646' width='32' height='32'%3E%3Cpath d='M539.101 769.844l-76.117 48.43-96.094-151.063c-19.842 63.221-52.85 120.174-96.455 172.482-18.128 21.78-36.977 41.396-58.667 62.004-6.99 6.629-34.947 32.332-39.592 36.976l-63.762-63.762c6.268-6.268 35.489-33.143 41.26-38.6 19.391-18.398 35.85-35.623 51.497-54.382 57.089-68.452 91.54-144.75 96.365-235.884H117.749V455.86h180.373V275.485h-39.14c-31.07 57.089-70.256 100.198-118.055 128.832l-46.356-77.29c62.905-37.788 109.351-117.423 136.993-241.7l88.023 19.57c-6.313 28.544-13.664 55.33-22.051 80.402h203.506v90.186H388.31V455.86h112.733v90.186h-104.39l142.45 223.799z m173.068-3.157l50.325-40.268h76.749V275.485H658.869V726.42h33.189l20.111 40.268zM568.682 185.3H929.43v631.307H794.15l-112.733 90.186-45.094-90.186h-67.64V185.299z' fill='%230E87EA' p-id='15647'%3E%3C/path%3E%3C/svg%3E",
  2100. };
  2101. engineList.knowledge[1] = {
  2102. name: '维基',
  2103. url: 'http://zh.wikipedia.org/wiki/%s',
  2104. favicon: '',
  2105. };
  2106. engineList.knowledge[2] = {
  2107. name: '百度百科',
  2108. url: 'http://baike.baidu.com/search/word?pic=1&sug=1&word=%s',
  2109. favicon: icon.baidu,
  2110. disable:true,
  2111. };
  2112. engineList.knowledge[3] = {
  2113. name: '百度文库',
  2114. url: 'http://wenku.baidu.com/search?word=%s&ie=utf-8',
  2115. favicon: icon.baidu,
  2116. };
  2117. engineList.knowledge[4] = {
  2118. name: '豆丁文档',
  2119. url: 'http://www.docin.com/search.do?searchcat=2&searchType_banner=p&nkey=%s',
  2120. favicon: '',
  2121. disable:true,
  2122. };
  2123. engineList.knowledge[5] = {
  2124. name: '爱问知识',
  2125. url: 'http://iask.sina.com.cn/search?searchWord=%s',
  2126. favicon: '',
  2127. disable:true,
  2128. };
  2129. engineList.knowledge[6] = {
  2130. name: '萌娘百科',
  2131. url: 'https://zh.moegirl.org/%s',
  2132. favicon: "",
  2133. blank:true,
  2134. };
  2135. engineList.knowledge[7] = {
  2136. name: '知乎(搜狗)',
  2137. url: 'http://zhihu.sogou.com/zhihu?ie=utf8&query=%s',
  2138. favicon: '',
  2139. disable:true,
  2140. };
  2141. engineList.knowledge[8] = {
  2142. name: 'Quora',
  2143. url: 'https://www.quora.com/search?q=%s',
  2144. favicon: '',
  2145. };
  2146. engineList.knowledge[9] = {
  2147. name: 'stackoverflow',
  2148. url: 'https://stackoverflow.com/search?q=%s',
  2149. favicon: '',
  2150. };
  2151.  
  2152. //社交列表
  2153. engineList.sociality = [];
  2154.  
  2155. engineList.sociality[0] = {
  2156. name: '百度贴吧',
  2157. url: 'http://tieba.baidu.com/f?kw=%s&ie=utf-8',
  2158. favicon: icon.baidu,
  2159. blank:true,
  2160. };
  2161. engineList.sociality[1] = {
  2162. name: '新浪微博',
  2163. url: 'https://s.weibo.com/weibo?q=%s',
  2164. favicon: '',
  2165. };
  2166. engineList.sociality[2] = {
  2167. name: '豆瓣',
  2168. url: 'http://www.douban.com/search?source=suggest&q=%s',
  2169. favicon: '',
  2170. };
  2171. engineList.sociality[3] = {
  2172. name: 'Twitter',
  2173. url: 'https://twitter.com/search/%s',
  2174. favicon: '',
  2175. };
  2176. engineList.sociality[4] = {
  2177. name: 'Facebook',
  2178. url: 'https://www.facebook.com/search/results.php?q=%s',
  2179. favicon: '',
  2180. };
  2181. engineList.sociality[5] = {
  2182. name: '微信搜索',
  2183. url: 'http://weixin.sogou.com/weixin?ie=utf8&type=2&query=%s',
  2184. favicon: '',
  2185. };
  2186.  
  2187.  
  2188. // 学术搜索列表
  2189. engineList.scholar = [];
  2190.  
  2191. engineList.scholar[0] = {
  2192. name: '谷歌学术',
  2193. url: 'https://scholar.google.com/scholar?hl=zh-CN&q=%s',
  2194. favicon: '',
  2195. };
  2196. engineList.scholar[1] = {
  2197. name: '百度学术',
  2198. url: 'http://xueshu.baidu.com/s?wd=%s',
  2199. favicon: icon.baidu,
  2200. };
  2201. engineList.scholar[2] = {
  2202. name: '知网',
  2203. url: 'https://kns.cnki.net/kns8/defaultresult/index?code=SCDB&kw=%s',
  2204. favicon: '',
  2205. };
  2206. engineList.scholar[3] = {
  2207. name: '万方',
  2208. url: 'http://s.g.wanfangdata.com.cn/Paper.aspx?q=%s',
  2209. favicon: '',
  2210. };
  2211. engineList.scholar[4] = {
  2212. name: 'EBSCO',
  2213. url: 'http://web.b.ebscohost.com/ehost/results?sid=8e76c941-084d-4b93-b05a-d5f182196017%40sessionmgr102&vid=1&hid=128&bquery=%s',
  2214. favicon: '',
  2215. };
  2216. engineList.scholar[5] = {
  2217. name: 'WOS',
  2218. url: 'http://apps.webofknowledge.com/UA_GeneralSearch.do?fieldCount=3&action=search&product=UA&search_mode=GeneralSearch&max_field_count=25&max_field_notice=Notice%3A+You+cannot+add+another+field.&input_invalid_notice=Search+Error%3A+Please+enter+a+search+term.&input_invalid_notice_limits=+%3Cbr%2F%3ENote%3A+Fields+displayed+in+scrolling+boxes+must+be+combined+with+at+least+one+other+search+field.&sa_img_alt=Select+terms+from+the+index&value(input1)=%s&value%28select1%29=TI&value%28hidInput1%29=initVoid&value%28hidShowIcon1%29=0&value%28bool_1_2%29=AND&value%28input2%29=&value%28select2%29=AU&value%28hidInput2%29=initAuthor&value%28hidShowIcon2%29=1&value%28bool_2_3%29=AND&value%28input3%29=&value%28select3%29=SO&value%28hidInput3%29=initSource&value%28hidShowIcon3%29=1&limitStatus=collapsed&expand_alt=Expand+these+settings&expand_title=Expand+these+settings&collapse_alt=Collapse+these+settings&collapse_title=Collapse+these+settings&SinceLastVisit_UTC=&SinceLastVisit_DATE=&timespanStatus=display%3A+block&timeSpanCollapsedListStatus=display%3A+none&period=Range+Selection&range=ALL&ssStatus=display%3Anone&ss_lemmatization=On&ss_query_language=&rsStatus=display%3Anone&rs_rec_per_page=10&rs_sort_by=PY.D%3BLD.D%3BVL.D%3BSO.A%3BPG.A%3BAU.A&rs_refinePanel=visibility%3Ashow',
  2219. favicon: '',
  2220. };
  2221. engineList.scholar[6] = {
  2222. name: 'JSTOR',
  2223. url: 'http://www.jstor.org/action/doAdvancedSearch?q0=%s',
  2224. favicon: '',
  2225. };
  2226. engineList.scholar[7] = {
  2227. name: 'Springer',
  2228. url: 'http://rd.springer.com/search?query=%s',
  2229. favicon: '',
  2230. };
  2231.  
  2232. engineList.news = [];
  2233.  
  2234. engineList.news[0] = {
  2235. name: "谷歌中文",
  2236. url: "https://news.google.com/search?q=%s&hl=zh-CN&gl=CN&ceid=CN:zh-Hans",
  2237. favicon:"",
  2238. blank: true,
  2239. };
  2240. engineList.news[1] = {
  2241. name: "百度新闻",
  2242. url: "http://news.baidu.com/ns?word=%s&tn=news&from=news&cl=2&rn=20&ct=1",
  2243. favicon:icon.baidu,
  2244. blank: true,
  2245. };
  2246. engineList.news[2] = {
  2247. name: "网易-百度",
  2248. url: "https://www.baidu.com/s?wd=%s%20site%3Anews.163.com",
  2249. favicon:"",
  2250. blank: true,
  2251. };
  2252. engineList.news[3] = {
  2253. name: "网易-谷歌",
  2254. url: "https://www.google.com.hk/search?q=site:news.163.com+%s",
  2255. favicon:"",
  2256. blank: true,
  2257. };
  2258. engineList.news[4] = {
  2259. name: "腾讯新闻",
  2260. url: "https://www.sogou.com/sogou?site=news.qq.com&query=%s",
  2261. favicon:"",
  2262. blank: true,
  2263. };
  2264. engineList.news[5] = {
  2265. name: "凤凰新闻",
  2266. url: "http://search.ifeng.com/sofeng/search.action?q=%s",
  2267. favicon:"",
  2268. blank: true,
  2269. };
  2270. engineList.news[6] = {
  2271. name: "CNN",
  2272. url: "https://edition.cnn.com/search/?q=%s",
  2273. favicon:"",
  2274. blank: true,
  2275. };
  2276. engineList.news[7] = {
  2277. name: "BBC",
  2278. url: "https://www.bbc.co.uk/search?q=%s",
  2279. favicon:"",
  2280. blank: true,
  2281. };
  2282. engineList.news[8] = {
  2283. name: "Economis",
  2284. url: "https://www.google.com/search?q=site:www.economist.com%20%s",
  2285. favicon:"",
  2286. blank: true,
  2287. };
  2288. engineList.news[9] = {
  2289. name: "今日头条",
  2290. url: "https://www.toutiao.com/search/?keyword=%s",
  2291. favicon:"",
  2292. blank: true,
  2293. };
  2294.  
  2295. // 自用 该列表默认隐藏,
  2296. engineList.mine = [];
  2297.  
  2298. engineList.mine[0] = {
  2299. name: 'MDN',
  2300. url: 'https://developer.mozilla.org/zh-CN/search?q=%s',
  2301. favicon: '',
  2302. };
  2303. engineList.mine[1] = {
  2304. name: 'Can I Use',
  2305. url: 'http://caniuse.com/#search=%s',
  2306. blank:true,
  2307. favicon: '',
  2308. };
  2309. engineList.mine[2] = {
  2310. name: 'GitHub',
  2311. url: 'https://github.com/search?utf8=✓&q=%s',
  2312. favicon: '',
  2313. blank:true,
  2314. };
  2315. engineList.mine[3] = {
  2316. name: 'w3c',
  2317. url: 'http://www.runoob.com/?s=%s',
  2318. favicon: '',
  2319. };
  2320. engineList.mine[4] = {
  2321. name: 'GreasyFork',
  2322. url: 'https://gf.qytechs.cn/scripts?q=%s&utf8=✓',
  2323. favicon: '',
  2324. blank:true,
  2325. };
  2326. engineList.mine[5] = {
  2327. name: '人生05电影',
  2328. url: 'http://www.rs05.com/search.php?s=%s',
  2329. favicon: '',
  2330. blank:true,
  2331. };
  2332. engineList.mine[6] = {
  2333. name: '射手网(伪)',
  2334. url: 'http://assrt.net/sub/?searchword=%s',
  2335. favicon: '',
  2336. blank:true,
  2337. };
  2338. engineList.mine[7] = {
  2339. name: '游戏-3dm',
  2340. url: 'http://so.3dmgame.com/?type=4&keyword=%s',
  2341. favicon: '',
  2342. blank:true,
  2343. };
  2344. engineList.mine[8] = {
  2345. name: '搜狗表情',
  2346. url: 'https://pic.sogou.com/pic/emo/searchList.jsp?statref=home_form&keyword=%s',
  2347. favicon: '',
  2348. blank:true,
  2349. };
  2350.  
  2351.  
  2352. // 导入列表
  2353. var engineList_plus = [];
  2354. engineList_plus[0] = {
  2355. "status":3,
  2356. "version":1,
  2357. "message":"应用app下载,由奔跑中的奶酪整理",
  2358. "name":"应用",
  2359. "engineDetails":['应用',"app_xin",true],
  2360. "engineList":[
  2361. {
  2362. name: 'AppStore',
  2363. url: 'https://fnd.io/#/us/search?mediaType=all&term=%s',
  2364. favicon: '',
  2365. blank:true
  2366. },
  2367. {
  2368. name: ' PP助手',
  2369. url: 'https://www.25pp.com/ios/search_app_0/%s',
  2370. favicon: '',
  2371. blank:true
  2372. },
  2373. {
  2374. name: 'Google Play',
  2375. url: 'https://play.google.com/store/search?q=%s',
  2376. favicon: '',
  2377. blank:true
  2378. },
  2379. {
  2380. name: 'Microsoft Store',
  2381. url: 'https://www.microsoft.com/zh-cn/search/result.aspx?q=%s&form=MSHOME',
  2382. favicon: '',
  2383. blank:true
  2384. },
  2385. {
  2386. name: 'Alternativeto',
  2387. url: 'https://alternativeto.net/browse/search?q=%s',
  2388. favicon: '',
  2389. blank:true
  2390. },
  2391. {
  2392. name: 'Github',
  2393. url: 'https://www.runningcheese.com/go/?url=https://github.com/search?q=%s',
  2394. favicon: '',
  2395. blank:true
  2396. },
  2397. {
  2398. name: 'GreaseFork',
  2399. url: 'https://gf.qytechs.cn/zh-CN/scripts?utf8=%E2%9C%93&q=%s',
  2400. favicon: '',
  2401. blank:true
  2402. },
  2403. {
  2404. name: 'Chrome WebStore',
  2405. url: 'https://chrome.google.com/webstore/search/%s',
  2406. favicon: '',
  2407. blank:true
  2408. },
  2409. {
  2410. name: 'Firefox Add-ons',
  2411. url: 'https://addons.mozilla.org/zh-CN/firefox/search/?platform=windows&q=%s',
  2412. favicon: '',
  2413. blank:true
  2414. },
  2415. {
  2416. name: 'Userstyles',
  2417. url: 'https://userstyles.org/styles/browse?search_terms=%s',
  2418. favicon: '',
  2419. blank:true
  2420. }
  2421. ]
  2422. }
  2423. engineList_plus[1] = {
  2424. "status":3,
  2425. "version":1,
  2426. "engineDetails":['电子书',"ebook_xin",true],
  2427. "message":"由奔跑中的奶酪整理",
  2428. "engineList":[
  2429. // {
  2430. // name: 'jiumodiary',
  2431. // url: 'https://www.jiumodiary.com/$post$q',
  2432. // favicon: '',
  2433. // blank:true
  2434. // },
  2435. {
  2436. name: 'forfrigg',
  2437. url: 'http://forfrigg.com/#gsc.tab=0&gsc.q=%s&gsc.sort=',
  2438. favicon: '',
  2439. blank:true
  2440. },
  2441. {
  2442. name: '威锋网',
  2443. url: 'https://s.feng.com/index.php?srchtxt=%s',
  2444. favicon: '',
  2445. blank:true
  2446. },
  2447. {
  2448. name: '我的小书屋',
  2449. url: 'http://mebook.cc/?s=%s',
  2450. favicon: '',
  2451. blank:true
  2452. },
  2453. {
  2454. name: 'Library Genesis',
  2455. url: 'http://gen.lib.rus.ec/search.php?req=%s',
  2456. favicon: '',
  2457. blank:true
  2458. },
  2459. {
  2460. name: 'B-OK',
  2461. url: 'http://b-ok.xyz/s/?q=%s',
  2462. favicon: '',
  2463. blank:true
  2464. }
  2465. ]
  2466. }
  2467. engineList_plus[2] = {
  2468. "status":3,
  2469. "version":1,
  2470. "engineDetails":['网盘',"netdisc_xin",true],
  2471. "message":"由奔跑中的奶酪整理,https://www.runningcheese.com/resources",
  2472. "engineList":[
  2473. // {
  2474. // name: 'jiumodiary',
  2475. // url: 'https://www.jiumodiary.com/$post$q',
  2476. // favicon: '',
  2477. // blank:true
  2478. // },
  2479. {
  2480. name: '百度网盘',
  2481. url: 'https://pan.baidu.com/disk/home?#/search?key=%s&vmode=list',
  2482. favicon: '',
  2483. blank:true
  2484. },
  2485. {
  2486. name: '盘多多',
  2487. url: 'http://www.panduoduo.net/s/name/%s',
  2488. favicon: '',
  2489. blank:true
  2490. },
  2491. {
  2492. name: '56网盘',
  2493. url: 'http://www.56wangpan.com/search/kw%s',
  2494. favicon: '',
  2495. blank:true
  2496. },
  2497. {
  2498. name: 'Pan115',
  2499. url: 'http://www.pan115.com/search?key=%s',
  2500. favicon: '',
  2501. blank:true
  2502. },
  2503. {
  2504. name: '胖次分享',
  2505. url: 'https://www.panc.cc/s/%s/td_0',
  2506. favicon: '',
  2507. blank:true
  2508. },
  2509. {
  2510. name: '小不点搜索',
  2511. url: 'https://www.xiaoso.net/mod/app_search?wd=%E9%92%A2%E7%82%BC&mod=app_search&oksubmit=true&okbtn=XiaoSo%s',
  2512. favicon: '',
  2513. blank:true
  2514. }
  2515. ]
  2516. }
  2517.  
  2518.  
  2519.  
  2520.  
  2521. var settingData = {
  2522. "status":1,
  2523. "message":"$相关说明$(status: 这个在将来或许很重要)..."+
  2524. "(version: 若有新功能加入,靠这个版本号识别)..." +
  2525. "(addSearchItems: 允许更新时,添加新的搜索网站到你的搜索列表)..." +
  2526. "(modifySearchItems: 允许更新时,修改你的搜索列表中的项目)..." +
  2527. "(closeBtn: 设置页面右上角的“关闭”按钮是否显示。true显示,false隐藏)..." +
  2528. "(newtab: 新标签页打开。0为默认设置,1为新标签页打开)..." +
  2529. "(foldlist: 折叠当前搜索分类列表。true为折叠,false为展开。)..." +
  2530. "(setBtnOpacity: 设置按钮的透明度,值为0-1之间的数,0为透明,1为完全显示,中间值半透明。注:-1为直接关闭按钮,关闭之前请确定自己知道如何再次打开它)..." +
  2531. "(debug: debug模式,开启后,控制台会输出一些信息,“关闭并保存”按钮将不会在刷新页面)..." +
  2532. "(fixedTop: 将搜索栏固定到顶端。 true开启,false关闭)..." +
  2533. "(fixedTopUpward: 固定顶端后,搜索栏下拉不会出现,只有上拉时才出现。 true开启,false关闭)..." +
  2534. "(baiduOffset: 在百度页面鼠标划过的菜单会出现位移,若有使用其他的style样式,可以修改这个来修复二级菜单的偏移)..." +
  2535. "(getIcon: 自己添加搜索后获取图标的方式。0为自动,能连接谷歌的情况下用谷歌获取,无法连接的情况下,域名加favicon.ico获取;1为域名加favicon获取,2为使用谷歌获取,3为使用dnspot的服务获取(不建议使用)。或者添加网址,关键字使用%s代替,未测试)..." +
  2536. "(allOpen:一键搜索,点击相关分类后,打开该分类下的所有搜索)..." +
  2537. "(HideTheSameLink:隐藏同站链接。默认开启,百度页面会隐藏百度搜索。如果想在同一个搜索网站,但是想通过不同语言来搜索, 可以选择false来实现)..." +
  2538. "(center:是否居中显示,主要是为了兼容脚本 ac 百度 : 0 不居中,强制在左。 1, 强制居中 。 2,自动判断)..." +
  2539. "(icon: 图标的显示方式, 0 关闭文字, 只保留图标, 1 显示网站图标,2 显示抽象图标。当脚本中不存在抽象图标时,显示网站图标)..." +
  2540. "(transtion: 是否有动画效果, true为开启所有动画效果,false关闭所有动画(包括模糊效果)。)" +
  2541. "(selectSearch: 划词搜索功能, true为开启划词搜索,false关闭)" +
  2542. "(engineDetails: 第一个值为分类列表标题名称,第二个值与enginelist相关联,必须匹配,第三个值true为显示列表,false为禁用列表。排列顺序与跳转栏上的显示顺序相同,可以用它将分类列表按自己喜欢排序)..." +
  2543. "(engineList: 各个搜索的相关信息)" +
  2544. "(rules: 已弃用--将搜索样式插入到目标网页,同脚本中的rules设置相同,优先级高于脚本中自带的规则。自带了360搜索,可仿写)...",
  2545. "version":5,
  2546. "addSearchItems":true,
  2547. "modifySearchItems":true,
  2548. "closeBtn":true,
  2549. "newtab":0,
  2550. "foldlist":true,
  2551. "setBtnOpacity":0.2,
  2552. "debug":false,
  2553. "fixedTop":true,
  2554. "fixedTopUpward":false,
  2555. "baiduOffset":-120,
  2556. "getIcon":0,
  2557. "allOpen":false,
  2558. "HideTheSameLink":true,
  2559. "center":2,
  2560. "icon":1,
  2561. "transtion":true,
  2562. "selectSearch":false,
  2563. "engineDetails":[['网页', 'web',true],['翻译', 'translate',true],['知识', 'knowledge',true],['图片', 'image',true],['视频', 'video',true],['音乐', 'music',true],['学术', 'scholar',false], ['社交', 'sociality',true],['购物', 'shopping',true],["下载","download",false],["新闻","news",false],['mine', 'mine',false]],
  2564. "engineList":{},
  2565. "rules":[{"name": "360", "url": "/^https?:\\/\\/www\\.so\\.com\\/s\\?/", "enabled": true, "engineList": "web","fixedTop":50, "style": "margin-left: 140px;margin-bottom:-10px;z-index:3001;", "insertIntoDoc": {"keyword": "//input[@name='q']", "target": "css;#tabs-wrap", "where": "afterEnd"}}]
  2566. }
  2567. // --------------------可设置项结束------------------------
  2568. // GM_deleteValue("searchEngineJumpData");
  2569. var getSettingData = GM_getValue("searchEngineJumpData");
  2570. if(getSettingData){
  2571. // console.log("本地存在列表:",getSettingData);
  2572. if(!getSettingData.status && confirm("设置发生错误,脚本将会复原出厂设置")){
  2573. GM_deleteValue("searchEngineJumpData");
  2574. window.location.reload();
  2575. }
  2576.  
  2577. // 查看本地配置信息是否完整
  2578. for(let value in settingData){
  2579. if(!getSettingData.hasOwnProperty(value)){
  2580. console.log("属性不存在: ",value);
  2581. getSettingData[value] = settingData[value];
  2582. GM_setValue("searchEngineJumpData",getSettingData);
  2583. }
  2584. }
  2585.  
  2586. // 获取版本,用于搜索列表更新
  2587. // console.log("当前版本号和目标版本号: ",getSettingData.version,settingData.version);
  2588. if(parseFloat(getSettingData.version) < settingData.version){
  2589. console.log("版本过低,开始更新,当前版本号和目标版本号: ",getSettingData.version,settingData.version);
  2590. // 1.96 更新 修改a站搜索链接
  2591. // if(getSettingData.modifySearchItems){
  2592. // getSettingData.engineList = modifySearchItemsFun(getSettingData.engineList,"http://www.acfun.tv/search.aspx#query=%s","http://www.acfun.cn/search/?#query=%s")
  2593. // }
  2594. // 版本3.02 添加 自用网站-搜狗表情
  2595. // if(getSettingData.addSearchItems && getSettingData.engineList.hasOwnProperty("mine")){
  2596. // // engineList.mine[8].disable = true; // 对于老用户,默认禁用的状态添加
  2597. // getSettingData.engineList["mine"].push(engineList.mine[8])
  2598. // }
  2599. // 4.01
  2600. // if(getSettingData.addSearchItems){
  2601. // if(getSettingData.engineList.hasOwnProperty("music")){
  2602. // getSettingData.engineList["music"].push(engineList.music[6])
  2603. // getSettingData.engineList["music"].push(engineList.music[7])
  2604. // }
  2605. // }
  2606. // 4.03
  2607. // if(getSettingData.addSearchItems){
  2608. // // engineList.mine[8].disable = true; // 对于老用户,默认禁用的状态添加
  2609. // if(getSettingData.engineList.hasOwnProperty("translate")){
  2610. // getSettingData.engineList["translate"].push(engineList.translate[8])
  2611. // }
  2612. // }
  2613. // 4.04 更改 b站图标
  2614. // 导致了5.23.7 的严重bug, 致使无法使用。原因是用户已经删除了相关列表, 但是脚本依旧去读取,出现了读取错误。
  2615. // if(getSettingData.modifySearchItems){
  2616. // getSettingData.engineList.video = modifySearchItemsIcon(getSettingData.engineList.video,"http://search.bilibili.com/all?keyword=%s",engineList.video[1].favicon)
  2617. // }
  2618. // v5 更改图标的显示样式
  2619. getSettingData.icon = 1;
  2620.  
  2621. // 更新本地版本 其他相关信息
  2622. getSettingData.version = settingData.version;
  2623. getSettingData.message = settingData.message;
  2624. GM_setValue("searchEngineJumpData",getSettingData);
  2625. }
  2626.  
  2627. engineList = getSettingData.engineList;
  2628.  
  2629. } else {
  2630. console.log("未发现本地列表");
  2631. settingData.engineList = engineList;
  2632. console.log("初始化:",settingData);
  2633.  
  2634. GM_setValue("searchEngineJumpData",settingData);
  2635. getSettingData = GM_getValue("searchEngineJumpData");
  2636. }
  2637.  
  2638. // 处理enginlist.detail的相关信息
  2639. var engineDetails = getSettingData.engineDetails;
  2640. //列表分类显示情况
  2641. var getDetails = engineDetails.map(function(value,index){
  2642. return value[2]?index:-index;
  2643. })
  2644.  
  2645. // 列表分类的key value
  2646. var getDetailsL = getDetails.length;
  2647. var details = [];
  2648. for(let i=0;i<getDetailsL;i++){
  2649. details[getDetails[i]] = engineDetails[i];
  2650. };
  2651. engineList.details = details;
  2652.  
  2653. reloadDebug(getSettingData.debug);
  2654.  
  2655. ///test -------------- 测试 start
  2656. debug("searchEngineJump test location.href: ",window.location.href)
  2657. ///test -------------- 测试 end
  2658.  
  2659. // 更新已过期的搜索链接
  2660. function modifySearchItemsFun(engineList,oldURL,newURL){
  2661. for(let value in engineList){
  2662. var item = engineList[value]
  2663. for(let i=0;i<item.length;i++){
  2664. if(item[i].url === oldURL){
  2665. item[i].url = newURL;
  2666. return engineList;
  2667. }
  2668. }
  2669. }
  2670. return engineList;
  2671. }
  2672. // 更新图标
  2673. function modifySearchItemsIcon(engineList,url,newIcon){
  2674. for (let i=0;i<engineList.length;i++){
  2675. if(engineList[i].url ==url){ //用户可能自己更改网站名称,所以此处用url来匹配
  2676. engineList[i].favicon=newIcon;
  2677. console.log("发现旧的图标");
  2678. }
  2679. }
  2680. return engineList;
  2681. }
  2682. // 更新本地 rule
  2683. function modifySearchItemsRuleFun(name,value){
  2684. var oldRule = getSettingData.rules;
  2685. for(let item in oldRule){
  2686. if(oldRule[item].name == name){
  2687. console.log("匹配成功, 更新 rule : ", name);
  2688. oldRule[item] = value;
  2689. GM_setValue("searchEngineJumpData",getSettingData);
  2690. }
  2691. }
  2692. }
  2693.  
  2694. // parseUri 1.2.2
  2695. // (c) Steven Levithan <stevenlevithan.com>
  2696. // MIT License
  2697. var parseUri = function(str) {
  2698. var o = parseUri.options,
  2699. m = o.parser[o.strictMode ? "strict" : "loose"].exec(str),
  2700. uri = {},
  2701. i = 14;
  2702.  
  2703. while (i--) uri[o.key[i]] = m[i] || "";
  2704.  
  2705. uri[o.ds.name] = {};
  2706. uri[o.ds.name][0] = {};
  2707. uri[o.ds.name][0]["key"] = (uri.protocol ? uri.protocol : "http") + "://" + uri.host + (uri.port ? ":" + uri.port : "") + "/";
  2708. uri[o.ds.name][0]["val"] = "/";
  2709. i = 0;
  2710. var tempsub = "/",
  2711. subs = uri[o.key[10]].substr(1).split("/");
  2712. for (var j = 1; j < (subs.length + 1); j++, i++) {
  2713. tempsub += tempsub === "/" ? subs[i] : "/" + subs[i];
  2714. if (subs[i]) {
  2715. uri[o.ds.name][j] = {};
  2716. uri[o.ds.name][j]["key"] = subs[i];
  2717. uri[o.ds.name][j]["val"] = tempsub;
  2718. }
  2719. }
  2720.  
  2721. uri[o.q.name] = {};
  2722. uri[o.key[12]].replace(o.q.parser, function($0, $1, $2) {
  2723. if ($1) uri[o.q.name][$1] = $2;
  2724. });
  2725. uri[o.aq.name] = {};
  2726. uri[o.key[13]].replace(o.aq.parser, function($0, $1, $2) {
  2727. if ($1) uri[o.aq.name][$1] = $2;
  2728. });
  2729.  
  2730. return uri;
  2731. };
  2732. parseUri.options = {
  2733. strictMode: false,
  2734. key: ["source", "protocol", "authority", "userInfo", "user", "password", "host", "port", "relative", "path", "directory", "file", "query", "anchor"],
  2735. q: {
  2736. name: "queryKey",
  2737. parser: /(?:^|&)([^&=]*)=?([^&]*)/g
  2738. },
  2739. aq: {
  2740. name: "anchorqueryKey",
  2741. parser: /(?:^|&)([^&=]*)=?([^&]*)/g
  2742. },
  2743. ds: {
  2744. name: "directorySub"
  2745. },
  2746. parser: {
  2747. strict: /^(?:([^:\/?#]+):)?(?:\/\/((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?))?((((?:[^?#\/]*\/)*)([^?#]*))(?:\?([^#]*))?(?:#(.*))?)/,
  2748. loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/
  2749. }
  2750. };
  2751.  
  2752. function getElementLeft(element){
  2753. var actualLeft = element.offsetLeft;
  2754. var current = element.offsetParent;
  2755. while (current !== null){
  2756. actualLeft += current.offsetLeft;
  2757. current = current.offsetParent;
  2758. }
  2759. return actualLeft;
  2760. };
  2761. // console.log("engineList: ",engineList);
  2762. //xpath 获取单个元素
  2763. function getElementByXPath(xPath, contextNode, doc) {
  2764. doc = doc || document;
  2765. contextNode = contextNode || doc;
  2766. return doc.evaluate(xPath, contextNode, null, 9, null).singleNodeValue;
  2767. };
  2768.  
  2769. // 从函数中获取多行注释的字符串
  2770. function getMStr(fn) {
  2771. var fnSource = fn.toString();
  2772. var ret = {};
  2773. fnSource = fnSource.replace(/^[^{]+/, '');
  2774. // console.log(fnSource);
  2775. var matched;
  2776. var reg = /var\s+([$\w]+)[\s\S]*?\/\*([\s\S]+?)\*\//g;
  2777. while (matched = reg.exec(fnSource)) {
  2778. // console.log(matched);
  2779. ret[matched[1]] = matched[2];
  2780. };
  2781.  
  2782. return ret;
  2783. };
  2784.  
  2785. // 事件支持检测.
  2786. // 比如 eventSupported('fullscreenchange', document);
  2787. function eventSupported(eventName, elem) {
  2788. elem = elem || document.createElement('div');
  2789. var prefix = ['o', 'ms', 'moz', 'webkit', ''];
  2790.  
  2791. var l = prefix.length;
  2792. var pEventName;
  2793. var isFunction;
  2794. var setAttr;
  2795.  
  2796. while(l --) {
  2797. pEventName = 'on' + prefix[l] + eventName;
  2798.  
  2799. if (pEventName in elem) {
  2800. return pEventName.slice(2);
  2801. } else if (typeof elem.setAttribute == 'function') { // setAttribute 是元素节点的方法
  2802. setAttr = false;
  2803. if (!elem.hasAttribute(pEventName)) {
  2804. setAttr = true;
  2805. elem.setAttribute(pEventName, 'return;');
  2806. };
  2807.  
  2808. isFunction = typeof elem[pEventName] == 'function';
  2809.  
  2810. if (setAttr) elem.removeAttribute(pEventName);
  2811.  
  2812. if (isFunction) {
  2813. return pEventName.slice(2);
  2814. };
  2815. };
  2816. };
  2817.  
  2818. return false;
  2819. };
  2820.  
  2821. // 保存指定对象相关数据
  2822. var data = (function () {
  2823. 'use strict';
  2824.  
  2825. var cache = {
  2826. objs: [],
  2827. data: {},
  2828. };
  2829.  
  2830. function data(obj, key, value) {
  2831. var id = cache.objs.indexOf(obj);
  2832. if (id == -1) {
  2833. id = cache.objs.push(obj) - 1;
  2834. };
  2835. if (!cache.data[id]) {//初始化
  2836. cache.data[id] = {};
  2837. };
  2838. if (typeof value == 'undefined') {// 取值
  2839. return typeof key == 'undefined' ? cache.data[id] : cache.data[id][key];
  2840. } else {
  2841. return cache.data[id][key] = value;
  2842. };
  2843. };
  2844.  
  2845. return data;
  2846. })();
  2847.  
  2848. // 为mouseleave mouseenter事件做个兼容
  2849. // 需要 eventSupported, data函数支持
  2850. var mouseEventListener = (function () {
  2851.  
  2852. var support = {
  2853. mouseleave : eventSupported('mouseleave'),
  2854. mouseenter : eventSupported('mouseenter'),
  2855. };
  2856.  
  2857. var map = {
  2858. mouseleave : 'mouseout',
  2859. mouseenter : 'mouseover',
  2860. };
  2861.  
  2862. return {
  2863. add : function (type, ele, callback) { //事件类型,元素,监听函数
  2864. if (support[type]) {
  2865. ele.addEventListener(type, callback, false); //mouseleave,enter不冒泡,所以在冒泡阶段监听事件,不要担心子孙元素进出发生的事件冒泡上来。
  2866. } else {
  2867. var listener = data(callback, 'mouseELListener');
  2868. if (!listener) {
  2869. listener = function (e) {
  2870. var relatedTarget = e.relatedTarget; //mouseout,去往的元素;mouseover,来自的元素
  2871. // 当mouseout(离开ele)去往的元素不是自己的子孙元素
  2872. // 当mouseover(进入ele)来自的元素不是自己的子孙元素
  2873. if (!ele.contains(relatedTarget)) { // contains函数,自己.contains(自己) 返回true
  2874. callback.call(ele, e);
  2875. };
  2876. };
  2877. data(callback, 'mouseELListener', listener);
  2878. };
  2879.  
  2880. ele.addEventListener(map[type], listener, true);
  2881. };
  2882. },
  2883. remove : function (type, ele, callback) {
  2884. if (support[type]) {
  2885. ele.removeEventListener(type, callback, false);
  2886. } else {
  2887. ele.removeEventListener(map[type], data(callback, 'mouseELListener'), true);
  2888. };
  2889. },
  2890. };
  2891. })();
  2892.  
  2893. //获取已滚动的距离
  2894. function getScrolled(container) {
  2895. if (container) {
  2896. return {
  2897. x:container.scrollLeft,
  2898. y:container.scrollTop,
  2899. };
  2900. };
  2901. return {
  2902. x: 'scrollX' in window ? window.scrollX : ('pageXOffset' in window ? window.pageXOffset : document.documentElement.scrollLeft || document.body.scrollLeft),
  2903. y: 'scrollY' in window ? window.scrollY : ('pageYOffset' in window ? window.pageYOffset : document.documentElement.scrollTop || document.body.scrollTop),
  2904. };
  2905. };
  2906.  
  2907. function getElement(selector) {
  2908. if (selector.indexOf('css;') == 0) {
  2909. return document.querySelector(selector.slice(4));
  2910. } else {
  2911. return getElementByXPath(selector);
  2912. };
  2913. };
  2914.  
  2915. function mousedownhandler(e) {
  2916. var target = e.target;
  2917.  
  2918. target = getElementByXPath('ancestor-or-self::a[contains(@class, "sej-engine")]', target);
  2919.  
  2920. // if (!target || target.className.indexOf('sej-engine') == -1) return;
  2921. // 某些网站致下方的this无法达到原本的效果, 例 https://origenapellido.com/apellido-gavira/
  2922. // if (!target || !this.contains(target)) return;
  2923. if (!target) return;
  2924.  
  2925. var value;
  2926. if (typeof iInput == 'function') {
  2927. value = iInput();
  2928. } else {
  2929. if (iInput.nodeName == 'INPUT') {
  2930. value = iInput.value;
  2931. } else {
  2932. value = iInput.textContent;
  2933. };
  2934. };
  2935.  
  2936. // 如果搜索内容是通过某一网站搜索, 就去掉。 例: 0 site:zhihu.com 只保留0, 后面的网站会去掉
  2937. if(!getSettingData.HideTheSameLink){
  2938. value = value.replace(/site[^\s]+/, "");
  2939. }
  2940.  
  2941.  
  2942. // 编码 解码
  2943. // 对搜索词编码 (未做解码处理,浏览器自动处理) 网站1688采用gbk编码
  2944. var ogbk = target.getAttribute('gbk');
  2945. if (ogbk){
  2946. value = toGBK(value)
  2947. } else {
  2948. value = encodeURIComponent(value);
  2949. }
  2950. // // @name searchEngineJump-NextStage
  2951. // if (document.characterSet != "UTF-8") value = encodeURIComponent(value);
  2952.  
  2953. var targetURL = target.getAttribute('url');
  2954.  
  2955. // 一键搜索
  2956. if(getSettingData.allOpen && target.classList.contains("sej-drop-list-trigger")){
  2957. var list = engineList[target.dataset.iqxincategory]
  2958. // console.log("allOpen")
  2959. // console.log(list)
  2960.  
  2961. for(var i=0;i<list.length;i++){
  2962. if (list[i].url.indexOf("site:")<0 && matchedRule?.url.test(list[i].url)) continue ;
  2963. if (list[i].disable) continue ;
  2964. var href = list[i].url.replaceAll('%s', value);
  2965. GM_openInTab(href)
  2966. }
  2967. target.setAttribute("onclick","return false;");
  2968. return
  2969. }
  2970.  
  2971.  
  2972. // 如果有post请求
  2973. var postSign = targetURL.indexOf('$post$');
  2974. if(~postSign){
  2975. var f=getPostFormHTML(targetURL.substring(0,postSign),[targetURL.substring(postSign+6),value],target.getAttribute('target'))
  2976. target.appendChild(f)
  2977. target.setAttribute("onclick","this.getElementsByTagName('form')[0].submit();return false;");
  2978.  
  2979. // var postURL = parseUri(target.getAttribute('url'));
  2980. // console.log(postURL);
  2981. // target.setAttribute("onclick","return false;");
  2982. // GM_xmlhttpRequest({
  2983. // method: "post",
  2984. // url: target.url,
  2985. // data: targetURL.substring(postSign + 6) + '=' + value ,
  2986. // get data() {
  2987. // return this._data;
  2988. // },
  2989. // set data(value) {
  2990. // this._data = value;
  2991. // },
  2992. // headers: {
  2993. // "Content-Type": "application/x-www-form-urlencoded",
  2994. // "Origin":postURL.host,
  2995. // "Referer":postURL.host
  2996. // },
  2997. // onload: function(res){
  2998. // if(res.status === 200){
  2999. // console.log('成功')
  3000. // }else{
  3001. // console.log('失败')
  3002. // console.log(res)
  3003. // }
  3004. // },
  3005. // onerror : function(err){
  3006. // console.log('error')
  3007. // console.log(err)
  3008. // }
  3009. // });
  3010.  
  3011. } else{
  3012. //console.log(value);
  3013. target.href = target.getAttribute('url').replaceAll('%s', value);
  3014. }
  3015. if(selectSearchMode){
  3016. target.target="_blank";
  3017. }
  3018. };
  3019. //获取 POST 的表单的 HTML
  3020. function getPostFormHTML(url, value, newTab) {
  3021. //console.log(url,value,newTab)
  3022. var ospan = document.createElement('span');
  3023. ospan.style.cssText = 'width:0px;height:0px;';
  3024. var form = "" +
  3025. "<form method='post'" +
  3026. " action='" + url + "'" +
  3027. (newTab ? " target='_blank'" : "") +
  3028. ">" +
  3029. "<input type='hidden'" +
  3030. " name='" + value[0] + "'" +
  3031. " value='" + value[1] + "'" +
  3032. " />" +
  3033. "</form>";
  3034. ospan.innerHTML = form;
  3035. return ospan;
  3036. };
  3037.  
  3038. // 滑词搜索
  3039. function selectSearch(e){
  3040. // console.log("滑词搜索");
  3041. // console.log(window.getSelection());
  3042. let selectText = window.getSelection().toString();
  3043. let sejContainer = document.querySelector("#sej-container");
  3044. if(matchedRule) return; // 该界面已经匹配到相关规则, 说明是在搜索网站的搜索界面
  3045. if(e.button !=0) return; // 排除非左键点击
  3046. if (selectText.length < 1) {
  3047. if(sejContainer){
  3048. sejContainer.style.top = "-50px";
  3049. }
  3050. return;
  3051. };
  3052.  
  3053. // if(document.activeElement.tagName.toUpperCase() == "INPUT"
  3054. // || document.activeElement.tagName.toUpperCase() == "TEXTAREA") return; // 排除inpu和textarea内的文本
  3055.  
  3056. iTarget = document.body;
  3057. iTargetWhere = "beforeend";
  3058. iInput = {};
  3059. iInput.textContent = selectText;
  3060. if(sejContainer){
  3061. sejContainer.style.top = "0px";
  3062. return;
  3063. };
  3064. selectSearchMode = true;
  3065. addSEJ()
  3066. }
  3067.  
  3068. let iTargetWhere; // 如何插入
  3069. let iTarget; // 插入位置
  3070. let iInput; // 搜索词
  3071. let selectSearchMode = false;
  3072. // 滑词搜索
  3073. if(getSettingData.selectSearch){
  3074. document.onmouseup = selectSearch;
  3075. }
  3076.  
  3077. // iframe 禁止加载
  3078. if (window.self != window.top) return;
  3079.  
  3080. // 准备往页面插入列表
  3081. var url = location.href;
  3082. var matchedRule;
  3083. var marchedSign;
  3084.  
  3085. //先判断用户规则
  3086. marchedSign = getSettingData.rules.some(function (rule) {
  3087. if(typeof(rule.url)=="string"){ // 2020-12-19 todo: 重新导入用户配置文件后, 会解析错误的问题。 是由于用户保存的rule.url由字符串变成了空对象{},具体在什么情况下会导致变成空对象,并未排查
  3088. rule.url = new RegExp(rule.url.substring(1,rule.url.length-1));
  3089. if (rule.url.test(url)) {
  3090. matchedRule = rule;
  3091. return true;
  3092. };
  3093. }
  3094. });
  3095.  
  3096. // console.log(marchedSign,matchedRule);
  3097. if(!marchedSign){
  3098. rules.some(function (rule) {
  3099. if (rule.url.test(url)) {
  3100. matchedRule = rule;
  3101. return true;
  3102. };
  3103. });
  3104. }
  3105.  
  3106. if (!matchedRule || !matchedRule.enabled) return;
  3107.  
  3108. // var iTarget = getElement(matchedRule.insertIntoDoc.target);
  3109. iTarget = typeof matchedRule.insertIntoDoc.target == "function" ? matchedRule.insertIntoDoc.target() : getElement(matchedRule.insertIntoDoc.target);
  3110. iInput = typeof matchedRule.insertIntoDoc.keyword == 'function' ? matchedRule.insertIntoDoc.keyword : getElement(matchedRule.insertIntoDoc.keyword);
  3111.  
  3112. ///test -------------- 测试 start
  3113. // console.log("searchEngineJump test iTarget, iInput: ",iTarget, iInput);
  3114. ///test -------------- 测试 end
  3115.  
  3116. if (!iTarget || !iInput) {
  3117. console.log("脚本 searchEngineJump 搜索引擎快捷跳转 遇到了错误: ");
  3118. console.log("目标有误:\n iTarget:" + iTarget + "\niInput(keyword): " + iInput);
  3119. return;
  3120. }
  3121. iTargetWhere = matchedRule.insertIntoDoc.where.toLowerCase();
  3122. addSEJ()
  3123. function addSEJ(){
  3124.  
  3125. // 搜索列表的样式(此处没有 “设置” 的css样式)
  3126. let styleText = "";
  3127. // 配色
  3128. styleText += `
  3129. body {
  3130. --font-color-qxin:#333;
  3131.  
  3132. --background-avtive-color-qxin: #ccc;
  3133. --background-active-enable-qxin:#cff9ff;
  3134. --background-active-disable-qxin:#ffa2a2;
  3135. --background-hover-color-qxin: #EAEAEA;
  3136. --trigger-shown-qxin: #DEEDFF !important;
  3137. --sej-drop-list-background-qxin:rgba(255,255,255,0.7);
  3138. --background-btn-qxin:#EFF4F8;
  3139. --background-setting-qxin:#fff;
  3140. }
  3141. body[qxintheme="dark"] {
  3142. --font-color-qxin:#BDC1BC;
  3143. --background-color-qxin: #202124;
  3144. --background-avtive-color-qxin: #424242;
  3145. --background-active-enable-qxin:#274144;
  3146. --background-active-disable-qxin:#583535;
  3147. --background-hover-color-qxin: #424242;
  3148. --trigger-shown-qxin: #424242 !important;
  3149. --sej-drop-list-background-qxin:rgba(0,0,0,0.7);
  3150. --background-btn-qxin:#292f36;
  3151. --background-setting-qxin:#202124;
  3152. }
  3153. `
  3154. // 搜索列表的样式
  3155. styleText += `
  3156. #sej-container {
  3157. display: block;
  3158. position: relative;
  3159. z-index: 2;
  3160. // padding: 1px 5px 1px 5px;
  3161. line-height: 1.5;
  3162. font-size: 13px;
  3163. font-family: arial,sans-serif;
  3164. transform-origin: top center;
  3165. animation: sejopen 0.2s;
  3166. border-bottom-right-radius: 4px;
  3167. border-bottom-left-radius: 4px;
  3168. color:var(--font-color-qxin);
  3169. background: var(--background-color-qxin);
  3170. // transition:0.3s;
  3171. }
  3172. /* 滑词搜索样式 */
  3173. #sej-container.selectSearch{
  3174. position:fixed;
  3175. top:0;
  3176. left:0;
  3177. right:0;
  3178. z-index: 99999;
  3179. text-align: center;
  3180. transition: 0.3s;
  3181. background: #ffffffba;
  3182. backdrop-filter: blur(25px);
  3183. padding: 5px 0;
  3184. box-shadow: 2px 2px 10px #eee;
  3185. }
  3186. .selectSearch .sej-engine{
  3187. margin-left:5px;
  3188. }
  3189. #sej-container a{
  3190. border-radius:2px;
  3191. }
  3192. #sej-expanded-category {
  3193. font-weight: bold;
  3194. }
  3195.  
  3196. .sej-engine {
  3197. line-height: 2;
  3198. display: inline-block;
  3199. margin: 0 0px 0 0;
  3200. border: none;
  3201. padding: 0 8px;
  3202. text-decoration: none;
  3203. font-weight:500;
  3204. transition: background-color 0.15s ease-in-out;
  3205. }
  3206. .sej-drop-list a:visited,
  3207. .sej-drop-list a:hover,
  3208. .sej-engine a:visited,
  3209. .sej-engine a:hover,
  3210. #sej-container a:link,
  3211. #sej-container a:visited,
  3212. #sej-container a:hover{
  3213. color:var(--font-color-qxin);
  3214. }
  3215. .sej-engine:hover {
  3216. background-color: var(--background-hover-color-qxin);
  3217. text-decoration: none;
  3218. }
  3219. .sej-drop-list > .sej-engine:hover {
  3220. // background-color: #DEEDFF;
  3221. background-color: var(--background-hover-color-qxin);
  3222. }
  3223. .sej-drop-list > .sej-engine {
  3224. display: block;
  3225. padding-top: 4px;
  3226. padding-bottom: 4px;
  3227. top: 0px;
  3228. border-radius:4px;
  3229. }
  3230.  
  3231. .sej-engine-icon {
  3232. display: inline-block;
  3233. width: 16px;
  3234. height: 16px;
  3235. border: none;
  3236. padding: 0;
  3237. margin: 0 3px 0 0;
  3238. vertical-align: text-bottom;
  3239. box-sizing:unset;
  3240. }
  3241.  
  3242. .sej-drop-list {
  3243. position: absolute;
  3244. display: none;
  3245. opacity: 0.3;
  3246. top: -10000px;
  3247. left: 0;
  3248. min-width: 90px;
  3249. padding: 5px 0;
  3250. text-align: left;
  3251. font-size: 13px;
  3252. -moz-box-shadow: 1px 1px 5px #999;
  3253. -webkit-box-shadow: 2px 2px 5px #999;
  3254. box-shadow: 2px 2px 5px #999;
  3255. // background-color: rgba(255,255,255,.7);
  3256. background-color: var(--sej-drop-list-background-qxin);
  3257. backdrop-filter: blur(7px);
  3258. border-bottom-right-radius: 3px;
  3259. border-bottom-left-radius: 3px;
  3260. transition: opacity 0.2s ease-in-out,
  3261. top 0.2s ease-in-out;
  3262. }
  3263. @keyframes sejopen {
  3264. 0% {
  3265. transform: scale(1, 0.1);
  3266. opacity: 0;
  3267. }
  3268. 100% {
  3269. transform: scale(1, 1);
  3270. opacity: 1;
  3271. }
  3272. }
  3273. @keyframes iqxinsejopen {
  3274. 0% {
  3275. transform: scale(0.01, 0.01);
  3276. opacity: 0;
  3277. }
  3278. 100% {
  3279. transform: scale(1, 1);
  3280. opacity: 1;
  3281. }
  3282. }
  3283. `
  3284.  
  3285. // 工具列表动画
  3286. if(!getSettingData.transtion){
  3287. styleText += `
  3288. .sej-engine,
  3289. .sej-drop-list-trigger,
  3290. .sej-drop-list{
  3291. transition:none!important;
  3292. }
  3293. #sej-container{
  3294. animation:none!important;
  3295. }
  3296. .sej-drop-list {
  3297. backdrop-filter:none!important;
  3298. }
  3299. `
  3300. }
  3301. // 隐藏箭头
  3302. // if(getSettingData.icon){
  3303. // styleText += `
  3304. // .sej-drop-list-trigger-shown {
  3305. // /* background-color: #DEEDFF !important; */
  3306. // background-color: var(--trigger-show)
  3307. // }
  3308. // .sej-drop-list-trigger::after {
  3309. // /* content: ''; */
  3310. // display: inline-block;
  3311. // margin: 0 0 0 3px;
  3312. // padding: 0;
  3313. // width: 0;
  3314. // height: 0;
  3315. // border-top: 6px solid #BCBCBC;
  3316. // border-right: 5px solid transparent;
  3317. // border-left: 5px solid transparent;
  3318. // border-bottom: 0px solid transparent;
  3319. // vertical-align: middle;
  3320. // transition: -webkit-transform 0.3s ease-in-out;
  3321. // transition: transform 0.3s ease-in-out;
  3322. // }
  3323. // .sej-drop-list-trigger-shown::after {
  3324. // -webkit-transform: rotate(180deg);
  3325. // transform: rotate(180deg);
  3326. // }
  3327. // `
  3328. // }else{
  3329. // styleText += `
  3330. // .sej-drop-list-trigger {
  3331. // margin-right:8px;
  3332. // }
  3333. // `
  3334. // }
  3335. GM_addStyle(styleText);
  3336. // 夜间模式
  3337. let scheme = document.getElementsByTagName('meta')['color-scheme']
  3338. if(scheme){
  3339. console.log("搜索到相关选项, ", scheme.content);
  3340. if(scheme.content=="dark"){
  3341. console.log("设置为夜间模式");
  3342. document.body.setAttribute("qxintheme","dark")
  3343. }
  3344. }
  3345. // 列表对象
  3346. function DropDownList(a, list) {
  3347. this.a = a;
  3348. this.list = list;
  3349. this.init();
  3350. };
  3351. DropDownList.zIndex = 100000000;
  3352. DropDownList.prototype = {
  3353. hidden: true,
  3354. showDelay: 233,
  3355. hideDelay: 233,
  3356. aShownClass: 'sej-drop-list-trigger-shown',
  3357. init: function () {
  3358. var a = this.a;
  3359. var list = this.list;
  3360. var self = this;
  3361. // 关闭动画
  3362. if(!getSettingData.transtion){
  3363. this.showDelay = 0;
  3364. this.hideDelay = 0;
  3365. }
  3366. // 进入显示
  3367. mouseEventListener.add('mouseenter', a, function () {
  3368. clearTimeout(self.hideTimerId);
  3369. if (self.hidden) {
  3370. self.showTimerId = setTimeout(function () {
  3371. self.show();
  3372. }, self.showDelay);
  3373. } else {
  3374. var style = list.style;
  3375. style.top = parseInt(list.style.top) -6 +"px";
  3376. style.zIndex = DropDownList.zIndex ++;
  3377. style.opacity = 0.96;
  3378. };
  3379. });
  3380. // 离开隐藏
  3381. mouseEventListener.add('mouseleave', a, function () {
  3382. clearTimeout(self.showTimerId);
  3383. if (!self.hidden) {
  3384. list.style.top = parseInt(list.style.top)+6 +"px";
  3385. list.style.opacity = 0.04;
  3386. self.hideTimerId = setTimeout(function () {
  3387. self.hide();
  3388. }, self.hideDelay);
  3389. };
  3390. });
  3391. mouseEventListener.add('mouseenter', list, function () {
  3392. clearTimeout(self.hideTimerId);
  3393. var style = list.style;
  3394. style.zIndex = DropDownList.zIndex ++;
  3395. style.opacity = 0.96;
  3396. style.top = parseInt(list.style.top) -6 +"px";
  3397. });
  3398. mouseEventListener.add('mouseleave', list, function () {
  3399. list.style.opacity = 0.04;
  3400. list.style.top = parseInt(list.style.top)+6 +"px";
  3401. self.hideTimerId = setTimeout(function () {
  3402. self.hide();
  3403. }, self.hideDelay);
  3404. });
  3405. },
  3406. show: function () {
  3407. if (!this.hidden) return;
  3408. this.hidden = false;
  3409. var scrolled = getScrolled();
  3410. var aBCRect = this.a.getBoundingClientRect();
  3411. var thisBCRect = this.a.parentNode.getBoundingClientRect()
  3412. var style = this.list.style;
  3413. var top = scrolled.y + aBCRect.bottom;
  3414. var left = scrolled.x + aBCRect.left;
  3415. // 百度界面二级搜索会出现偏移的问题
  3416. // if(/^https?:\/\/www\.baidu\.com\/(?:s|baidu)/.test(url)){
  3417. // top = 26;
  3418. // if(document.querySelector(".AC-style-logo") && getSettingData.center != 0){
  3419. // // left += 0;
  3420. // left = aBCRect.x -thisBCRect.x
  3421. // } else {
  3422. // // left += getSettingData.baiduOffset; 不需要用户自己修改,直接写死
  3423. // left += -134;
  3424. // }
  3425. // }
  3426. style.top = top + 6 + 'px';
  3427. style.left = left + 'px';
  3428. style.zIndex = DropDownList.zIndex --;
  3429. style.display = 'block';
  3430. // 二级搜索居中显示
  3431. style.left = left- (this.list.getBoundingClientRect().width - aBCRect.width)/2 + "px";
  3432. setTimeout(function () {
  3433. style.opacity = 0.96;
  3434. style.top = top + 'px';
  3435. }, 30);
  3436. this.a.classList.add(this.aShownClass);
  3437. },
  3438. hide: function () {
  3439. if (this.hidden) return;
  3440. this.hidden = true;
  3441. var style = this.list.style;
  3442. style.display = 'none';
  3443. style.opacity = 0.1;
  3444. this.a.classList.remove(this.aShownClass);
  3445. }
  3446. };
  3447. // var pageEncoding = (document.characterSet || document.charset).toLowerCase();
  3448. // 创建dom
  3449. var container = document.createElement('sejspan');
  3450. container.id = 'sej-container';
  3451. container.className = "rwl-exempt";
  3452.  
  3453. // 没有匹配到样式, 说明是通过滑词搜索进入
  3454. if(!matchedRule){
  3455. container.classList.add("selectSearch");
  3456. }
  3457. // 添加 class 以获取目标网站相同的样式。
  3458. if(matchedRule?.class){
  3459. container.className = container.className + " " + matchedRule.class;
  3460. }
  3461. container.addEventListener('mousedown', mousedownhandler, true);
  3462. var aPattern = '<a href="" class="sej-engine" target="$blank$" data-iqxincategory="$category$" encoding="$encoding$" gbk="$gbk$" url="$url$"><img src="$favicon$" class="sej-engine-icon" />$name$</a>';
  3463. var dropLists = [];
  3464. engineList.details.forEach(function (item) {
  3465. // console.log(item); // 搜索菜单  ["网页", "web", true]
  3466. var category = item[1]; // "web"
  3467. var cName = item[0]; // "网页"
  3468. var engines = [];
  3469. engineList[category].forEach(function (engine) {
  3470. if(engine.disable) return;
  3471. var engineUrl = engine.url;
  3472. if (getSettingData.HideTheSameLink && matchedRule?.url.test(engineUrl)) return;// 去掉跳转到当前引擎的引擎
  3473. var a = aPattern.replace('$encoding$', (engine.encoding || 'utf-8').toLowerCase())
  3474. .replace('$url$', engineUrl)
  3475. .replace('$name$', engine.name)
  3476. .replace("$category$",category);
  3477. // 图标
  3478. if (engine.favicon) {
  3479. a = a.replace('$favicon$', engine.favicon);
  3480. } else {
  3481. a = a.replace('src="$favicon$"', '');
  3482. };
  3483. // gbk编码
  3484. if (engine.gbk) {
  3485. a = a.replace('$gbk$', engine.gbk);
  3486. } else {
  3487. a = a.replace('gbk="$gbk$"', '');
  3488. };
  3489. // 新标签页
  3490. if (getSettingData.newtab || engine.blank) {
  3491. a = a.replace('$blank$', "_blank");
  3492. } else {
  3493. a = a.replace('target="$blank$"', '');
  3494. };
  3495. engines.push(a);
  3496. });
  3497. // 非空列表
  3498. if (!engines.length) return;
  3499. engines = engines.join('');
  3500. // 展开当前搜索分类列表
  3501. if (!getSettingData.foldlist && category == matchedRule?.engineList) {
  3502. container.innerHTML = engines;
  3503. } else {
  3504. var dropList = document.createElement('sejspan');
  3505. dropList.className = 'sej-drop-list rwl-exempt';
  3506. dropList.innerHTML = engines;
  3507. // a:主搜索菜单
  3508. // dropList: 搜索子菜单
  3509. var a = dropList.firstElementChild.cloneNode(true);
  3510. a.className = a.className + ' sej-drop-list-trigger';
  3511. // 隐藏主搜索菜单的图标
  3512. if(!getSettingData.icon){
  3513. cName = "";
  3514. }
  3515. a.lastChild.nodeValue = cName;
  3516. dropLists.push([a, dropList]);
  3517. };
  3518. });
  3519. //将各个搜索列表插入文档中
  3520. dropLists.forEach(function (item) {
  3521. // console.log(item[0]);
  3522. // console.log(item[0].dataset.iqxincategory) //"web"
  3523. // console.log(item[0].querySelector("img").src); // 图片链接
  3524. // console.log(item[0].innerText); // 网页
  3525. // console.log(item[1]);
  3526. if(getSettingData.icon == 2){
  3527. // console.log(icon[item[0].dataset.iqxincategory])
  3528. if(icon[item[0].dataset.iqxincategory]){
  3529. item[0].querySelector("img").src = icon[item[0].dataset.iqxincategory]
  3530. }
  3531. }
  3532. container.appendChild(item[0]); //将搜索列表放入主搜索
  3533. document.body.appendChild(item[1]); // 插入搜索子菜单
  3534. item[1].addEventListener('mousedown', mousedownhandler, true);
  3535. new DropDownList(item[0], item[1]);
  3536. });
  3537. // 将主搜索插入网页中
  3538. switch (iTargetWhere) {
  3539. case 'beforebegin' : // 'beforeBegin'(插入到给定元素的前面) ;
  3540. iTarget.parentNode.insertBefore(container, iTarget);
  3541. break;
  3542. case 'afterbegin' : // 'afterBegin'(作为给定元素的第一个子元素) ;
  3543. if (iTarget.firstChild) {
  3544. iTarget.insertBefore(container, iTarget.firstChild);
  3545. } else {
  3546. iTarget.appendChild(container);
  3547. };
  3548. break;
  3549. case 'beforeend' : // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  3550. iTarget.appendChild(container);
  3551. break;
  3552. case 'afterend' : // 'afterEnd'(插入到给定元素的后面);.
  3553. if (iTarget.nextSibling) {
  3554. iTarget.parentNode.insertBefore(container, iTarget.nextSibling);
  3555. } else {
  3556. iTarget.parentNode.appendChild(container);
  3557. };
  3558. break;
  3559. default:
  3560. iTarget.appendChild(container);
  3561. break;
  3562. };
  3563. // 兼容其他修改网页的脚本
  3564. if (matchedRule?.style) {
  3565. // 判断是否存在脚本 “AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列”
  3566. if(getSettingData.center==2){ // 自动判断是否添加
  3567. // console.log("判断是否自动添加");
  3568. // console.log(document.querySelector("#myuser"));
  3569. // console.log(matchedRule.style_ACBaidu);
  3570. if(document.querySelector(".AC-style-logo") && matchedRule.style_ACBaidu){
  3571. console.log("检测到脚本:“AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列” ------自动添加");
  3572. matchedRule.style = matchedRule.style_ACBaidu;
  3573. }
  3574. } else if (getSettingData.center==1){ // 强制添加
  3575. console.log("检测到脚本:“AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列” ------强制添加");
  3576. matchedRule.style = matchedRule.style_ACBaidu?matchedRule.style_ACBaidu:matchedRule.style;
  3577. } //
  3578. // 判断是否存在脚本“知乎排版优化”
  3579. if(document.getElementById('SearchMain')){
  3580. if(document.getElementById('SearchMain').style.marginLeft=='150px'){
  3581. matchedRule.style = matchedRule.style_ZhihuChenglinz;
  3582. matchedRule.fixedTop = null;
  3583. console.log("检测到‘知乎排版优化’脚本")
  3584. }
  3585. }
  3586. container.style.cssText = matchedRule.style;
  3587. };
  3588. //兼容ac百度中lite选项, fixedtop和正常的不一样
  3589. setTimeout(function(){
  3590. if(document.querySelector(".AC-baiduLiteStyle") && matchedRule.fixedTop2){
  3591. console.log("检测到 AC-baiduLiteStyle")
  3592. matchedRule.fixedTop = matchedRule.fixedTop2
  3593. }else{
  3594. console.log("没找到 AC-baiduLiteStyle")
  3595. }
  3596. },2500)
  3597. // 由于与要插入网页的样式无法很好的兼容,更改源网页的样式
  3598. if(matchedRule?.stylish){GM_addStyle(matchedRule.stylish);};
  3599. //固定搜索栏
  3600. if(getSettingData.fixedTop && matchedRule){
  3601. // 判断是否需要只在向上滚动时显示
  3602. if(getSettingData.fixedTopUpward){
  3603. window.onmousewheel = document.onmousewheel = function(eee){
  3604. if(eee.wheelDelta>0){
  3605. fixedTopFun(matchedRule.fixedTop, matchedRule.fixedTopColor);
  3606. }else{
  3607. var obj = document.getElementById("sej-container");
  3608. obj.style.cssText = matchedRule.style;
  3609. }
  3610. }
  3611. } else {
  3612. window.onscroll = function(){
  3613. fixedTopFun(matchedRule.fixedTop, matchedRule.fixedTopColor);
  3614. };
  3615. }
  3616. } else {
  3617. window.onscroll = function(){
  3618. return true;
  3619. };
  3620. };
  3621. // 固定搜索栏
  3622. function fixedTopFun(height, color){
  3623. var obj = document.getElementById("sej-container");
  3624. if(!obj){return};
  3625. var objTop = obj.offsetTop ;
  3626. var objLeft = obj.offsetLeft ;
  3627. var current = obj.offsetParent;
  3628. while (current !== null){
  3629. objLeft += current.offsetLeft;
  3630. current = current.offsetParent;
  3631. }
  3632. var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
  3633. if(height){
  3634. objTop = height;
  3635. }else{
  3636. height = 0;
  3637. }
  3638. if(scrollTop <= objTop){
  3639. obj.style.cssText = matchedRule.style;
  3640. }else if(obj.style.position!="fixed"){
  3641. // console.log("固定到顶端");
  3642. // console.log(scrollTop,objTop,scrollTop - objTop);
  3643. var objstyle = window.getComputedStyle(obj , null);
  3644. var marginTop = parseInt(objstyle.marginTop);
  3645. var marginLeft = parseInt(objstyle.marginLeft);
  3646. var marginRight = parseInt(objstyle.marginRight);
  3647. //console.log(objLeft,marginLeft);
  3648. obj.style.top = height - marginTop + 'px';
  3649. // 如果之前未设置颜色,则默认设置为白色
  3650. // 2020-12-19 增加选项,可以通过代码自定义颜色,但是无法通过网站自动获取
  3651. if(color){
  3652. obj.style.background = color;
  3653. } else if(objstyle.backgroundColor === "rgba(0, 0, 0, 0)" || objstyle.backgroundColor === "transparent"){
  3654. obj.style.background = '#fff';
  3655. }
  3656. obj.style.left = getElementLeft(obj) - marginLeft + "px";
  3657. // obj.style.left = getElementLeft(obj) + "px";
  3658. debug("objLeft: ",objLeft,"marginLeft: ",marginLeft,"marginRight: ",marginRight,"getElementLeft: ",getElementLeft(obj));
  3659. // 知乎等网站的情况 利用 margin 居中
  3660. if(marginRight === marginLeft && marginRight != 0){
  3661. obj.style.left = marginLeft + "px";
  3662. }
  3663. // 淘宝等网站的情况 利用 text-align 居中
  3664. if(obj.style.textAlign === "center"){
  3665. obj.style.width = objstyle.width;
  3666. }
  3667. obj.style.position = 'fixed';
  3668. obj.style.padding = "0px 5px 0px 0px"; // 重置padding, 因为用了 fixed 定位, 没必要继续用padding,反而会带来遮挡
  3669. // if(document.querySelectorAll("input[name='sp-ac-a_force_style_baidu']").length !=0){
  3670. // console.log("检测到 ac脚本单列居中选项")
  3671. // if((document.querySelectorAll("input[name='sp-ac-a_force_style_baidu']")[2].checked)){
  3672. // obj.style.display = "none";
  3673. // obj.style.transform = "translate(-50%, 0)";
  3674. // obj.style.top = "none" ;
  3675. // obj.style.position = 'fixed';
  3676. // fixedTopFun2(matchedRule.fixedTopTarget,matchedRule.fixedTopWhere);
  3677. // return;
  3678. // }
  3679. // }
  3680. }
  3681. }
  3682. function fixedTopFun2(Target,where){
  3683. var obj = document.getElementById("sej-container");
  3684. var oTarget = getElement(Target)
  3685. console.log("fixedTopFun2");
  3686. console.log(Target);
  3687. console.log(where);
  3688. switch (where.toLowerCase()) {
  3689. case 'beforebegin' : // 'beforeBegin'(插入到给定元素的前面) ;
  3690. oTarget.parentNode.insertBefore(obj, oTarget);
  3691. break;
  3692. case 'afterbegin' : // 'afterBegin'(作为给定元素的第一个子元素) ;
  3693. if (oTarget.firstChild) {
  3694. oTarget.insertBefore(obj, oTarget.firstChild);
  3695. } else {
  3696. oTarget.appendChild(obj);
  3697. };
  3698. break;
  3699. case 'beforeend' : // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  3700. oTarget.appendChild(obj);
  3701. break;
  3702. case 'afterend' : // 'afterEnd'(插入到给定元素的后面);.
  3703. if (oTarget.nextSibling) {
  3704. oTarget.parentNode.insertBefore(obj, oTarget.nextSibling);
  3705. } else {
  3706. oTarget.parentNode.appendChild(obj);
  3707. };
  3708. break;
  3709. };
  3710. };
  3711. }
  3712.  
  3713.  
  3714.  
  3715. // -------------------设置相关--------------------------------
  3716. // 设置按钮相关
  3717. var dragEl = null;
  3718. var dragData = null;
  3719.  
  3720. function SEJsetting(){
  3721. this.ele = document.createElement("div");
  3722. this.mask = document.createElement("div");
  3723.  
  3724. this.parentTemp = null;
  3725. this.editTemp = null;
  3726. this.online = null;
  3727. this.init();
  3728. };
  3729.  
  3730. SEJsetting.prototype = {
  3731. testabc : "hahah",
  3732. aPatternParent : "<div></div>",
  3733.  
  3734. init: function () {
  3735. // console.log("init...");
  3736. var that = this;
  3737.  
  3738. this.ele.id = "settingLayer";
  3739. this.mask.id = "settingLayerMask";
  3740.  
  3741. this.addGlobalStyle();
  3742.  
  3743. this.addContent();
  3744.  
  3745. this.mask.addEventListener("click",function(){
  3746. that.hide();
  3747. });
  3748. this.ele.addEventListener("click",function(e){
  3749. e.stopPropagation();
  3750. });
  3751.  
  3752. this.mask.appendChild(this.ele);
  3753. document.body.appendChild(this.mask);
  3754.  
  3755. // 绑定事件
  3756. this.ele.addEventListener("click",that.domClick.bind(this),false);
  3757. this.dragEvent();
  3758. this.setDragNode(this.ele); //设置拖动
  3759. // input[range]
  3760. that.rangeChange(true);
  3761. document.querySelector("#setBtnOpacityRange").addEventListener("input",that.rangeChange);
  3762. },
  3763. dragEvent: function(){
  3764. var that = this;
  3765. var odivsdrag = document.querySelectorAll(".drag");
  3766. [].forEach.call(odivsdrag,function(odiv){
  3767. odiv.addEventListener("dragstart",that.domdragstart,false);
  3768. odiv.addEventListener('dragenter', that.domdragenter, false);
  3769. odiv.addEventListener('dragover', that.domdragover, false);
  3770. odiv.addEventListener('dragleave', that.domdragleave, false);
  3771. odiv.addEventListener('drop', that.domdrop, false);
  3772. odiv.addEventListener('dragend',that.domdropend, false);
  3773. });
  3774. },
  3775. addContent: function(){
  3776. var aPattern = '<span draggable="true" class="drag">' +
  3777. '<span class="sej-engine"' +
  3778. ' data-xin="$xin$" ' +
  3779. ' data-iqxinimg="$img$" ' +
  3780. ' data-iqxintitle="$title$" ' +
  3781. ' data-iqxinlink="$link$" ' +
  3782. ' data-iqxintarget="$blank$" ' +
  3783. ' data-iqxindisabled="$disabled$" ' +
  3784. ' data-iqxingbk="$gbk$" ' +
  3785. '><img src="$favicon$" class="sej-engine-icon" style="padding-bottom:3px;"/><span>$name$</span></span>' +
  3786. ' <span class="iqxin-set-edit" title="编辑 Edit"><img class="sej-engine-icon" src=""/></span>' +
  3787. ' <span class="iqxin-set-del" title="删除 Delete"><img class="sej-engine-icon" src=""></span>' +
  3788. '</span>';
  3789. var details = engineList.details;
  3790. // 若根据数组长度获取,负数引导的为属性,不再length长度之内,所以来个大体的数字,当都为空时,结束循环
  3791. // var detailsLength = details.length;
  3792. var detailsLength = 99;
  3793. for (let i=0;i<detailsLength;i++){
  3794. var j = i;
  3795. j = details[j] ? j : -j;
  3796. if (!details[j]){break};
  3797.  
  3798. var odiv = document.createElement("div");
  3799. odiv.id = details[j][1]; // "web"
  3800. odiv.classList.add("iqxin-items");
  3801.  
  3802. var oDivTitle = document.createElement("div");
  3803. oDivTitle.classList.add("sejtitle","drag");
  3804. oDivTitle.setAttribute("draggable","true");
  3805. oDivTitle.dataset.iqxintitle = details[j][1];
  3806. oDivTitle.dataset.xin = j;
  3807. oDivTitle.innerHTML ='<span class="iqxin-pointer-events">' + details[j][0] + '</span>' +
  3808. '<span class="iqxin-title-edit" title="编辑 Edit"><img class="sej-engine-icon" src="' + icon.edit + '"/></span>'+
  3809. ' <span class="iqxin-set-title-del" title="删除 Delete"><img class="sej-engine-icon" src="' + icon.del + '"></span>';
  3810. odiv.appendChild(oDivTitle);
  3811.  
  3812. var oDivCon = document.createElement("div");
  3813. oDivCon.classList.add("sejcon");
  3814. var oDivConStr = "";
  3815. var engineListItme = engineList[details[j][1]];
  3816. var itemLength = engineListItme.length;
  3817. for(let ii=0;ii<itemLength;ii++){
  3818. var jj = ii;
  3819. if (!engineListItme[jj]){break};
  3820. var a = aPattern.replace('$name$', engineListItme[jj].name)
  3821. .replace('$favicon$', engineListItme[jj].favicon)
  3822. .replace("$xin$",jj);
  3823. // 添加属性
  3824. a = a.replace("$img$", engineListItme[jj].favicon)
  3825. .replace("$title$", engineListItme[jj].name)
  3826. .replace("$link$", engineListItme[jj].url);
  3827. if (engineListItme[jj].blank) {
  3828. a = a.replace('$blank$', "_blank");
  3829. } else {
  3830. a = a.replace('data-iqxintarget="$blank$"', '');
  3831. };
  3832. if (engineListItme[jj].disable) {
  3833. a = a.replace('$disabled$', "true");
  3834. } else {
  3835. a = a.replace('data-iqxindisabled="$disabled$"', '');
  3836. };
  3837. if (engineListItme[jj].gbk) {
  3838. a = a.replace('$gbk$', "true");
  3839. } else {
  3840. a = a.replace('data-iqxingbk="$gbk$"', '');
  3841. };
  3842.  
  3843. oDivConStr += a;
  3844. };
  3845.  
  3846. oDivConStr += "<span class='iqxin-additem'>+</span>";
  3847.  
  3848. oDivCon.innerHTML = oDivConStr;
  3849. odiv.appendChild(oDivCon);
  3850.  
  3851. this.ele.appendChild(odiv);
  3852. };
  3853.  
  3854. // 更多设置 菜单
  3855. var btnEle2 = document.createElement("div");
  3856. btnEle2.id = "btnEle2"
  3857. var fixedTop_checked = getSettingData.fixedTop?"checked":"";
  3858. var fixedTopUpward_checked = getSettingData.fixedTopUpward?"checked":"";
  3859. // var debug_checked = getSettingData.debug?"checked":"";
  3860. var transition_checked = getSettingData.transtion?"checked":"";
  3861. var selectSearch_checked = getSettingData.selectSearch?"checked":"";
  3862. var foldlist_checked = getSettingData.foldlist?"checked":"";
  3863. var allOpen_checked = getSettingData.allOpen?"checked":"";
  3864. var HideTheSameLink_checked = getSettingData.HideTheSameLink?"checked":"";
  3865.  
  3866. // var setBtnOpacity_value = getSettingData.setBtnOpacity;
  3867. var btnStr2 = "<div>" +
  3868. // "<span id='xin-reset' title='慎点,出厂重置'>清空设置</span>" +
  3869. "<span id='xin-modification' title='edit 分享自己的配置或清空配置'>配置文件</span>" +
  3870. // "<span id='xin-importing' title='importing 导入更为专业的搜索引擎'>导入</span>" +
  3871. "<span id='xin-selectSearch' title='划词搜索, 只有非搜索页面才会生效, 开关功能需要刷新页面'>" +
  3872. "<label>划词搜索<input id='iqxin-selectSearch' type='checkbox' name='' " +
  3873. selectSearch_checked +
  3874. " style='vertical-align:middle;'></label>" +
  3875. "</span>" +
  3876. // "<span id='iqxin-debugS' title='对设置菜单有一定的影响'>" +
  3877. // "<label>debug<input id='iqxin-debug' type='checkbox' name='' " +
  3878. // debug_checked +
  3879. // " style='vertical-align:middle;'></label>" +
  3880. // "</span>" +
  3881. "<span id='xin-transtion' title='动画,该设置需要刷新页面生效'>" +
  3882. "<label>动画<input id='iqxin-transtion' type='checkbox' name='' " +
  3883. transition_checked +
  3884. " style='vertical-align:middle;'></label>" +
  3885. "</span>" +
  3886. "<span id='xin-foldlists' title='将当前所在搜索分类折叠'>" +
  3887. "<label>折叠当前搜索分类<input id='iqxin-foldlist' type='checkbox' name='' " +
  3888. foldlist_checked +
  3889. " style='vertical-align:middle;'></label>" +
  3890. "</span>" +
  3891. "<span id='iqxin-fixedTopS' title='fixedTop 当滚动页面时,固定到页面顶端。某些页面的样式存在问题'>" +
  3892. "<label>固定到顶端<input id='iqxin-fixedTop' type='checkbox' name='' " +
  3893. fixedTop_checked +
  3894. " style='vertical-align:middle;'></label>" +
  3895. "</span>" +
  3896. "<span id='iqxin-fixedTopUpward' title='固定到顶端后,仅向上滚动才显示,需要刷新网页生效'>" +
  3897. "<label>仅上拉显示<input id='iqxin-fixedTopUpward-item' type='checkbox' name='' " +
  3898. fixedTopUpward_checked +
  3899. " style='vertical-align:middle;'></label>" +
  3900. "</span>" +
  3901. "<span id='xin-HideTheSameLink' title='隐藏同站链接,如果想在同一个搜索网站,但是想通过不同语言来搜索, 可以取消该选项'>" +
  3902. "<label>隐藏同站链接<input id='iqxin-HideTheSameLink' type='checkbox' name='' " +
  3903. HideTheSameLink_checked +
  3904. " style='vertical-align:middle;'></label>" +
  3905. "</span>" +
  3906. "<span id='xin-setBtnOpacity' title='设置按钮透明度,需要刷新页面'>设置按钮透明度 <input type='range' step='0.05' min='0' max='1' value='"+ (getSettingData.setBtnOpacity<0?-getSettingData.setBtnOpacity:getSettingData.setBtnOpacity) +"' id='setBtnOpacityRange'><i style='display:inline-block;width:3em;text-align:center;' class='iqxin-setBtnOpacityRangeValue' title='按钮 显示/隐藏(非透明)),请确定知道自己如何再次打开; 火狐非高级玩家建议别禁用'></i></span>" +
  3907.  
  3908. "</div>" ;
  3909. // "<div><span>test</span></div>";
  3910. btnEle2.innerHTML = btnStr2;
  3911. this.ele.appendChild(btnEle2);
  3912.  
  3913.  
  3914. // 添加按钮
  3915. var btnEle = document.createElement("div");
  3916. btnEle.id = "btnEle"
  3917.  
  3918. var btnStr = "<div class='btnEleLayer'>" +
  3919. "<span class='feedback' title='在 GreasyFork 进行反馈'><a target='_blank' href='https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump'>Greasy Fork镜像</a></span>" +
  3920. "<span class='feedback' title='在 Github 进行反馈'><a target='_blank' href='https://github.com/qxinGitHub/searchEngineJump'>GitHub</a></span>" +
  3921. "<span id='xin-allOpen' title='后台打开该搜索分类的所有网站'>" +
  3922. "<label>一键搜索<input id='iqxin-allOpen-item' type='checkbox' name='' " +
  3923. allOpen_checked +
  3924. " style='vertical-align:middle;'></label>" +
  3925. "</span>" +
  3926. "<span id='xin-centerDisplay' title='center 居中显示。主要是兼容AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列'>居中:" +
  3927. "<select id='iqxin-center'>" +
  3928. "<option value='original'" + (getSettingData.center == 0?"selected":"") + ">默认 ▽</option>" +
  3929. "<option value='force'" + (getSettingData.center == 1?"selected":"") + ">强制 ▽</option>" +
  3930. "<option value='auto'" + (getSettingData.center == 2?"selected":"") + ">自动 ▽</option>" +
  3931. "</select>" +
  3932. "</span> " +
  3933. "<span id='xin-newtab' title='open newtab 是否采用新标签页打开的方式'>打开方式:" +
  3934. "<select id='iqxin-globalNewtab'>" +
  3935. "<option value='globalDef'>默认页面 ▽</option>" +
  3936. "<option value='globalNewtab'" + (getSettingData.newtab?"selected":"") + ">新标签页 ▽</option>" +
  3937. "</select>" +
  3938. "</span> " +
  3939. "<span id='xin-addDel' title='add & del 增加新的或者删除现有的搜索'>增加 / 删除</span> " +
  3940. "<span id='moreSet' title='more set'>更多设置</span>" +
  3941. "<span id='xin-save' title='save & close'>保存并关闭</span>" +
  3942. "</div>";
  3943. btnEle.innerHTML = btnStr;
  3944. this.ele.appendChild(btnEle);
  3945.  
  3946. // 可以拖动的顶栏
  3947. var dragDom = document.createElement("div");
  3948. dragDom.id = "dragDom";
  3949. dragDom.style.cssText = "height:16px;width:97%;position:absolute;top:0;cursor:move;";
  3950. this.ele.appendChild(dragDom);
  3951.  
  3952. // 增加搜索列表
  3953. var nSearchList = document.createElement("div");
  3954. nSearchList.id = "nSearchList";
  3955. nSearchList.style.cssText = "visibility:hidden;opacity:0;transition:0.3s;position:absolute;bottom:10%;right:5%;padding:5px 10px;border-radius:4px;border:1px solid #EC6D51;color:#ec6d51;cursor:pointer;background:#fff;";
  3956. nSearchList.innerHTML = "增加新的搜索列表";
  3957. this.ele.appendChild(nSearchList);
  3958.  
  3959. // 关闭按钮
  3960. if(getSettingData.closeBtn){
  3961. var closebtnELe = document.createElement("span");
  3962. closebtnELe.id = "xin-close";
  3963. closebtnELe.setAttribute("title","close 关闭");
  3964. this.ele.appendChild(closebtnELe);
  3965. }
  3966. },
  3967. show: function(){
  3968. var style = this.mask.style;
  3969. var eleStyle = this.ele.style;
  3970. style.display = "flex";
  3971. eleStyle.transform = "translateY(-20%)";
  3972. document.body.style.overflow = "hidden";
  3973.  
  3974. this.windowResize();
  3975.  
  3976. // if(document.querySelector("xin-newtab")){
  3977. // document.querySelector("#xin-newtab").querySelectorAll("option")[getSettingData.newtab].setAttribute("selected","selected");
  3978. // }
  3979.  
  3980. setTimeout(function () {
  3981. style.opacity = 1;
  3982. eleStyle.transform = "none";
  3983. }, 30);
  3984. },
  3985. hide: function(){
  3986. this.allBoxClose(); // 关闭所有次级窗口、菜单
  3987.  
  3988. var style = this.mask.style;
  3989. this.ele.style.transform = "translateY(20%)";
  3990. style.opacity = 0;
  3991. setTimeout(function () {
  3992. style.display = "none";
  3993. document.body.style.overflow = "auto";
  3994. }, 500);
  3995. },
  3996. reset: function(){
  3997. if(confirm("将会删除用户设置!")){
  3998. GM_deleteValue("searchEngineJumpData");
  3999. window.location.reload();
  4000. }
  4001. },
  4002. // 增加 “添加删除框”
  4003. addDel: function(e){
  4004. if (e.target.classList.contains("iqxin-btn-active")){
  4005. this.addDelremove();
  4006. } else {
  4007. // console.log("不存在,增加增加");
  4008. var obtn = document.querySelector("#xin-addDel");
  4009. obtn.classList.add("iqxin-btn-active");
  4010.  
  4011. var odom = document.querySelectorAll(".iqxin-set-del");
  4012. [].forEach.call(odom,function(div){
  4013. div.classList.add("iqxin-set-active");
  4014. });
  4015.  
  4016. // 标题添加删除框
  4017. var odom = document.querySelectorAll(".iqxin-set-title-del");
  4018. [].forEach.call(odom,function(div){
  4019. // console.log(div);
  4020. div.classList.add("iqxin-set-active");
  4021. });
  4022.  
  4023. // 增加单个搜索
  4024. var oitemAdd = document.querySelectorAll(".iqxin-additem");
  4025. [].forEach.call(oitemAdd,function(div){
  4026. // console.log(div);
  4027. div.classList.add("iqxin-set-active");
  4028. });
  4029.  
  4030. // 添加搜索列表
  4031. var olistAdd = document.querySelector("#nSearchList");
  4032. olistAdd.classList.add("iqxin-set-active");
  4033.  
  4034. }
  4035. },
  4036. // 关闭 “添加删除框”
  4037. addDelremove: function(bool){
  4038. var obtn = document.querySelector(".iqxin-btn-active");
  4039. if(obtn){
  4040. obtn.classList.remove("iqxin-btn-active");
  4041.  
  4042. var odom = document.querySelectorAll(".iqxin-set-active");
  4043. [].forEach.call(odom,function(div){
  4044. div.classList.remove("iqxin-set-active");
  4045. });
  4046.  
  4047. var oitemAdd = document.querySelectorAll(".iqxin-additem");
  4048. [].forEach.call(oitemAdd,function(div){
  4049. div.classList.remove("iqxin-set-active");
  4050. });
  4051. }
  4052. this.addItemBoxRemove();
  4053. },
  4054.  
  4055. // 界面,框:添加新的搜索
  4056. addItemBox: function(bool){
  4057. this.isOnline();
  4058. this.addItemBoxRemove();
  4059.  
  4060. var newDiv = document.createElement("div");
  4061. newDiv.id= "newSearchBox";
  4062. newDiv.style.cssText = "top:43%;opacity:0.1;";
  4063. newDiv.innerHTML=""+
  4064. "<span>标&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp题 : </span><input id='iqxin-newTitle' placeholder='必填' onfocus='this.select()' /> <br/><br/>" +
  4065. "<span>链&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp接 : </span><input id='iqxin-newLink' placeholder='必填' onfocus='this.select()' /> <br/><br/>" +
  4066. "<span>图&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp标 : </span><input id='iqxin-newIcon' placeholder='选填,留空则自动获取' onfocus='this.select()' /> <br/><br/>" +
  4067. "<span>打开方式 : " +
  4068. '<select id="iqxin-newTarget" style="border-radius: 4px;border: none;padding: 2px 0 2px 2px"> ' +
  4069. '<option value="default">新标签页打开</option> ' +
  4070. '<option value="newtab">当前页打开</option> ' +
  4071. '<select> ' +
  4072. "</span>" +
  4073. "<br/><br/>" +
  4074. "<span style=''><a target='_blank' style='color:#999;' href='https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump'>相关使用说明</a></span>" +
  4075. "&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp;" +
  4076. "<button id='addItemBoxEnter' class='addItemBoxEnter addItemBoxBtn iqxin-enterBtn'>确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp" +
  4077. "<button id='addItemBoxCancel' class='addItemBoxCancel addItemBoxBtn iqxin-closeBtn'>取消</button>" +
  4078. "";
  4079.  
  4080. this.ele.appendChild(newDiv);
  4081. setTimeout(function(){newDiv.style.cssText="";},10);
  4082. document.querySelector("#iqxin-newTitle").focus();
  4083. },
  4084. // 内部逻辑,:添加新的搜索
  4085. addItemEnger: function(){
  4086. var otitle,olink,oimg,oblank;
  4087. otitle = document.querySelector("#iqxin-newTitle").value;
  4088. olink = document.querySelector("#iqxin-newLink").value;
  4089. oimg = document.querySelector("#iqxin-newIcon").value;
  4090. oblank = document.querySelector("#iqxin-newTarget").selectedIndex;
  4091.  
  4092. if (!oimg){
  4093. oimg = this.getICON(olink);
  4094. }
  4095.  
  4096. var a = '<span class="sej-engine"' +
  4097. ' data-iqxinimg="$img$" ' +
  4098. ' data-iqxintitle="$title$" ' +
  4099. ' data-iqxinlink="$link$" ' +
  4100. ' data-iqxintarget="$blank$" ' +
  4101. '><img src="$favicon$" class="sej-engine-icon" />$name$</span>' +
  4102. '<span class="iqxin-set-edit" title="编辑 Edit">' +
  4103. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4104. '</span> ' +
  4105. '<span class="iqxin-set-del iqxin-set-active" title="删除 Delete">' +
  4106. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4107. '</span>' ;
  4108.  
  4109. a = a.replace("$img$", oimg)
  4110. .replace("$title$", otitle)
  4111. .replace("$link$", olink);
  4112.  
  4113. if (oblank){
  4114. a = a.replace('data-iqxintarget="$blank$"', '');
  4115. } else {
  4116. a = a.replace('$blank$', "_blank");
  4117. };
  4118.  
  4119. a = a.replace('$name$', otitle)
  4120. .replace('$favicon$', oimg);
  4121.  
  4122. var ospan = document.createElement("span");
  4123. ospan.className = "drag";
  4124. ospan.innerHTML = a;
  4125.  
  4126. this.parentNode.insertBefore(ospan,this.parentNode.lastChild);
  4127.  
  4128. // 添加完成,移除添加框
  4129. this.addItemBoxRemove();
  4130. },
  4131. addItemBoxRemove: function(ele){
  4132. ele = ele?ele:"#newSearchBox"
  4133. var newBox = document.querySelector(ele);
  4134. if(newBox){
  4135. // newBox.style.transform = "translateY(30%)";
  4136. newBox.style.top = "60%";
  4137. newBox.style.opacity = "0";
  4138. setTimeout(function(){
  4139. newBox.parentNode.removeChild(newBox);
  4140. },550);
  4141. }
  4142. },
  4143. // 获取图标
  4144. getICON: function(olink){
  4145. var ourl;
  4146. var mark;
  4147. var uri = parseUri(olink);
  4148. var ohttp = uri.protocol?uri.protocol:"http";
  4149. var siteURL = ohttp + "://" + uri.host;
  4150. // console.log(siteURL);
  4151.  
  4152. if(isNaN(getSettingData.getIcon)){
  4153. ourl = getSettingData.getIcon;
  4154. } else {
  4155. mark = parseInt(getSettingData.getIcon);
  4156. console.log(mark);
  4157. switch (mark){
  4158. case 1: ourl = siteURL + "/favicon.ico";break;
  4159. case 2: ourl = 'https://www.google.com/s2/favicons?domain='+siteURL;break;
  4160. case 3: ourl = 'http://statics.dnspod.cn/proxy_favicon/_/favicon?domain='+uri.host;break;
  4161. }
  4162. }
  4163.  
  4164. if(ourl){
  4165. ourl = ourl.replace("%s", siteURL)
  4166. return ourl;
  4167. }
  4168. debug("能否连接至google:",this.online);
  4169. if (this.online){
  4170. ourl = 'https://www.google.com/s2/favicons?domain=' + uri.host;
  4171. return ourl;
  4172. } else {
  4173. ourl = ohttp + "://" + uri.host + "/favicon.ico";
  4174. return ourl;
  4175. }
  4176. },
  4177.  
  4178. // 界面, 框: 添加新的搜索列表
  4179. addSearchListBox: function(){
  4180. var odiv = document.querySelector("#newSearchListBox");
  4181. if (odiv){
  4182. this.boxClose("#newSearchListBox");
  4183. return;
  4184. }
  4185. var newDiv = document.createElement("div");
  4186. newDiv.id= "newSearchListBox";
  4187.  
  4188. var myDate = new Date();
  4189. // var hash = "user" + myDate.getFullYear() + myDate.getMonth() + myDate.getDate() + myDate.getHours() +myDate.getMinutes()+myDate.getSeconds();
  4190. var hash = "user" + myDate.getTime();
  4191.  
  4192. newDiv.innerHTML=""+
  4193. "<span>列表名称: </span><input id='iqxin-newSearchListName' onfocus='this.select()'>" +
  4194. "<br><br>" +
  4195. "<span>内部名称: </span><input id='iqxin-newSearchListInnerName' onfocus='this.select()' value='" + hash + "'>" +
  4196. "<br><br>" +
  4197. "<button id='addSearchListBoxEnter' class='addSearchListBoxEnter addItemBoxBtn'>确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp" +
  4198. "<button id='addSearchListBoxCancel' class='addSearchListBoxCancel addItemBoxBtn'>取消</button>" +
  4199. "";
  4200. this.ele.appendChild(newDiv);
  4201.  
  4202. document.querySelector("#iqxin-newSearchListName").focus();
  4203. },
  4204. addSearchListEnger: function(){
  4205. var name = document.querySelector("#iqxin-newSearchListName").value;
  4206. var innerName = document.querySelector("#iqxin-newSearchListInnerName").value;
  4207.  
  4208. if(innerName.length===0){
  4209. alert("内部名称不能为空");
  4210. return;
  4211. }
  4212. if(name.length===0){
  4213. name = innerName;
  4214. }
  4215.  
  4216. var odiv = document.createElement("div");
  4217. odiv.id = innerName;
  4218. odiv.className = "iqxin-items";
  4219. odiv.innerHTML = "" +
  4220. '<div class="sejtitle" data-iqxintitle="' + innerName + '" data-xin="99">' +
  4221. '<span class="iqxin-pointer-events">'+ name +'</span>' +
  4222. '<span class="iqxin-title-edit" title="编辑 Edit">' +
  4223. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4224. '</span> ' +
  4225. '<span class="iqxin-set-title-del iqxin-set-active" title="删除 Delete">' +
  4226. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4227. '</span>' +
  4228. '</div>' +
  4229. '<div class="sejcon">' +
  4230. '<span class="iqxin-additem iqxin-set-active">+</span>' +
  4231. '</div>' +
  4232. "";
  4233.  
  4234. // this.boxClose("#newSearchListBox");
  4235. this.addItemBoxRemove("#newSearchListBox");
  4236.  
  4237. var btnEle = document.querySelector("#btnEle");
  4238. btnEle.parentNode.insertBefore(odiv,btnEle);
  4239. },
  4240.  
  4241. boxClose: function(ele){
  4242. var odiv = document.querySelector(ele);
  4243. if(odiv){
  4244. odiv.parentNode.removeChild(odiv);
  4245. }
  4246. },
  4247.  
  4248. // 界面 框:修改框
  4249. addEditBox: function(e){
  4250. console.log(e);
  4251. this.addItemBoxRemove();
  4252.  
  4253. var target = e.target.parentNode.firstChild;
  4254.  
  4255. var otitle = target.dataset.iqxintitle;
  4256. var olink = target.dataset.iqxinlink;
  4257. var oicon = target.dataset.iqxinimg;
  4258. var otarget = target.dataset.iqxintarget;
  4259. var odisabled = target.dataset.iqxindisabled;
  4260. let oGBK = target.dataset.iqxingbk;
  4261.  
  4262. this.editTemp = target;
  4263.  
  4264. console.log(oicon);
  4265.  
  4266. var strblank;
  4267. if(otarget){
  4268. strblank = '<option value="default">新标签页打开</option><option value="newtab">当前页打开</option> ';
  4269. } else{
  4270. strblank = '<option value="default">新标签页打开</option><option value="newtab" selected="selected">当前页打开</option>';
  4271. }
  4272.  
  4273. var strGBK = "";
  4274. if(oGBK){
  4275. strGBK = "checked='checked'";
  4276. }
  4277.  
  4278. var newDiv = document.createElement("div");
  4279. newDiv.id= "newSearchBox";
  4280. // 从鼠标点击所在的项目展开菜单(2021-03-16,从上线至今,动画一直有卡顿现象)
  4281. // newDiv.style.cssText = "top:"+(e.screenY-120) +"px;left:"+(e.screenX-140) +"px;";
  4282. newDiv.style.cssText = "top:43%;opacity:0.1;";
  4283. var innerHTML=`
  4284. <span>标&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp : </span><input id="iqxin-newTitle" placeholder="必填" onfocus="this.select()" value="${otitle}" /> <br/><br/>
  4285. <span>链&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp : </span><input id="iqxin-newLink" placeholder="必填" onfocus="this.select()" value="${olink }" /> <br/><br/>
  4286. <span>图&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp : </span><input id="iqxin-newIcon" placeholder="选填,留空则自动获取" onfocus="this.select()" value="${oicon }" /> <br/><br/>
  4287. <span>打开方式 :
  4288. <select id="iqxin-newTarget" style="border-radius: 4px;border: none;padding: 2px 0 2px 2px">
  4289. ${strblank}
  4290. <select>
  4291. </span>
  4292. <br/><br/>
  4293. <span style=""><label>GBK编码:<input type="checkbox" name="" id="iqxin-newGBK" ${strGBK} style="vertical-align:middle;"></label></span>
  4294. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  4295. <button id="editItemBoxEnter" class="editItemBoxEnter addItemBoxBtn iqxin-enterBtn">确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp
  4296. <button id="addItemBoxCancel" class="addItemBoxCancel addItemBoxBtn iqxin-closeBtn">取消</button>
  4297. `
  4298.  
  4299. newDiv.innerHTML = innerHTML;
  4300.  
  4301. this.ele.appendChild(newDiv);
  4302. setTimeout(function(){newDiv.style.cssText="";},10);
  4303. document.querySelector("#iqxin-newTitle").select();
  4304. },
  4305. addEditBoxEnger: function(){
  4306. var otitle,olink,oimg,oblank,ogbk;
  4307. otitle = document.querySelector("#iqxin-newTitle").value;
  4308. olink = document.querySelector("#iqxin-newLink").value;
  4309. oimg = document.querySelector("#iqxin-newIcon").value;
  4310. oblank = document.querySelector("#iqxin-newTarget").selectedIndex;
  4311. ogbk = document.querySelector("#iqxin-newGBK").checked;
  4312.  
  4313. this.editTemp.dataset.iqxintitle = otitle;
  4314. this.editTemp.lastChild.innerText = otitle; //文本节点
  4315.  
  4316. this.editTemp.dataset.iqxinlink = olink;
  4317. this.editTemp.dataset.iqxinimg = oimg;
  4318. this.editTemp.firstChild.src = oimg;
  4319.  
  4320. // 是否新标签页打开
  4321. if (oblank){
  4322. this.editTemp.removeAttribute("data-iqxintarget");
  4323. } else {
  4324. this.editTemp.dataset.iqxintarget = "_blank";
  4325. }
  4326. // 是否禁用
  4327. if (ogbk){
  4328. this.editTemp.dataset.iqxingbk = "true";
  4329. } else{
  4330. this.editTemp.removeAttribute("data-iqxingbk");
  4331. }
  4332.  
  4333. // 修改完成,移除添加框
  4334. this.addItemBoxRemove();
  4335. },
  4336.  
  4337. // 标题编辑
  4338. addTitleEditBox: function(e){
  4339. this.addItemBoxRemove();
  4340.  
  4341. var element = e.target.parentNode.firstChild;
  4342. element.classList.remove("iqxin-pointer-events");
  4343.  
  4344. var flag = document.querySelector("#titleEdit");
  4345. // 存在编辑的标题 && 之前的编辑的节点与点击的节点是同一个节点
  4346. if(flag && flag.parentNode == element){
  4347. element.innerHTML = element.firstChild.value?element.firstChild.value:"空";
  4348. element.classList.add("iqxin-pointer-events");
  4349. } else {
  4350. // 存在编辑的标题,但与点击的不是同一个节点
  4351. if(flag){
  4352. flag.parentNode.innerHTML = flag.parentNode.firstChild.value;
  4353. }
  4354. var oldhtml = element.innerHTML;
  4355. var newobj = document.createElement("input");
  4356. newobj.id = "titleEdit";
  4357. newobj.type = "text";
  4358. newobj.value = oldhtml;
  4359. // newobj.onblur = function(){
  4360. // element.innerHTML = this.value?this.value:oldhtml;
  4361. // }
  4362. newobj.onkeydown = function(e){
  4363. if((e.keyCode || e.which) == 13){
  4364. element.innerHTML = this.value?this.value:oldhtml;
  4365. } else if((e.keyCode || e.which) == 27){
  4366. element.innerHTML = oldhtml;
  4367. }
  4368.  
  4369. element.classList.add("iqxin-pointer-events");
  4370. }
  4371. element.innerHTML = "";
  4372. element.appendChild(newobj);
  4373. newobj.select();
  4374. }
  4375. },
  4376. addTitleEditBoxRemove:function(){
  4377. var odiv = document.querySelector("#titleEdit");
  4378. if(odiv){
  4379. odiv.parentNode.innerHTML = odiv.value?odiv.value:"空";
  4380. }
  4381. },
  4382.  
  4383. // 高级菜单,配置文件编辑界面
  4384. editCodeBox: function(){
  4385. console.log("原始数据: ",getSettingData);
  4386. var userSetting = GM_getValue("searchEngineJumpData")
  4387. var editbox = document.createElement("div");
  4388. // var sData =
  4389. editbox.id = "iqxin-editCodeBox";
  4390. editbox.style.cssText = "position:fixed;" +
  4391. "top:50%;left:50%;" +
  4392. "transform:translate(-50%,-50%);" +
  4393. "background:#ccc;" +
  4394. "border-radius:4px;" +
  4395. "padding:10px 20px;" ;
  4396. var innerH = " "+
  4397. "<p><span style='color:red;font-size:1.2em;'>! ! !</span></br>"+
  4398. "此处有更多的设置选项,自由度更高,</br>"+
  4399. "但设置错误会导致脚本无法运行"+
  4400. "</p>" +
  4401. "<textarea wrap='off' cols='45' rows='20' style='overflow:auto;border-radius:4px;'>" + JSON.stringify(userSetting,false,4) + "</textarea>" +
  4402. "<br>" +
  4403. "<button id='xin-reset'>清空设置</button> &nbsp;&nbsp;&nbsp;" +
  4404. "<button id='xin-copyCode'>复制</button> &nbsp;&nbsp;&nbsp;" +
  4405. "<button id='codeboxclose' class='iqxin-closeBtn'>关闭</button> &nbsp;&nbsp;&nbsp;" +
  4406. "<button id='xin-codeboxsave' class='iqxin-enterBtn'>保存</button>" +
  4407. "";
  4408. // console.log(JSON.stringify(getSettingData,4));
  4409. // console.log(JSON.stringify(getSettingData,null,4));
  4410. editbox.innerHTML = innerH;
  4411. this.ele.appendChild(editbox);
  4412. },
  4413. editCodeBoxSave: function(){
  4414. var codevalue = document.querySelector("#iqxin-editCodeBox textarea").value;
  4415. if(codevalue){
  4416. // console.log(JSON.parse(codevalue));
  4417. GM_setValue("searchEngineJumpData",JSON.parse(codevalue));
  4418. // console.log(GM_getValue("searchEngineJumpData"));
  4419. // 刷新页面
  4420. setTimeout(function(){
  4421. window.location.reload();
  4422. },300);
  4423. } else {
  4424. // alert("输入为空");
  4425. this.reset();
  4426. }
  4427. },
  4428. editCodeBoxClose: function(){
  4429. var box = document.querySelector("#iqxin-editCodeBox");
  4430. if(box){
  4431. box.parentNode.removeChild(box);
  4432. }
  4433. },
  4434.  
  4435. // 导入窗口
  4436. addImportingBox: function(){
  4437. var odiv = document.querySelector("#importingBox");
  4438. if (odiv){
  4439. this.boxClose("#importingBox");
  4440. return;
  4441. }
  4442. var newDiv = document.createElement("div");
  4443. newDiv.id= "importingBox";
  4444.  
  4445. var a ="<p>更加细分的搜索列表, 列表之间会有所重合</p>" +
  4446. "<ul>";
  4447.  
  4448. for(let i=0;i<engineList_plus.length;i++){
  4449. // if(engineList_plus.status!=3){continue};
  4450. console.log(engineList_plus[i]);
  4451.  
  4452. // 包含网站名称
  4453. var includeWeb = "";
  4454. for(let j=0; j<engineList_plus[i].engineList.length;j++){
  4455. if(j!=0){
  4456. includeWeb += " | " + engineList_plus[i].engineList[j].name;
  4457. } else{
  4458. includeWeb += engineList_plus[i].engineList[j].name;
  4459. }
  4460. }
  4461.  
  4462. a += "<li>"+
  4463. "<span class='xin-importing-item' xin-importing-id='" + i +"' title='"+ (engineList_plus[i].message?engineList_plus[i].message:engineList_plus[i].engineDetails[0]) +"'>"+ (engineList_plus[i].name?engineList_plus[i].name:engineList_plus[i].engineDetails[0]) + " : </span>" +
  4464. "<p title='"+ includeWeb +"'>"+ includeWeb +"</p>"
  4465. "</li>";
  4466. }
  4467.  
  4468. a += "</ul>";
  4469.  
  4470. newDiv.innerHTML=a;
  4471.  
  4472. this.ele.appendChild(newDiv);
  4473. },
  4474. addImportingEnger:function(e){
  4475. // console.log(e);
  4476. // console.log("第几个: ",e.target.getAttribute("xin-importing-id"));
  4477. var engineListID = e.target.getAttribute("xin-importing-id");
  4478. var engineList_temp = engineList_plus[engineListID];
  4479. var elist = engineList_temp.engineList;
  4480.  
  4481. var name = engineList_temp.engineDetails[0];
  4482. var innerName = engineList_temp.engineDetails[1];
  4483.  
  4484. var odiv = document.createElement("div");
  4485. odiv.id = innerName;
  4486. odiv.className = "iqxin-items";
  4487. var innerHTML = "" +
  4488. '<div class="sejtitle" data-iqxintitle="' + innerName + '" data-xin="99">' +
  4489. '<span class="iqxin-pointer-events">'+ name +'</span>' +
  4490. '<span class="iqxin-title-edit" title="编辑 Edit">' +
  4491. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4492. '</span> ' +
  4493. '<span class="iqxin-set-title-del iqxin-set-active" title="删除 Delete">' +
  4494. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4495. '</span>' +
  4496. '</div>' +
  4497. '<div class="sejcon">' +
  4498. "";
  4499.  
  4500. // 具体列表
  4501. for(let i=0;i<elist.length;i++){
  4502. var a = '<span draggable="true" class="drag">' +
  4503. '<span class="sej-engine"' +
  4504. ' data-iqxinimg="$img$" ' +
  4505. ' data-iqxintitle="$title$" ' +
  4506. ' data-iqxinlink="$link$" ' +
  4507. ' data-iqxintarget="$blank$" ' +
  4508. '><img src="$favicon$" class="sej-engine-icon" />$name$</span>' +
  4509. '<span class="iqxin-set-edit" title="编辑 Edit">' +
  4510. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4511. '</span> ' +
  4512. '<span class="iqxin-set-del iqxin-set-active" title="删除 Delete">' +
  4513. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4514. '</span>' +
  4515. '</span>';
  4516.  
  4517. a = a.replace("$img$", elist[i].favicon)
  4518. .replace("$title$", elist[i].name)
  4519. .replace("$link$", elist[i].url);
  4520.  
  4521. if (elist[i].blank){
  4522. a = a.replace('$blank$', "_blank");
  4523. } else {
  4524. a = a.replace('data-iqxintarget="$blank$"', '');
  4525. };
  4526.  
  4527. a = a.replace('$name$', elist[i].name)
  4528. .replace('$favicon$', elist[i].favicon);
  4529.  
  4530. innerHTML += a;
  4531. }
  4532.  
  4533. innerHTML += "" +
  4534. '<span class="iqxin-additem iqxin-set-active">+</span>' +
  4535. '</div>' +
  4536. "";
  4537.  
  4538.  
  4539. odiv.innerHTML = innerHTML;
  4540.  
  4541. this.addItemBoxRemove("#importingBox");
  4542.  
  4543. var btnEle = document.querySelector("#btnEle");
  4544. btnEle.parentNode.insertBefore(odiv,btnEle);
  4545. },
  4546.  
  4547. // “设置按钮” 透明度
  4548. setBtnOpacityFun: function(){
  4549. if(~window.navigator.userAgent.indexOf("Chrome")){
  4550. var odom = document.querySelector("#setBtnOpacityRange");
  4551. var odomV = odom.value;
  4552. // odom.style.backgroundSize = odom.value*100 +"% 100%";
  4553. console.log(odomV,getSettingData.setBtnOpacity);
  4554. if(getSettingData.setBtnOpacity<0){
  4555. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = odomV.toString().padEnd(4,"0");
  4556. odom.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff";
  4557. }else{
  4558. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = "禁用";
  4559. odom.style.background = "-webkit-linear-gradient(left,#bdbdbd,#c6c7c7) no-repeat, #fff";
  4560. }
  4561. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4562.  
  4563. getSettingData.setBtnOpacity = -getSettingData.setBtnOpacity;
  4564. } else {
  4565. // console.log("非chrome");
  4566. iqxinShowTip("抱歉,目前只支持chrome类浏览器",2500);
  4567. }
  4568. },
  4569.  
  4570. // 标题点击 (开关搜索列表)(可以并入到下面的点击事件)
  4571. titleClick: function(e){
  4572. var target = e.target;
  4573. target.dataset.xin = -parseInt(target.dataset.xin);
  4574. target.dataset.xin>0 ? iqxinShowTip("启用") : iqxinShowTip("禁用");
  4575. },
  4576. // 点击事件 此处的 if 需要根据实际情况替换成 elseif (switch)
  4577. domClick: function(e){
  4578. var targetClass = e.target.className;
  4579. var targetid = e.target.id;
  4580. debug("点击事件:%o, ID: %o, class: %o, e: %o",e.target,targetid,targetClass,e)
  4581.  
  4582. // 删除搜索
  4583. if(~e.target.className.indexOf("iqxin-set-del")){
  4584. // console.log(e.target);
  4585. e.target.parentNode.parentNode.removeChild(e.target.parentNode);
  4586. };
  4587. // 删除搜索列表
  4588. if(~e.target.className.indexOf("iqxin-set-title-del")){
  4589. // console.log(e.target, e.target.parentNode.parentNode);
  4590. e.target.parentNode.parentNode.parentNode.removeChild(e.target.parentNode.parentNode);
  4591. };
  4592.  
  4593. if(~e.target.className.indexOf("iqxin-additem")){
  4594. this.parentNode = e.target.parentNode;
  4595. this.addItemBox();
  4596. };
  4597. if(e.target.className==="sej-engine"){
  4598. e.target.dataset.iqxindisabled = e.target.dataset.iqxindisabled ? "": "true";
  4599. e.target.dataset.iqxindisabled ? iqxinShowTip("禁用") : iqxinShowTip("启用");
  4600. };
  4601. if(~targetClass.indexOf("addItemBoxCancel")){
  4602. this.addItemBoxRemove();
  4603. };
  4604. // 添加新的搜索 确定
  4605. if(~targetClass.indexOf("addItemBoxEnter")){
  4606. this.addItemEnger();
  4607. };
  4608. // 添加新的搜索列表 确定
  4609. if(targetid === "nSearchList"){
  4610. debug("添加新的搜索列表");
  4611. this.addSearchListBox();
  4612. };
  4613. if(targetid === "addSearchListBoxEnter"){
  4614. debug("向网页添加元素");
  4615. this.addSearchListEnger();
  4616. };
  4617. if(targetid === "addSearchListBoxCancel"){
  4618. debug("移除盒子");
  4619. // this.boxClose("#newSearchListBox");
  4620. this.addItemBoxRemove("#newSearchListBox");
  4621. };
  4622.  
  4623. // 修改搜索 确定
  4624. if(~targetClass.indexOf("editItemBoxEnter")){
  4625. this.addEditBoxEnger();
  4626. };
  4627.  
  4628. // 编辑框
  4629. if(~e.target.className.indexOf("iqxin-set-edit")){
  4630. this.addEditBox(e);
  4631. }
  4632. // 标题编辑框
  4633. if(~targetClass.indexOf("iqxin-title-edit")){
  4634. e.stopPropagation();
  4635. this.addTitleEditBox(e);
  4636. }
  4637. if(~targetClass.indexOf("sejtitle")){
  4638. this.titleClick(e);
  4639. }
  4640. // codebox 源代码编辑框
  4641. if(targetid ==="codeboxclose"){
  4642. this.editCodeBoxClose();
  4643. } else if(targetid==="xin-reset"){
  4644. this.reset();
  4645. } else if( targetid === "xin-codeboxsave"){
  4646. this.editCodeBoxSave();
  4647. } else if( targetid === "xin-copyCode"){
  4648. GM_setClipboard(JSON.stringify(getSettingData,false,4));
  4649. iqxinShowTip("复制成功");
  4650. }
  4651.  
  4652. // 点击更多菜单
  4653. if(targetid ==="moreSet"){
  4654. document.querySelector("#btnEle2").classList.toggle("btnEle2active");
  4655. // iqxin-btn-active
  4656. e.target.classList.toggle("iqxin-btn-active");
  4657. }
  4658.  
  4659. // 点击导入菜单
  4660. if(targetid ==="xin-importing"){
  4661. this.addImportingBox();
  4662. }
  4663. if(targetClass ==="xin-importing-item"){
  4664. this.addImportingEnger(e);
  4665. }
  4666.  
  4667. // 关闭"设置菜单按钮"
  4668. if(targetClass === "iqxin-setBtnOpacityRangeValue"){
  4669. this.setBtnOpacityFun();
  4670. }
  4671.  
  4672. // 关闭设置菜单
  4673. if (targetid === "xin-close"){
  4674. this.hide();
  4675. }
  4676.  
  4677. // 空白地方点击
  4678. if(~targetClass.indexOf("iqxin-items") || targetid === "settingLayer" || targetClass==="btnEleLayer"){
  4679. this.allBoxClose();
  4680. }
  4681. },
  4682.  
  4683. // 关闭所有次级窗口、菜单
  4684. allBoxClose: function(){
  4685. this.addItemBoxRemove(); // 新的搜索添加框
  4686. this.addDelremove(); // 增加/删除界面
  4687. this.editCodeBoxClose(); // code编辑框
  4688. this.addTitleEditBoxRemove(); //标题编辑框
  4689. this.addItemBoxRemove("#newSearchListBox"); // 添加新的搜索列表
  4690. this.boxClose("#iqxin-sortBox"); // 搜索列表排序
  4691. this.addItemBoxRemove("#importingBox"); //导入框
  4692. document.querySelector("#btnEle2").classList.remove("btnEle2active"); // 更多设置
  4693. },
  4694.  
  4695. // 窗口位置拖动
  4696. setDragNode: function(ele) {
  4697. var node = document.querySelector("#dragDom");
  4698.  
  4699. node.addEventListener("mousedown",function(event){
  4700. ele.style.transition = "null";
  4701. // offsetLeft 距离 body 的位置, 得到的 dis 即鼠标到窗口左上角的位置
  4702. var disX = event.clientX - ele.offsetLeft;
  4703. var disY = event.clientY - ele.offsetTop;
  4704.  
  4705. var move = function(event) {
  4706. //鼠标的位置减去到左上角的位置 即窗口的位置
  4707. // console.log(event.clientX - disX,event.clientY - disY)
  4708. ele.style.left = event.clientX - disX + "px";
  4709. ele.style.top = event.clientY - disY + "px";
  4710. };
  4711.  
  4712. document.addEventListener("mousemove",move);
  4713. document.addEventListener("mouseup",function(){
  4714. ele.style.transition = "0.5s";
  4715. document.removeEventListener("mousemove",move);
  4716. })
  4717. });
  4718. },
  4719.  
  4720. // 拖动
  4721. domdragstart:function (e) {
  4722. if(~this.className.indexOf("sejtitle")){
  4723. dragEl = this.parentNode;
  4724. } else{
  4725. dragEl = this;
  4726. }
  4727. dragData = dragEl.innerHTML;
  4728. e.dataTransfer.effectAllowed = "move";
  4729. e.dataTransfer.setData("text/html",dragEl.innerHTML);
  4730. },
  4731. domdragenter:function (e) {
  4732. var target = e.target;
  4733. var targetClass = target.className;
  4734. if(~targetClass.indexOf("sejtitle")){
  4735. target = target.parentNode;
  4736. }
  4737. target.classList.add('drop-over');
  4738. },
  4739. domdragover:function (e) {
  4740. if (e.preventDefault) {
  4741. e.preventDefault();
  4742. }
  4743. e.dataTransfer.dropEffect = 'move';
  4744. return false;
  4745. },
  4746. domdragleave:function (e) {
  4747. var target = e.target;
  4748. var targetClass = target.className;
  4749. if(~targetClass.indexOf("sejtitle")){
  4750. target = target.parentNode;
  4751. }
  4752. target.classList.remove('drop-over');
  4753. },
  4754. domdrop:function (e) {
  4755. debug("拖拽结束")
  4756. // e.target === this
  4757. var _this = e.target;
  4758. var that = _this.parentNode;
  4759. var pparentNode = that.parentNode;
  4760.  
  4761. // 防止跨区域移动
  4762. SEJsetting.prototype.domdropend();
  4763. if(dragEl.className != that.className){
  4764. console.log("移动对象 之前,现在: ", dragEl.className);
  4765. console.log(that.className);
  4766. return;
  4767. }
  4768.  
  4769. // Sortable.js https://github.com/RubaXa/Sortable
  4770. var targetRect = _this.getBoundingClientRect(); //
  4771. var width = targetRect.right - targetRect.left; //目标节点的宽
  4772. var height = targetRect.bottom - targetRect.top; //目标节点的高
  4773. var domPosition = null;
  4774. if(~_this.className.indexOf("sejtitle")){
  4775. debug(e.clientX,targetRect.left,height,e.clientX - targetRect.left,(e.clientX - targetRect.left) / height)
  4776. if((e.clientX - targetRect.left) / width > 0.5){
  4777. debug("右");
  4778. domPosition = true;
  4779. }else{
  4780. debug("左");
  4781. domPosition = false;
  4782. }
  4783. } else {
  4784. if((e.clientY - targetRect.top) / height > 0.5){
  4785. debug("下");
  4786. domPosition = true;
  4787. }else{
  4788. debug("上");
  4789. domPosition = false;
  4790. }
  4791. }
  4792.  
  4793. dragEl.style.transformOrigin = "top center";
  4794. dragEl.style.animation = "sejopen 0.3s";
  4795.  
  4796. if(domPosition){
  4797. if(pparentNode.lastChild == that){
  4798. pparentNode.insertBefore(dragEl,that);
  4799. }else{
  4800. pparentNode.insertBefore(dragEl,that.nextElementSibling)
  4801. }
  4802. }else{
  4803. that.parentNode.insertBefore(dragEl,that);
  4804. }
  4805.  
  4806. // 重新绑定拖拽事件
  4807. SEJsetting.prototype.dragEvent();
  4808. return false;
  4809. },
  4810. domdropend:function(){
  4811. var dom = document.querySelector(".drop-over");
  4812. if(dom){
  4813. dom.classList.remove("drop-over")
  4814. }
  4815. },
  4816.  
  4817. // 判断是否能连接至google
  4818. isOnline: function(){
  4819. console.log("this.online",this.online);
  4820. if(this.online)return;
  4821.  
  4822. var that = this;
  4823. var myImage = new Image;
  4824. myImage.src = 'https://www.google.com/s2/favicons?domain=www.baidu.com&' + Math.random() ;
  4825. setTimeout(function(){
  4826. // console.log("取消加载");
  4827. console.log(myImage.width);
  4828. if(myImage.width){
  4829. that.online = true;
  4830. }else{
  4831. myImage.src = undefined;
  4832. };
  4833. },2000);
  4834. },
  4835.  
  4836. // 重新加载工具
  4837. reloadSet: function(){
  4838. var elems = document.querySelectorAll('#sej-container, #settingLayerMask, sejspan.sej-drop-list');
  4839. if (!elems) return;
  4840. console.log("elems: " + elems);
  4841. // return;
  4842.  
  4843. [].forEach.call(elems, function(elem) {
  4844. elem.parentNode.removeChild(elem);
  4845. });
  4846.  
  4847. iqxinstart();
  4848. iqxinShowTip("保存成功");
  4849. },
  4850.  
  4851. // 设置按钮透明度设置
  4852. rangeChange: function(bool){
  4853. var odom = document.querySelector("#setBtnOpacityRange");
  4854. if(getSettingData.setBtnOpacity<0){
  4855. odom.style.background = "-webkit-linear-gradient(left,#bdbdbd,#c6c7c7) no-repeat, #fff";
  4856. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4857. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = "禁用";
  4858. getSettingData.setBtnOpacity = -odom.value;
  4859. } else{
  4860. odom.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff";
  4861. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4862. let value = odom.value;
  4863. let valueStr = "";
  4864. if(value==0){
  4865. valueStr = "0.00";
  4866. }else if(value==1){
  4867. valueStr = "1.00";
  4868. } else {
  4869. valueStr = odom.value.toString().padEnd(4,"0");
  4870. }
  4871. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = valueStr;
  4872. getSettingData.setBtnOpacity = odom.value;
  4873. }
  4874. },
  4875.  
  4876. // 窗口大小改变
  4877. windowResize: function(){
  4878. var eleStyle = window.getComputedStyle(this.ele , null);
  4879. var w = parseInt(eleStyle.width) ;
  4880. var h = parseInt(eleStyle.height) + 54;
  4881. var ww = document.documentElement.clientWidth;
  4882. var wh = document.documentElement.clientHeight;
  4883. var maskStyle = this.mask.style;
  4884.  
  4885. if(w>=ww){
  4886. maskStyle.justifyContent = "stretch";
  4887. }else{
  4888. maskStyle.justifyContent = "center";
  4889. }
  4890. if(h>=wh){
  4891. maskStyle.alignItems = "stretch";
  4892. }else{
  4893. maskStyle.alignItems = "center";
  4894. }
  4895. },
  4896. saveData: function(){
  4897. //
  4898. this.addTitleEditBoxRemove(); //标题栏处于编辑状态
  4899.  
  4900. var obj = {};
  4901. var parentdiv = document.querySelectorAll("#settingLayer .iqxin-items");
  4902. for (let i=0;i<parentdiv.length;i++){
  4903. var data = parentdiv[i].querySelectorAll(".sej-engine");
  4904. var id = parentdiv[i].id;
  4905. obj[id]=[];
  4906. for(let ii=0;ii<data.length;ii++){
  4907. if (data[ii].dataset.xin<0){
  4908. var ij = -ii;
  4909. } else {
  4910. ij = ii;
  4911. }
  4912. obj[id][ij]={};
  4913. obj[id][ij].favicon=data[ii].dataset.iqxinimg;
  4914. obj[id][ij].name=data[ii].dataset.iqxintitle;
  4915. obj[id][ij].url=data[ii].dataset.iqxinlink;
  4916. if(data[ii].dataset.iqxintarget){
  4917. obj[id][ij].blank=data[ii].dataset.iqxintarget;
  4918. };
  4919. if(data[ii].dataset.iqxindisabled){
  4920. obj[id][ij].disable=data[ii].dataset.iqxindisabled;
  4921. };
  4922. if(data[ii].dataset.iqxingbk){
  4923. obj[id][ij].gbk=data[ii].dataset.iqxingbk;
  4924. };
  4925. }
  4926. }
  4927.  
  4928. // 分类名称
  4929. var engineDetails=[];
  4930.  
  4931. // 分类排序
  4932. var odetails = document.querySelectorAll(".sejtitle");
  4933. var odetailsLength = odetails.length;
  4934. for(let i=0;i<odetailsLength;i++){
  4935. debug(odetails[i]);
  4936. engineDetails[i] = [];
  4937. engineDetails[i][0] = odetails[i].firstChild.innerHTML;
  4938. engineDetails[i][1] = odetails[i].dataset.iqxintitle;
  4939. engineDetails[i][2] = odetails[i].dataset.xin>=0?true:false;
  4940. }
  4941.  
  4942. // 新标签页全局设置
  4943. var onewtab = document.querySelector("#iqxin-globalNewtab").selectedIndex;
  4944. var foldlist = document.querySelector("#iqxin-foldlist").checked;
  4945.  
  4946. // 以防不测,重新获取本地配置文件
  4947. var getData = GM_getValue("searchEngineJumpData");
  4948. getData.newtab = onewtab;
  4949. getData.foldlist = foldlist;
  4950. getData.setBtnOpacity = getSettingData.setBtnOpacity;
  4951. // getData.debug = document.querySelector("#iqxin-debug").checked;
  4952. getData.center = document.querySelector("#iqxin-center").selectedIndex;
  4953. getData.fixedTop = document.querySelector("#iqxin-fixedTop").checked;
  4954. getData.allOpen = document.querySelector("#iqxin-allOpen-item").checked;
  4955. getData.fixedTopUpward = document.querySelector("#iqxin-fixedTopUpward-item").checked;
  4956. getData.transtion = document.querySelector("#iqxin-transtion").checked;
  4957. getData.HideTheSameLink = document.querySelector("#iqxin-HideTheSameLink").checked;
  4958. getData.selectSearch = document.querySelector("#iqxin-selectSearch").checked;
  4959. getData.engineDetails = engineDetails;
  4960. getData.engineList = obj;
  4961.  
  4962. debug('将要保存的数据:',getData);
  4963. GM_setValue("searchEngineJumpData",getData);
  4964. },
  4965. // 此处的样式主要是设置界面
  4966. addGlobalStyle: function(){
  4967. var head, style;
  4968. var css =
  4969. "#settingLayerMask{" +
  4970. "display: none;" +
  4971. "justify-content: center;" +
  4972. "align-items: center;" +
  4973. "position: fixed;" +
  4974. "top:0; right:0; bottom:0; left:0;" +
  4975. "background-color: rgba(0,0,0,.3);" +
  4976. "backdrop-filter: blur(10px);" +
  4977. "z-index: 200000000;" +
  4978. "overflow: auto;" +
  4979. "font-family: arial,sans-serif;" +
  4980. "min-height: 100%;" +
  4981. "font-size:16px;" +
  4982. "transition:0.3s;" +
  4983. "opacity:0;" +
  4984. "user-select: none;" +
  4985. "-moz-user-select: none;" +
  4986. "padding-bottom: 80px;" +
  4987. "box-sizing: border-box;" +
  4988. "color: var(--font-color-qxin);" +
  4989. "}" +
  4990. "#settingLayer{" +
  4991. "display: flex;" +
  4992. "flex-wrap: wrap;" +
  4993. "padding: 20px 20px 50px 20px;" +
  4994. "margin: 2% 25px 50px 5px;" +
  4995. "background-color: var(--background-setting-qxin);" +
  4996. "border-radius: 4px;" +
  4997. "position: absolute;" +
  4998. "min-width: 700px;" +
  4999. "max-width: 94%;" +
  5000. "transition:0.5s;" +
  5001. "}" +
  5002. ".iqxin-items{" +
  5003. "min-width:5em;" +
  5004. "margin: 0 5px 0px;" +
  5005. "}" +
  5006. "#settingLayer .drag{" +
  5007. "display: block;" +
  5008. "position: relative;" +
  5009. "}" +
  5010. "#settingLayer .sej-engine{" +
  5011. "display: inline-block;" +
  5012. "width: 100%;" +
  5013. "box-sizing: border-box;" +
  5014. "}" +
  5015. ".iqxin-pointer-events," +
  5016. ".sej-engine-icon," +
  5017. "#settingLayer .sej-engine *{" +
  5018. "pointer-events:none;" +
  5019. "}" +
  5020. ".sejtitle{" +
  5021. "text-align: center;" +
  5022. "padding: 2px 0;" +
  5023. "cursor: pointer;" +
  5024. "position: relative;" +
  5025. "}" +
  5026. "#settingLayerMask [data-xin]{" +
  5027. "margin:4px 0;" +
  5028. "line-height:1.7;" +
  5029. "border-radius:4px;" +
  5030. "}" +
  5031. "#settingLayerMask .iqxin-set-edit," +
  5032. "#settingLayerMask .iqxin-set-del{" +
  5033. "border-radius:4px;" +
  5034. "line-height: 1em;" +
  5035. "}" +
  5036. ".sejcon [data-xin]{"+
  5037. "cursor: pointer;" +
  5038. "}" +
  5039. "#settingLayerMask [data-iqxindisabled='true']," +
  5040. "[data-xin^='-']{" +
  5041. "background-color: var(--background-avtive-color-qxin);" +
  5042. "text-decoration: line-through;" +
  5043. "text-decoration-color:red;" +
  5044. "border-radius:2px;" +
  5045. "transition:.3s;" +
  5046. "}" +
  5047. ".sejtitle:not([data-xin^='-']):hover{" +
  5048. "background:var(--background-active-enable-qxin);" +
  5049. "}" +
  5050. "#settingLayerMask .sej-engine:hover{" +
  5051. "background-color: var(--background-active-enable-qxin);" +
  5052. "}" +
  5053. "#settingLayerMask [data-iqxindisabled='true']:hover," +
  5054. "[data-xin^='-']:hover{" +
  5055. "background-color: var(--background-active-disable-qxin);" +
  5056. "}" +
  5057. "#settingLayerMask label{" +
  5058. "cursor:pointer;" +
  5059. "}" +
  5060. "#settingLayerMask .sej-engine-icon{" +
  5061. "vertical-align:middle;" +
  5062. "}" +
  5063. "#btnEle2," +
  5064. "#btnEle{" +
  5065. "position:absolute;" +
  5066. "width:100%;" +
  5067. "bottom: 0px;" +
  5068. "right: 0;" +
  5069. "background: var(--background-setting-qxin);" +
  5070. "border-radius: 4px;" +
  5071. "}" +
  5072. "#btnEle2 span," +
  5073. "#btnEle span{" +
  5074. "display: inline-block;" +
  5075. "background: var(--background-btn-qxin);" +
  5076. "border: 1px solid #3abdc1;" +
  5077. "margin: 12px auto 10px;" +
  5078. "color: #3abdc1;" +
  5079. "padding: 5px 10px;" +
  5080. "border-radius: 4px;" +
  5081. "cursor: pointer;" +
  5082. "outline: none;" +
  5083. "transition: 0.3s;" +
  5084. "}" +
  5085. "#btnEle a{" +
  5086. "color: #999;" +
  5087. "text-decoration: none;" +
  5088. "font-family: auto;" +
  5089. "}" +
  5090. "#btnEle a:hover{" +
  5091. "text-decoration: underline;" +
  5092. "color: #ef8957;" +
  5093. "}" +
  5094. "#btnEle2 span.feedback:hover," +
  5095. "#btnEle span.feedback:hover{" +
  5096. "border-color:#ef8957;" +
  5097. "}" +
  5098. "#btnEle2 span:not(.feedback):hover," +
  5099. "#btnEle span:not(.feedback):hover{" +
  5100. "background:#3ACBDD;" +
  5101. "color:#fff;" +
  5102. "}" +
  5103. "#btnEle .feedback{" +
  5104. "border-color: #aaa;" +
  5105. "}" +
  5106. "#btnEle2>div," +
  5107. "#btnEle>div{" +
  5108. "width: 100%;" +
  5109. "display:flex;" +
  5110. "justify-content: space-around;" +
  5111. "background: var(--background-btn-qxin);" +
  5112. "border-radius: 4px;" +
  5113. "}" +
  5114. "#btnEle2{" +
  5115. "visibility:hidden;" +
  5116. "opacity:0;" +
  5117. "transform:translate(0,40px);" +
  5118. "transition : 0.3s;" +
  5119. "}" +
  5120. "#btnEle2.btnEle2active{" +
  5121. "visibility:visible;" +
  5122. "opacity:1;" +
  5123. // "transform:translate(0,108px);" // 两行的情况下
  5124. "transform:translate(0,53px);" +
  5125. "}" +
  5126. "#settingLayerMask input[type=checkbox]{" +
  5127. "width: 12px;" +
  5128. "height: 12px;" +
  5129. "display: inline-block;" +
  5130. "text-align: center;" +
  5131. "vertical-align: middle;" +
  5132. "line-height: 10px!important;" +
  5133. "margin: 0 5px 5px 5px!important;" +
  5134. "position: relative;" +
  5135. "}" +
  5136. "#settingLayerMask input[type=checkbox]:before{" +
  5137. "content: '';" +
  5138. "position: absolute;" +
  5139. "top: 0;" +
  5140. "left: 0;" +
  5141. "background: #fff;" +
  5142. "width: 100%;" +
  5143. "height: 100%;" +
  5144. "border: 1px solid #d9d9d9;" +
  5145. "}" +
  5146. "#settingLayerMask input[type=checkbox]:checked:after{" +
  5147. 'content: "✔";' +
  5148. "background-color: #63d4d8;" +
  5149. "position: absolute;" +
  5150. "top: 0;" +
  5151. "left: 0;" +
  5152. "width: 12px;" +
  5153. "height: 12px;" +
  5154. "border: 1px solid #63d4d8;" +
  5155. "color: #fff;" +
  5156. "font-size: 10px;" +
  5157. "}" +
  5158. ".drop-over{" +
  5159. "opacity: 0.6;" +
  5160. "}" +
  5161. ".iqxin-title-edit," +
  5162. ".iqxin-set-edit," +
  5163. ".iqxin-set-title-del," +
  5164. ".iqxin-set-del {" +
  5165. "visibility: hidden;" +
  5166. "opacity:0;" +
  5167. "position: absolute;" +
  5168. "background: rgba(207, 249, 255, 0.86);" +
  5169. "color: red;" +
  5170. "top: 50%;" +
  5171. "transform: translate(0,-50%);" +
  5172. "right: 0;" +
  5173. "padding: 3px 3px 6px 6px;" +
  5174. "border-radius: 2px;" +
  5175. "cursor: pointer;" +
  5176. "transition: .3s;" +
  5177. "}" +
  5178. ".iqxin-set-title-del.iqxin-set-active {" +
  5179. "background: #fff;" +
  5180. "border-radius: 50% 0 0 50%;" +
  5181. "}" +
  5182. ".iqxin-title-edit{" +
  5183. "padding: 0px 3px 6px 6px;" +
  5184. "}" +
  5185. "span.iqxin-additem {" +
  5186. "display: inline-block;" +
  5187. "text-align: center;" +
  5188. "width: 100%;" +
  5189. "margin: 10px 0;" +
  5190. "border: 1px dotted red;" +
  5191. "color: red;" +
  5192. "cursor: pointer;" +
  5193. "visibility:hidden;" +
  5194. "opacity:0;" +
  5195. "transition:0.3s;" +
  5196. "transform:scale(0);" +
  5197. "}" +
  5198. "span.iqxin-additem.iqxin-set-active {" +
  5199. "visibility:visible;" +
  5200. "opacity:1;" +
  5201. "margin:10px 0;" +
  5202. "transform:scale(1);" +
  5203. "}" +
  5204. "#settingLayer .sejtitle:hover .iqxin-title-edit," +
  5205. "#settingLayer .sejcon>span:hover .iqxin-set-edit{" +
  5206. "visibility:visible;" +
  5207. "opacity:0.8;" +
  5208. "}" +
  5209. "#nSearchList.iqxin-set-active," +
  5210. ".iqxin-set-edit.iqxin-set-active," +
  5211. ".iqxin-set-title-del.iqxin-set-active," +
  5212. ".iqxin-set-del.iqxin-set-active {" +
  5213. "visibility:visible !important;" +
  5214. "opacity:1 !important;" +
  5215. "}" +
  5216. "#btnEle span.iqxin-btn-active{" +
  5217. "color:red;" +
  5218. "border-color:red;" +
  5219. "}" +
  5220. "#newSearchListBox," +
  5221. "#newSearchBox{" +
  5222. "transition:0.3s;" +
  5223. "transform : translateY(0%);" +
  5224. "opacity: 1;" +
  5225. "position:fixed;" +
  5226. "z-index:200000100;" +
  5227. "top:50%;" +
  5228. "left:50%;" +
  5229. "padding:22px;" +
  5230. "background:rgb(29, 29, 29);" +
  5231. "border-radius:4px;" +
  5232. "color: #e8e8e8;" +
  5233. "margin: -149px -117px;" +
  5234. "}" +
  5235. "#newSearchListBox input," +
  5236. "#newSearchBox input{" +
  5237. "border: none;" +
  5238. "padding: 4px 0 4px 5px;" +
  5239. "border-radius: 4px;" +
  5240. "outline: none;" +
  5241. "}" +
  5242. "#newSearchListBox input:focus," +
  5243. "#newSearchBox input:focus {" +
  5244. "background: #f1d2d2;" +
  5245. "transition: 0.5s;" +
  5246. "}" +
  5247. ".addItemBoxBtn{" +
  5248. "cursor: pointer;" +
  5249. "background: #fff;" +
  5250. "border: none;" +
  5251. "border-radius: 4px;" +
  5252. "padding: 4px 10px;" +
  5253. "color: #333;" +
  5254. "transition:0.3s;" +
  5255. "}" +
  5256. "#xin-centerDisplay select," +
  5257. "#xin-newtab select{" +
  5258. "height:auto;" +
  5259. "border: none;" +
  5260. "outline: none;" +
  5261. "color: #3ABDC1;" +
  5262. "font-size: 1em;" +
  5263. "font-family: arial,sans-serif;" +
  5264. "appearance: none;" +
  5265. "-moz-appearance: none;" +
  5266. "-webkit-appearance: none;" +
  5267. "padding: 0px 5px;" +
  5268. "cursor: pointer;" +
  5269. "text-decoration: underline;" +
  5270. "background: var(--background-btn-qxin);" +
  5271. "}" +
  5272. "#titleEdit{" +
  5273. "width:6em;" +
  5274. "}" +
  5275. // 按钮效果 : 确定 取消按钮
  5276. ".iqxin-closeBtn," +
  5277. ".iqxin-enterBtn{" +
  5278. "box-sizing: border-box;" +
  5279. "}" +
  5280. ".iqxin-closeBtn:hover{" +
  5281. "background: #ff6565;" +
  5282. "border-color: #ff6565;" +
  5283. "color: #fff;" +
  5284. "}" +
  5285. ".iqxin-enterBtn:hover{" +
  5286. "background: #84bb84;" +
  5287. "border-color: #84bb84;" +
  5288. "color: #fff;" +
  5289. "}" +
  5290. "#iqxin-editCodeBox button{" +
  5291. "cursor:pointer;" +
  5292. "}" +
  5293.  
  5294. // 关闭按钮
  5295. "#xin-close{" +
  5296. "background:white;" +
  5297. "color:#3ABDC1;" +
  5298. "line-height:20px;" +
  5299. "text-align:center;" +
  5300. "height:20px;" +
  5301. "width:20px;" +
  5302. "text-align:center;" +
  5303. "font-size:20px;" +
  5304. "padding:10px;" +
  5305. "border: 3px solid #3ABDC1;" +
  5306. "border-radius: 50%;" +
  5307. "transition: .5s;" +
  5308. "top: -20px;" +
  5309. "right:-20px;" +
  5310. "position: absolute;" +
  5311. "box-sizing: unset;" +
  5312. "}" +
  5313. "#xin-close::before{" +
  5314. "content:'\\2716';" +
  5315. "margin:-10px;" +
  5316. "}" +
  5317. "#xin-close:hover{" +
  5318. "background: indianred;" +
  5319. "border-color: indianred;" +
  5320. "color: #fff;" +
  5321. "}" +
  5322. // type[range] 效果
  5323. "input[type=range] {" +
  5324. "outline: none;" +
  5325. "-webkit-appearance: none;" +
  5326. "background:-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff;" +
  5327. "border-radius: 10px; /*这个属性设置使填充进度条时的图形为圆角*/" +
  5328. "}" +
  5329. "input[type=range]::-webkit-slider-thumb {" +
  5330. "-webkit-appearance: none;" +
  5331. "} " +
  5332. "input[type=range]::-webkit-slider-runnable-track {" +
  5333. "height: 10px;" +
  5334. "border-radius: 10px; /*将轨道设为圆角的*/" +
  5335. "box-shadow: 0 1px 1px #def3f8, inset 0 .125em .125em #0d1112; /*轨道内置阴影效果*/" +
  5336. "}" +
  5337. "input[type=range]::-webkit-slider-thumb {" +
  5338. "-webkit-appearance: none;" +
  5339. "height: 18px;" +
  5340. "width: 18px;" +
  5341. "margin-top: -5px; /*使滑块超出轨道部分的偏移量相等*/" +
  5342. "background: #fff; " +
  5343. "border-radius: 50%; /*外观设置为圆形*/" +
  5344. "border: solid 0.125em rgba(205, 224, 230, 0.5); /*设置边框*/" +
  5345. "box-shadow: 0 .125em .125em #3b4547; /*添加底部阴影*/" +
  5346. "}" +
  5347. // 导入
  5348. "#importingBox{" +
  5349. "position:fixed;" +
  5350. "width:350px;" +
  5351. "top:50%;" +
  5352. "left:50%;" +
  5353. "transform:translate(-50%,-50%);" +
  5354. "padding: 15px 30px;" +
  5355. "border-radius: 4px;" +
  5356. "background:#1D1D1D;" +
  5357. "color:#fff;" +
  5358. "}" +
  5359. "#importingBox li{" +
  5360. "margin:5px;" +
  5361. "border-bottom:1px solid #3ACBDD;" +
  5362. "}" +
  5363. "#importingBox li p{" +
  5364. "white-space: nowrap;" +
  5365. "overflow: hidden;" +
  5366. "text-overflow: ellipsis;" +
  5367. "margin-top:0;" +
  5368. "margin-bottom:0;" +
  5369. "}" +
  5370. ".xin-importing-item{" +
  5371. "cursor:pointer;" +
  5372. "}" +
  5373. "";
  5374. head = document.getElementsByTagName('head')[0];
  5375. style = document.createElement('style');
  5376. style.type = 'text/css';
  5377. style.innerHTML = css;
  5378. head.appendChild(style);
  5379. // 关闭设置菜单中的所有动画效果
  5380. if(!getSettingData.transtion){
  5381. GM_addStyle("#settingLayer," +
  5382. "#btnEle span," +
  5383. "#btnEle2," +
  5384. ".iqxin-set-del," +
  5385. "span.iqxin-additem," +
  5386. "#newSearchBox," +
  5387. ".addItemBoxBtn," +
  5388. "#xin-close," +
  5389. "#settingLayerMask{" +
  5390. "transition:none;"+
  5391. "}"+
  5392. "#settingLayerMask{" +
  5393. "backdrop-filter:none;" +
  5394. // "background-color: rgba(0,0,0,.7);" +
  5395. "}"+
  5396. "");
  5397. }
  5398. }
  5399. };
  5400.  
  5401. // 增加设置按钮
  5402. if (getSettingData.setBtnOpacity>=0){
  5403. var setBtn = document.createElement("span");
  5404. setBtn.id = "setBtn";
  5405. GM_addStyle("#setBtn{" +
  5406. "opacity:"+getSettingData.setBtnOpacity+";"+
  5407. "transition:0.5s;"+
  5408. "}"+
  5409. "span#setBtn:hover{" +
  5410. "opacity:1;" +
  5411. "}" +
  5412. "");
  5413. setBtn.innerHTML = `<img style='margin:0 0 -3px 6px;width:16px;vertical-align: baseline;display:inline-block;cursor:pointer;' src="data:image/svg+xml,%3Csvg t='1666950165377' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='11048' width='32' height='32'%3E%3Cpath d='M337.333 517.667c77.406 0 141.974 54.967 156.8 127.998l440.534 0.002c17.673 0 32 14.327 32 32 0 17.496-14.042 31.713-31.471 31.995l-0.53 0.005-440.534 0.001C479.307 782.7 414.74 837.667 337.333 837.667S195.36 782.699 180.534 709.668l-99.2-0.001c-17.674 0-32-14.327-32-32 0-17.497 14.041-31.713 31.47-31.996l0.53-0.004 99.2-0.002c14.825-73.03 79.393-127.998 156.8-127.998z m0 64c-53.019 0-96 42.98-96 96 0 53.019 42.981 96 96 96 53.02 0 96-42.981 96-96 0-53.02-42.98-96-96-96z m341.334-405.334c77.406 0 141.974 54.968 156.799 127.999l99.2 0.001c17.674 0 32 14.327 32 32 0 17.497-14.041 31.713-31.47 31.996l-0.53 0.004-99.2 0.003c-14.826 73.03-79.394 127.997-156.8 127.997-77.405 0-141.973-54.967-156.798-127.997l-440.535-0.003c-17.673 0-32-14.327-32-32 0-17.496 14.042-31.713 31.471-31.995l0.53-0.005 440.534-0.001c14.825-73.031 79.393-127.999 156.799-127.999z m0 64c-53.02 0-96 42.981-96 96 0 53.02 42.98 96 96 96 53.019 0 96-42.98 96-96 0-53.019-42.981-96-96-96z' p-id='11049'%3E%3C/path%3E%3C/svg%3E">`
  5414. document.querySelector("#sej-container").appendChild(setBtn);
  5415. var sejSet = null;
  5416.  
  5417. setBtn.addEventListener("click",setBtnStart);
  5418. };
  5419.  
  5420. // 注册(不可用)菜单
  5421. GM_registerMenuCommand("search jump 搜索跳转设置",setBtnStart);
  5422.  
  5423. function setBtnStart(){
  5424. if(!document.querySelector("#settingLayerMask")){
  5425. sejSet = new SEJsetting();
  5426.  
  5427. var sej_save = document.querySelector("#xin-save");
  5428. // var sej_close = document.querySelector("#xin-close");
  5429. // var sej_reset = document.querySelector("#xin-reset");
  5430. var sej_addDel = document.querySelector("#xin-addDel");
  5431. var sej_edit = document.querySelector("#xin-modification");
  5432.  
  5433. // sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.hide();if(!getSettingData.debug)window.location.reload();});
  5434. sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.hide();sejSet.reloadSet();});
  5435. // sej_close.addEventListener("click",function(){sejSet.hide();});
  5436. // sej_reset.addEventListener("click",function(){sejSet.reset();sejSet.hide();window.location.reload();});
  5437. sej_addDel.addEventListener("click",function(e){sejSet.addDel(e);});
  5438. // sej_edit.addEventListener("click",function(e){sejSet.addEdit(e);});
  5439. sej_edit.addEventListener("click",function(){sejSet.editCodeBox();});
  5440.  
  5441. window.addEventListener("resize",sejSet.windowResize.bind(sejSet));
  5442. }
  5443. sejSet.show();
  5444. }
  5445.  
  5446. // 获取存储的数据信息
  5447. function get_data(){
  5448. setData = GM_getValue("searchEngineJumpData");
  5449. }
  5450. var setData = null;
  5451. // get_data();
  5452. }
  5453.  
  5454. // 消息提示框
  5455. // 目前只是为了给用户一个反馈。 - 成功了么 - 嗯,成功了
  5456. var iqxinTimerGlobalTip = null
  5457. function iqxinShowTip(text,duration){
  5458. console.log("iqxin -- 消息提示框: ", text);
  5459. var odom = document.querySelector("#iqixn-global-tip");
  5460. if(!odom){
  5461. odom = document.createElement("iqxinDiv");
  5462. odom.id = "iqixn-global-tip";
  5463. odom.style.cssText = "" +
  5464. "opacity: 0;" +
  5465. "height: 25px;" +
  5466. "line-height: 25px;" +
  5467. "letter-spacing: 1px;" +
  5468. "font-size: 1em;" +
  5469. "color: #fff;" +
  5470. "padding: 5px 20px;" +
  5471. "border-radius: 5px;" +
  5472. "background-color: #666;" +
  5473. "position: fixed;" +
  5474. "z-index: 200000001;" +
  5475. "left: 50%;" +
  5476. "bottom: 5%;" +
  5477. "transform: translate(-50%);" +
  5478. "transition: .4s;" ;
  5479. document.body.appendChild(odom);
  5480. }
  5481.  
  5482. odom.innerHTML=text;
  5483. odom.style.opacity=1;
  5484.  
  5485. duration = duration?duration:1500;
  5486. //防止持续时间内多次触发提示
  5487. if(!iqxinTimerGlobalTip){
  5488. iqxinTimerGlobalTip = setTimeout(function(){
  5489. odom.style.opacity=0;
  5490. iqxinTimerGlobalTip = null;
  5491. },duration);
  5492. }
  5493. }
  5494.  
  5495. // 从此处开始执行
  5496. var debug;
  5497. function reloadDebug(bool) {
  5498. debug = bool ? console.info.bind(console) : function() {};
  5499. }
  5500.  
  5501. if (window.self != window.top) return;
  5502.  
  5503. var url = window.location.href;
  5504. // var hashList = [
  5505. // /^https?:\/\/www\.baidu\.com\/$/i,
  5506. // /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/$/i,
  5507. // /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^#]*#(?:&?q=|.+?&q=).+/,
  5508. // // /^https?:\/\/searx\.me\//i,
  5509. // ];
  5510. // 部分网站或内因或外因的原因加载缓慢,所以推迟插入
  5511. var delayList = [
  5512. /^https?:\/\/google\.infinitynewtab\.com\/\?q/,
  5513. /^https?:\/\/www\.zhihu\.com\/search\?/,
  5514. /^https?:\/\/www\.iciba\.com\/word\?/,
  5515. /^https?:\/\/neeva\.com\/search\?/i,
  5516. /^https?:\/\/s\.taobao\.com\/search/,
  5517. ]
  5518.  
  5519. // var hashListTag = hashList.some(function hashUrl(element, index, array){
  5520. // return ~url.search(element);
  5521. // });
  5522. var delayListTag = delayList.some(function hashUrl(element, index, array){
  5523. return ~url.search(element);
  5524. });
  5525.  
  5526. // if (hashListTag){
  5527. // var oldTitle = document.title;
  5528. // var newTitle = "";
  5529. // var timer = setInterval(function(){
  5530. // // console.log("循环中",newTitle,oldTitle);
  5531. // newTitle = document.title;
  5532. // if (document.querySelector("#appbar") && !document.querySelector("sejspan")){
  5533. // // console.log("new");
  5534. // iqxinstart();
  5535. // } else if (document.querySelector("sejspan")){
  5536. // // console.log("已存在");
  5537. // clearInterval(timer);
  5538. // }else if (oldTitle!=newTitle){
  5539. // // console.log("不存在开始插入");
  5540. // iqxinstart();
  5541. // }
  5542. // },1000)
  5543. // } else
  5544. if (delayListTag){
  5545. setTimeout(function(){
  5546. // console.log("延时运行");
  5547. var sejSpan = document.querySelector('sejspan');
  5548. if(sejSpan){
  5549. return;
  5550. } else{
  5551. iqxinstart();
  5552. }
  5553. },2000);
  5554. } else {
  5555. // console.log("普通插入");
  5556. iqxinstart();
  5557. }
  5558. if (true) {
  5559. // console.log('iqxin添加标题节点监视器: title');
  5560. // 延时添加标题监视器, 应对 youtube
  5561. setTimeout(function(){
  5562. var watch = document.querySelector('title');
  5563. // console.log("titile: ",watch);
  5564. // console.log("titile: ",document.title);
  5565. new (window.MutationObserver || window.WebKitMutationObserver)(function(mutations){
  5566. console.log('iqxin标题发生了变化', document.title);
  5567. var sejSpan = document.querySelector('sejspan')
  5568. if(!sejSpan){
  5569. iqxinstart();
  5570. }else{
  5571. sejSpan.parentNode.removeChild (sejSpan);
  5572. iqxinstart();
  5573. }
  5574. }).observe(watch, {childList: true, subtree: true, characterData: true});
  5575. },1000)
  5576. }
  5577. })();
  5578.  

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址