一些实用的学生向脚本(补)

重定向优化百度搜狗谷歌必应搜

// ==UserScript==
// @name            AC-baidu:重定向优化百度搜狗谷歌必应搜索_favicon_双列
// @name:en         AC-baidu:google_sogou_bing_RedirectRemove_favicon_adaway_TwoLine
// @name:zh         AC-baidu:重定向优化百度搜狗谷歌必应搜索_favicon_双列
// @name:zh-CN      AC-baidu:重定向优化百度搜狗谷歌必应搜索_favicon_双列
// @name:ja         AC-baidu:重定向最適化Baiduの搜狗のGoogleのBing検索結果のリダイレクト除去+favicon
// @description     1.繞過百度、搜狗、谷歌、好搜搜索結果中的自己的跳轉鏈接,直接訪問原始網頁-反正都能看懂 2.新增自定义网站拦截功能 3添加Favicon显示 4.页面CSS 5.添加计数 6.开关选择以上功能 7.自动翻页功能
// @description:en  1.bypass the redirect link at baidu\sogou\google\haosou; 2.remove ads at baidu; 3.add Favicon for each website; 4.render your own style; 5.counter; 6.Switch to handle all 7.Auto Pager
// @description:ja  1.迂回Baidu、Sogou、Google、Haosou検索検索結果の中の自分の遷移リンク; 2.Baiduの余分な広告を取り除く; 3.コメントを追加; 4.ページのカスタムCSP; 5.カウントを追加; 6.スイッチは以上の機能を選択します; 7.自動ページめくり.
// @icon            https://img.tujidu.com/image/5e7ba0d6b0062.jpg
// @author          AC
// @license         GPL-3.0-only
// @create          2015-11-25
// @run-at          document-start
// @version         23.32
// @connect         www.baidu.com
// @include         *://ipv6.baidu.com/*
// @include         *://www.baidu.com/*
// @include         *://m.baidu.com/*
// @include         *://xueshu.baidu.com/s*
// @include         *://www.sogou.com/web*
// @include         *://www.sogou.com/sie*
// @include         *://www.sogou.com/sogou*
// @include         *://www.sogou.com/tx*
// @include         *://www.so.com/s?*
// @include         *://*.bing.com/*
// @include         *://encrypted.google.*/search*
// @include         *://*.google*/search*
// @include         *://*.google*/webhp*
// @include         *://*.zhihu.com/*
// @exclude         *://*.google*/sorry*
// @namespace       [email protected]
// @supportURL      https://qm.qq.com/cgi-bin/qm/qr?k=fOg8ij6TuwOAfS8g16GRYNf5YYFu5Crw&jump_from=&auth=-l05paasrPe5zigt5ahdzn_dzXiB1jJ_
// @home-url        https://greasyfork.org/zh-TW/scripts/14178
// @home-url2       https://github.com/langren1353/GM_script
// @homepageURL     https://greasyfork.org/zh-TW/scripts/14178
// @copyright       2015-2020, AC
// @lastmodified    2020-04-24
// @feedback-url    https://qm.qq.com/cgi-bin/qm/qr?k=fOg8ij6TuwOAfS8g16GRYNf5YYFu5Crw&jump_from=&auth=-l05paasrPe5zigt5ahdzn_dzXiB1jJ_
// @note            2020.04-24-V23.32 版本倒退:安全起见:默认关闭搜狗的自定义域名拦截功能和重定向功能-以后考虑更换方式;默认不开启重定向功能、默认不开启广告拦截功能;更新部分说明内容;同时也对部分支持不到位的,兼容不好的效果向大家说一声抱歉,之后我会更加努力让搜索结果更加方便查看和使用
// @note            2020.03-27-V23.31 修复google由于页面结构更新导致的block功能失效的问题,同时修复谷歌护眼模式也失效的问题。新增翻页的按钮事件,新增使用在线config,避免由于页面结构改动又需要重新提交脚本更新
// @note            2020.03-26-V23.30 小改代码with GoogleLOGO && 修复在inject极速模式下的小问题 && 修复各种样式问题 && 自定义样式开启动态模式 && 新增自动翻页功能-妈妈再也不用担心我翻页问题了-[推荐更新]
// @note            2019.12-16-V23.29 自定义英文和中文的显示效果 && 修复上个版本导致的block按钮丢失的问题 && 修复部分百度内容无法拦截的情况
// @note            2019.12-15-V23.28 由于域名备案丢失了,只能换一个 && 修复自己认为的谷歌favicon已存在的问题,实际上谷歌favicon并没有显示
// @note            2019.11-28-V23.27 修复上次更新导致的某些模式下window对象无法获取导致的异常进而导致的脚本无法运行的bug & 优化百度样式内容和谷歌单列的偏右的情况以及必应中英文的偏移位置 修复屏蔽功能失效的bug
// @note            2019.10-05-V23.25 修复谷歌样式、必应样式、百度的部分样式问题.修复屏蔽模式在chrome内核上的小bug 新增自动全英文模式 修复被翻译导致的bug
// @note            2019.09-13-V23.24 修复谷歌由于页面改动导致的插入之后的样式变化 & 修复上次更新导致的重定向失效的问题
// @note            2019.09-12-V23.23 紧急修复谷歌页面的bug & 增加时间判断是否重置最新的自定样式 & 修复整体页面的内存占用以及采用RAF来替代setInterval & 优化拦截列表并修复列表数据过多的删除失败的问题 & 新增支持通配符拦截模式 & 全部使用处理结果后的顺序
// @note            2019.08-09-V23.22 1.移除手机百度的广告内容 2.更换数据来源地址为ibaidu.ntaow.com降低服务器负载 3.变更:页面加载不载入iframe,点击显示后载入iframe 4.未启用自定义样式时间过长会更新最新的样式表 5.修复各大搜索的样式问题-侧移+背景透明 6.修复edge首页的问题 7.block屏蔽之后可以直接取消了 8.采用错误页支持后续的google的iframe嵌入
// @note            2019.06.16-V23.21 修复在屏蔽列表中加入异常数据导致的部分数据异常,同时还无法移除的bug && 修改Baidu学术的生效页面,避免导致其他学术页面的显示出问题 && 修复在缩放150%的情况下搜索框位置异常的问题
// @note            2019.06.15-V23.20 尽量修改在adguard上的部分兼容问题--如果有问题记得叫我
// @note            2019.06.05-V23.19 修复由于去广告其他插件导致的本脚本异常的问题 修复必应上的样式部分异常问题 修复图标的地址异常问题
// @note            2019.05.06-V23.18 修复Baidu学术的异常,上次修改了,但是代码没有生效 && 新增BaiduLite的样式效果-from yiclear _ pan_cao && 优化页面显示效果,加快样式的载入速度 && 根据申杰老司机的推荐修改了许多残留的bug并且优化了页面的数据提示
// @note            2019.05.05-V23.17 修复Baidu首页的图标异常的问题
// @note            2019.04.26-V23.15 修复护眼色调节;新增不显示lock按钮选项;新增谷歌伪装百度;修复谷歌和百度页面的搜索样式;修复百度学术页面异常
// @note            2019.03.30-V23.14 更新一下说明文档 && 添加一个github的跳转按钮 && 新增背景色
// @note            2019.03.28-V23.13 更新-移除部分异常的百度白屏问题.新域名baidu.mx并不是百度旗下的地址,所以跳过。顺便刷一个版本,修复谷歌的recapture的问题,感谢老司机“breath365”
// @note            2019.02.16-V23.12 修复上次更新导致的一堆bug & 更换资源。。。腾讯CDN真的不够你们用,还是用百度的免费cdn吧
// @note            2019.02.15-V23.11 修复和Google Search Extra Button的兼容问题。修复地址有时候不能访问的问题。修复旧ff上的forEach和innerText不能用的问题。删除部分旧日志
// @note            2019.02.14-V23.10 安静点,我有女朋了i_i。& 修复百度图片失效的问题
// @note            2019.02.13-V23.09 提供选项-直接删除已屏蔽的内容,避免看到一些垃圾无用信息;修复残留bug在单列时相关搜索宽度异常;优化百度图标为透明图标
// @note            2019.01.29-V23.08 修复从首页进入的导致的block功能失效的问题;修复移动预测按钮失效的问题;新增并修复百度手机版的兼容问题-支持手机版重定向;新增原始地址展示,减少百度更新导致的看不到地址的问题;优化拦截列表的展示和刷新的问题
// @note            2019.01.25-V23.07 修复Favion加载失败的问题-这下就可以自定义favicon了,以前遗留了很久的bug了 && 移除部分LOG减小代码
// @note            2019.01.25-V23.06 修复由于代码优化,导致的Huyan功能开启后脚本失效的问题
// @note            2019.01.25-V23.05 假装大家没发现bug,赶紧更新搜狗页面的bug
// @note            2019.01.25-V23.03 优化提示效果; 修复有时候自定义按钮无法显示的情况;新增搜狗页面的多列效果
// @note            2019.01.23-V23.02 修复初始化的时候数据异常导致的block拦截无效的问题
// @note            2019.01.23-V23.01 新增说明-感谢大神Jefferson Scher的拦截脚本https://greasyfork.org/zh-CN/scripts/1682. Thanks for the script of Jefferson Scher Without his help I can't Implement this Function.
// @note            2019.01.23-V23.00 新增拦截模式,可以自定义的选择拦截某个域名,拦截掉你不想看的内容
// @note            2018.12.25-V22.06 移除谷歌底部广告
// @note            2018.12.22-V22.05 修复小细节问题
// @note            2018.12.22-V22.04 修复百度搜索“咨询”栏目下没有搜索结果的问题 && 同时修改部分样式 && 修复输入框右侧无法点击输入的问题
// @note            2018.12.22-V22.03 修复edge的样式错乱问题 && 修复谷歌双列样式问题 && 修复百度顶部大空白的问题 && 修复支持DarkReader
// @note            2018.12.20-V22.02 修复样式加载 && 修复护眼模式效果
// @note            2018.12.20-V22.01 更换样式表插入模式,尽量避免闪烁问题; 修复edge上该模式的兼容问题
// @note            2018.12.19-V21.15 修复上次更新导致的护眼模式失效的问题
// @note            2018.12.19-V21.14 修复在edge上样式没有生效的问题
// @note            2018.12.19-V21.13 修复上次更新代码忘记修改导致的bug,修复百度移动预测的遗留bug
// @note            2018.12.18-V21.12 继续加快移除广告的内容,尽量减少闪烁的情况;
// @note            2018.12.18-V21.11 修复在特殊情况下的样式表没有生效的问题,同时能够更快速的移除广告内容
// @note            2018.12.18-V21.10 修复特殊关键内容搜索下,由于移除广告导致的页面顶部特殊标记显示不正确的问题。
// @note            2018.12.18-V21.9 再次优化样式表加载速度,能更好的更快速的加载样式而不影响代码运行
// @note            2018.12.08-V21.8 修复srcElement在firefox旧版本上不支持的问题
// @note            2018.12.07-V21.7 修复护眼色的引入;修复GM小于4.0版本的兼容问题;优化选项的位置,避免过长
// @note            2018.12.06-V21.6 感谢Mooncan对谷歌样式调整的建议,已经采用了该样式,效果特别好; 同时修复了谷歌右侧栏的位置问题
// @note            2018.12.06-V21.5 P_P修复上一版没有测试导致的支持ViolentMonkey但是有不支持GreaseMonkey的问题;更换css地址;修复护眼色在百度上的部分样式问题
// @note            2018.12.06-V21.4 修复ViolentMonkey的支持;至此已经完全支持三只猴子(TamperMonkey、ViolentMonkey、GreaseMonkey)了;如果还有BUG-直接加群反馈
// @note            2018.12.06-V21.3 修复在edge上样式错乱的问题 && 修复宽度过宽的问题
// @note            2018.12.05-V21.2 移除默认的护眼模式。。。
// @note            2018.12.05-V21.1 修复GreaseMonkey不支持GM_getResourceText导致的样式无法引入的问题,使用自己的服务器中转
// @note            2018.12.05-V21.0 新增必应单列、双列、多列展示;新增护眼模式,各种颜色自定义设置;修复谷歌已浏览的网址未变色问题;优化一定的资源占用
// @note            2018.10.18-V20.5 修复由于谷歌更新导致的样式问题
// @note            2018.10.08-V20.4 修复由于去广告导致的卡顿问题 & 重写favicon添加的位置元素-减少错位产生
// @note            2018.10.03-V20.3 国庆无事,刷版本; 修复在侧边栏开启需要在1920的分辨率下的问题,默认关闭侧边栏的样式操作,如果需要开启的话,在自定义样式中设置开启即可,增加三列|四列模式
// @note            2018.10.01-V20.2 修复拦截广告过多导致的页面显示问题-有些正常地址也被拦截了->似乎发现不是这个脚本的bug;那就刷个版本吧,正好处理下样式缓存问题 & 大家国庆节快乐
// @note            2018.09.21-V20.1 修复在ViolentMonkey的兼容问题 && 样式加载缓慢的问题
// @note            2018.09.21-V20.0 修复闪烁频繁的问题;修复由于扩展和脚本模式两个CSS同时加载导致的问题;新增点击任意位置关闭设置按钮;修复在bing上的计数器位置错误;调整页面单页的样式,这次是真的居中了
// @note            2018.09.19-V19.8 修复TamperMonkey和扩展模式下的兼容问题
// @note            2018.09.19-V19.7 分离去广告功能和自定义样式功能
// @note            2018.09.18-V19.6 修复由于infinity扩展的地址导致的百度样式没有载入的问题;修复万年bug之搜索预测无效的问题
// @note            2018.09.18-V19.5 新增支持扩展模式-推荐使用扩展;修复谷歌地图页面的载入问题;配置脚本GPL协议;支持旧版本的chrome上的自定义显示结果却在最底部的问题-无法解决旧版本chrome上双列的问题
// @note            2018.08.31-V19.4 修复1.google页面中计数器Counter在账号登录后的显示错位问题; 2.排除掉百度可能存在的error情况的地址; 3.更换css样式地址,我的CDN流量撑不住了
// @note            2018.08.24-V19.3 修复谷歌图片在单列模式下的错位问题
// @note            2018.08.17-V19.2 修复谷歌和百度的部分样式问题
// @note            2018.08.16-V19.1 继续修复谷歌和百度双列的问题,这次尽量采用css样式表来调整,感觉效果还可以
// @note            2018.08.14-V18.9 修复谷歌双列的翻页错位的问题; 百度搜索结果的阴影模式; 高分屏等我找到一台高分的显示器再说吧
// @note            2018.08.11-V18.8 紧急-修复更新规则导致的谷歌失效的问题
// @note            2018.08.10-V18.7 推荐升级:修改生效规则,尽量避免弹出提示更新窗口;修复-chrome4x版本的bug;预计下次更新处理高分屏显示界面问题
// @note            2018.08.08-V18.6 更新脚本命名; 尝试解决http没有自动https的问题--------刷版本号
// @note            2018.08.04-V18.5 修复在chrome上脚本偶尔没有生效的问题;修复百度搜索顶部侧移的情况;一定情况下修复双页的分列
// @note            2018.07.25-V18.4 仅做文本说明修改-en-jp; 下次预计修改百度首页的广告问题
// @note            2018.07.25-V18.3 减少了偶尔从首页加载进来的时候样式表没有载入的问题~能遇到部分样式表加载失效的情况很少;优化广告移除
// @note            2018.07.24-V18.2 修复从百度首页加载进入页面时样式表没有载入的问题
// @note            2018.07.24-V18.1 整体优化样式表加载速度-百度和谷歌的界面美化一下就载入了特别快;修复百度搜索的小链接的重定向没有改;修复下划线移除选项的下划线移除模式
// @note            2018.07.21-V18.0 修复搜狗搜索没有获取到真实链接的问题;处理百度重定向速度又快又好;这次更新就支持edge了,同时理论上支持safari,希望测试;其次优化谷歌的界面样式
// @note            2018.07.12-V17.9 修改检测参数,兼容支持Opera浏览器;暂时还是不支持EDGE的链接重定向功能
// @note            2018.07.07-V17.8 修复由于上次更新世界杯界面时导致的shadowDOM关闭,然后广告出现的问题;优化整体去广告规则---有工具何必自己造轮子-本次用了百度自带jquery的查询函数has()
// @note            2018.06.29-V17.7 修复右边栏导致的右侧过高,左侧看不见,以及自定义页面样式丢失的问题
// @note            2018.06.27-V17.6 暂时关闭ShadowDOM的移除功能-尽量保留搜索世界杯功能完善。修复在某些页面上脚本无法运行的情况。新增自定义样式的输入框
// @note            2018.06.26-V17.5 默认关闭右边栏-昨天忘了关闭了
// @note            2018.06.25-V17.4 1.修复谷歌双列问题;2.修复右边栏展示-好些人说去掉之后不好看;3.似乎上个版本又有多次插入导致的页面卡顿情况-再次修复。。。其他的似乎没有了,想起再说
// @note            2018.06.14-V17.3 由于edge中还是不支持返回真实链接,于是暂时屏蔽掉edge浏览器总的请求,等猴子更新了再开启这个功能;connect元素中添加baidu.com避免抽风
// @note            2018.06.13-V17.2 加快查询速度-同时不再弹窗说新连接,无需设置特殊参数;缺点:LOG中会有许多Refused to connect to "xxx": Request was redirected to a not whitelisted URL
// @note            2018.05.25-V17.1 新增支持百度学术的重定向功能
// @note            2018.05.25-V17.0 拆分关键词高亮这个功能,保证功能尽量不交叉,如果需要这个功能的,请安装搜索关键词自动高亮脚本
// @note            2018.05.22-V16.5 尝试缓解内存的问题,避免对其他的进行干扰,同时减少了head标签触发
// @note            2018.05.22-V16.4 彻底拆分双击高亮和自动高亮功能,同时保持两个功能都是关闭状态
// @note            2018.05.22-V16.3 设置添加双击高亮按钮
// @note            2018.05.22-V16.2 不再使用MO方式,百度的原因导致MO彻底无法使用,于是全都用DOM操作来判断吧
// @note            2018.05.21-V16.1 优化ac_redirectstatus高亮的问题; 同时修复了一个高亮关键词的bug;在一个老司机的指点下,添加了referer参数
// @note            2018.05.21-V16.0 谢谢朋友们关心5.20我还是一个人过的很好;大版本:修正计数器的计数问题,修正MO失效之后脚本的触发问题;新增搜索关键词高亮选项,默认关闭
// @note            2018.05.06-V15.3 简单移除好搜的广告
// @note            2018.04.20-V15.2 修复bing的Favicon效果,避免显示在不同行上
// @note            2018.04.04-V15.1 继续尝试修复bug,优化整体页面效果以及谷歌其余页面的效果展示;同时将百度样式写入到#wrapper>#head中去,刷新或者更换页面时就不会异常闪烁并且很平滑了
// @note            2018.04.02-V14.9 更新谷歌整体效果,并尝试修复图片新闻等显示问题的bug
// @note            2018.04.01-V14.8 --日狗问题,忘了改代码,只是更新了说明。。
// @note            2018.04.01-V14.7 经过老司机(没ID)提供的反馈,发现上一版更新的依旧有bug,修复调小触发参数导致的触发没有生效的问题--偶尔双列失效的问题
// @note            2018.04.01-V14.6 经过老司机(没ID)提供的反馈,排查发现chrome上脚本首次载入失效的问题,已经修复
// @note            2018.04.01-V14.5 更新并添加谷歌双列、待测试,如果有问题,可以直接反馈
// @note            2018.03.28-V14.4 移除jquery的require,疑似jquery引起冲突问题,于是彻底弃用jquery来处理页面数据,改用原声JS处理页面
// @note            2018.03.27-V14.3 刷一个版本号,同时优化CSS载入过多的问题,但是载入过慢的问题又出现了,下次处理
// @note            2018.03.26-V14.2 修复由于上次更新过于流畅的bug,同时修正首页的样式显示
// @note            2018.03.25-V14.1 再次抄点代码,借鉴老司机:浮生@未歇的部分优化代码完善已有的(@resource、GM_getResourceText、GM_addStyle),避免页面闪烁一下,同时解决部分css载入重复的问题
// @note            2018.03.23-V14.0 1.尝试修复在百度贴吧和百度知道的文字显示异常的问题; 2.修复编号奇怪的异常问题
// @note            2018.03.18-V13.9 更新谷歌的favicon丢失的问题
// @note            2018.03.04-V13.8 更新图库为https模式,避免那啥显示不安全
// @note            2018.02.16-V13.7 1.新增关闭百度搜索预测;2.新增未知图标时切换; 3.移除百度搜索建议的顶部一条
// @note            2018.01.12-V13.6 1.新增移除右边栏的按钮;2.新增版本显示文字;3.修正favicon位置;4.修复favicon的图片错误时候的值,万年BUG
// @note            2017.12.27-V13.5 修复由于上个版本更新处理白屏,导致的默认标准模式的右侧栏不见了
// @note            2017.12.20-V13.4 感谢ID:磁悬浮青蛙的反馈,已经修复小概率搜索之后点击结果白屏的问题-貌似之前处理过,但是没有彻底处理掉,这次彻底了,改用CSS隐藏
// @note            2017.12.04-V13.3 新增设置,针对百度系列的重定向问题,不常用百度系列的朋友可以开启这个功能
// @note            2017.11.23-V13.2 感谢卡饭坛友@Apollo8511提供反馈,已经修复部分知乎的重定向问题,更多问题可以直接反馈我
// @note            2017.11.22-V13.1 移除百度系的重定向,虽然处理了,但是百度系直连会导致文字无法直接显示,其他直连不影响
// @note            2017.11.17-V12.13 进一步移除百度的广告,右边部分广告的处理和移除
// @note            2017.11.15-V12.12 搜狗的搜索地址又变了,加一个
// @note            2017.11.02-V12.11 新增在手机mobile模式下百度的重定向处理,其余网站以后再说吧,估计没有需求
// @note            2017.10.27-V12.10 1.修复逼死强迫症的问题;2.移除完整模式-避免出现各种拦截;3.修复www.so.com的重定向问题
// @note            2017.09.18-V12.9 更新原因:1.勿忘国耻918;2.更新百度偶尔重定向没成功的问题;3.修复页面的小问题;4.新增文字下划线开关
// @note            2017.09.15-V12.8 紧急修复谷歌上页面卡顿的问题,排查得知为百度规则的扩展出了问题,非常感谢众多朋友的支持,没有你们的反馈就没有这个脚本。修复并移除了百度官方采用的新方式广告模式,貌似只在chrome上出现
// @note            2017.09.13-V12.7 1.修复N年前更新导致的部分网址重定向无效,继续使用GET方法,因为好些网站不支持HEAD方法,获取成功之后就断开,尽量减少了网络开支; 2.修复搜狗的部分搜索异常; 3.修复百度在chrome61上的链接异常问题
// @note            2017.09.13-V12.6 开学之后的第二个版本,修复上次更新导致的百度首页错乱,修复firefox上的触发,修复SuperPreloader的翻页展示
// @note            2017.09.12-V12.5 开学之后的第一个版本,修复在百度上偶尔不触发的问题【从首页搜索的时候触发】,其次在兄弟XXX(我也忘了哪个P_P)的帮助下,修复了偶尔会全屏特殊推广模式的问题
// @note            2017.09.06-V12.4 修复上个版本更新导致的百度知道再次异常问题;更新知乎上的重定向问题-自己的脚本
// @note            2017.09.06-V12.3 修复双列的模式的显示问题,如果有问题希望反馈一下,顺便切换css来源
// @note            2017.09.04-V12.2 特意修复在ViolentMonkey上的设置无效的问题以及在360浏览器上的设置不显示问题
// @note            2017.09.04-V12.1 百度页面直接添加设置入口;360浏览器设置可能在底部页面;支持单列和双列模式,界面更美观from浮生@未歇;可能是最近一段时间的最后版本了,要开学了~~
// @note            2017.09.02-V11.10 添加两个选项,可以选择性移除部分设置
// @note            2017.09.01-V11.9 修复上次更新导致的百度去广告不灵的问题
// @note            2017.08.30-V11.8 新增:1.GM设置栏目中加入设置 2.baidu-使用HEAD方式获取,减少数据传输,搜狗特殊,继续GET方式
// @note            2017.08.29-V11.7 方便朋友们-移除知乎重定向
// @note            2017.08.07-V11.6 调整:移除小绿点,换为点击Favicon或者是计数器弹出窗口,更换为加群链接
// @note            2017.08.06-V11.5 修复,保存异常;预期之后会添加百度搜索页面的大调整
// @note            2017.08.05-V11.4 新增:反馈和建议地址增加
// @note            2017.08.04-V11.3 修复:由于英语不好导致的拼写错误,感谢shj兄弟指出
// @note            2017.08.03-V11.2 新增:谷歌链接新标签打开; 移除搜索结果链接的下划线
// @note            2017.07.22-V11.1 新增了开关模式,可以开启或者关闭某些自己不喜欢的功能,开关在右上角,和SuperPreload共用
// @note            2017.06.25-V10.1 修复上次更新导致的百度去广告的问题
// @note            2017.06.25-V10.0 修复上次更新导致的百度知道再次出现老问题
// @note            2017.06.24-V9.9 更新了翻页的问题,经过多次的尝试应该没有太大问题了
// @note            2017.06.24-V9.8 更新了bing上的图片favicon地址;并且尽量减少了MO触发次数,避免页面卡顿;修复搜狗的重定向问题
// @note            2017.06.23-V9.7 上传错了~重新来,顺带处理了谷歌favicon问题
// @note            2017.06.23-V9.6 修复了谷歌重定向的问题~~我的锅
// @note            2017.06.11-V9.5 不再使用DOM方式来监听页面了,使用timer+MO来处理,极大减少了cpu占用时间和瞬时网速占用
// @note            2017.05.26-V9.4 恢复favicon模式,现在这个脚本基本上全了,有需要以后再说
// @note            2017.05.15-V9.3 暂时移除百度右边侧栏的广告移除模式,准备下次优化好了再继续
// @note            2017.05.12-V9.2 暂时移除谷歌的安全搜索模式,因为很复杂的原因
// @note            2017.05.12-V9.1 暂时移除Favicon的显示,因为这样就杂了,有需要的人自己去装这个脚本吧,保留百度去广告
// @note            2017.05.12-V9.0 集合了去重定向+去广告+Favicon显示
// @note            2017.05.12-V8.7 集合了去广告的脚本,以前的那个去广告的脚本就不用了
// @note            2017.05.12-V8.6 修复谷歌安全搜索的BUG V2
// @note            2017.05.12-V8.4 新增:默认屏蔽谷歌的安全搜索功能
// @note            2017.05.05-V8.3 修复include范围太小导致的百度知道的屏蔽问题
// @note            2017.05.04-V8.2 终于修复了百度知道图片替换了文字的这个大BUG; 顺便处理了superapi.zhidao.baidu.com; 新增谷歌搜索结果重定向去除
// @note            2017.05.04-V8.1 终于修复了百度知道图片替换了文字的这个大BUG,顺便处理了superapi.zhidao.baidu.com
// @note            2017.05.04-V8.0 终于修复了百度知道图片替换了文字的这个大BUG,待测试
// @note            2017.03.28-V7.6 修复在ViolentMonkey上的不支持的问题
// @note            2017.03.28-V7.5 尝试修复chrome上的问题
// @note            2017.03.21-V7.4 尝试处理Edge上不支持的问题,结果发现是Edge本身的TamperMonkey支持有问题
// @note            2017.03.19-V7.3 修复打开百度之后再次点击“百度一下”导致的无法更新重定向问题
// @note            2017.03.19-V7.2 未知原因chrome的MutationObserver无法使用了,继续回归以前的DOMNodeInserted
// @note            2017.02.17-V7.0 修复搜狗的搜索结果重定向问题+改个名字
// @note            2017.02.17-V6.9 修复搜狗的搜索结果重定向问题
// @note            2016.12.10-V6.8 ***
// @note            2016.10.27-V6.7 修复了以前的重复请求,现在的请求数应该小了很多,网络也就不卡了,感觉萌萌哒
// @note            2016.04.24-V6.6 恢复以前的版本,因为兼容性问题
// @note            2015.12.01-V5.0 加入搜狗的支持,但是支持不是很好
// @note            2015.11.25-V2.0 优化,已经是真实地址的不再尝试获取
// @note            2015.11.25-V1.0 完成去掉百度重定向的功能
// @resource        baiduCommonStyle     http://ibaidu.htt5.com/newcss/baiduCommonStyle.css?t=23.31
// @resource        baiduOnePageStyle    http://ibaidu.htt5.com/newcss/baiduOnePageStyle.css?t=23.31
// @resource        baiduTwoPageStyle    http://ibaidu.htt5.com/newcss/baiduTwoPageStyle.css?t=23.31
// @resource        baiduLiteStyle       http://ibaidu.htt5.com/newcss/baiduLiteStyle.css?t=23.31
// @resource        googleCommonStyle    http://ibaidu.htt5.com/newcss/googleCommonStyle.css?t=23.31
// @resource        googleOnePageStyle   http://ibaidu.htt5.com/newcss/googleOnePageStyle.css?t=23.31
// @resource        googleTwoPageStyle   http://ibaidu.htt5.com/newcss/googleTwoPageStyle.css?t=23.31
// @resource        bingCommonStyle      http://ibaidu.htt5.com/newcss/bingCommonStyle.css?t=23.31
// @resource        bingOnePageStyle     http://ibaidu.htt5.com/newcss/bingOnePageStyle.css?t=23.31
// @resource        bingTwoPageStyle     http://ibaidu.htt5.com/newcss/bingTwoPageStyle.css?t=23.31
// @resource        sogouCommonStyle     http://ibaidu.htt5.com/newcss/sogouCommonStyle.css?t=23.31
// @resource        sogouOnePageStyle    http://ibaidu.htt5.com/newcss/sogouOnePageStyle.css?t=23.31
// @resource        sogouTwoPageStyle    http://ibaidu.htt5.com/newcss/sogouTwoPageStyle.css?t=23.31
// @resource        MainHuYanStyle       http://ibaidu.htt5.com/newcss/HuYanStyle.css?t=23.31
// @resource        SiteConfigRules      http://ibaidu.htt5.com/newcss/SiteConfigRules.conf?t=23.31
// @grant           GM_getValue
// @grant           GM.getValue
// @grant           GM_setValue
// @grant           GM.setValue
// @grant			GM_addStyle
// @grant           GM_xmlhttpRequest
// @grant           GM_getResourceText
// @grant           GM_registerMenuCommand
// ==/UserScript==

!function () {
    let isdebug = false;
    let isLocalDebug = isdebug || false;
    let debug = isdebug ? console.log.bind(console) : function () {};
    let acCssLoadFlag = false;

    let inExtMode = typeof(isExtension) != "undefined";
    let inGMMode = typeof(GM_info.scriptHandler) != "undefined"; // = "Greasemonkey" || "Tampermonkey" || "ViolentMonkey"
    // 新版本的GreaseMonkey是带有scriptHandler,但是没有GM_getResourceText;旧版本不带scriptHandler,但是有GM_getResourceText
    let isNewGM = typeof(GM_info.scriptHandler) != "undefined" && GM_info.scriptHandler.toLowerCase() == "greasemonkey";
    let useCNLan = true; // 暂定,之后需要逻辑处理
    // inExtMode & inGMMode
    // true        true =扩展下的GM代码 不执行
    // true        false=扩展下代码 执行
    // false       true =仅GM代码 执行
    // false       false=异常 但是还是要执行代码
    debug("程序开始");
    if (inExtMode == true && inGMMode == true) {
        console.log("扩展模式-脚本不启用");
        return;
    }
    if (typeof(GM) == "undefined") {
        // 这个是ViolentMonkey的支持选项
        GM = {};
        GM.setValue = GM_setValue;
        GM.getValue = GM_getValue;
    }
    (function () {
        debug("程序执行");
        let needDisplayNewFun = true; // 本次更新是否有新功能需要展示
        if (window.NodeList && !NodeList.prototype.forEach) {
            NodeList.prototype.forEach = function (callback, thisArg) {
                thisArg = thisArg || window;
                for (var i = 0; i < this.length; i++) {
                    callback.call(thisArg, this[i], i, this);
                }
            };
        }
        if(!Array.prototype.acpush){
            /**
             * 进行不重复插入,插入后执行回调函数
             * @param data 待插入数据
             * @param callback 回调函数
             */
            Array.prototype.acpush = function (data, callback) {
                // 如果是垃圾数据,那么可以丢弃的
                if(data == null) return;
                // 如果数据中有回车,那数据也是无效的正文而已
                if(data.replace(/({|}|,|\+|:|。|\n)/) != data) return;
                if(this.findIndex(m => m == data) < 0){
                    this.push(data);
                    callback && callback(this);
                }
            };
            Array.prototype.acremove = function (data, callback) {
                let delId = this.findIndex(m => m == data);
                if(delId >= 0){
                    this.splice(delId, 1);
                    callback && callback(this);
                } // 删除delId的数据,删除一个
            };
        }
        let ACConfig = {};
        /*存在对未初始化变量的初始化赋值-无需担心迭代兼容问题*/
        let DefaultConfig = {
            isRedirectEnable: false,  // 是否开启重定向功能
            isAdsEnable: false, // 是否开启去广告模式
            isAutopage: true,  // 是否开启自动翻页功能
            isBlockEnable: false, // 是否开启去拦截模式
            isBlockDisplay: false, // 是否删除已拦截的条目
            isBlockBtnDisplay: true, // 是否显示block按钮
            AdsStyleEnable: true, // 是否开启自定义样式模式
            AdsStyleMode_Baidu: 2, // 0-不带css;1-单列靠左;2-单列居中;3-双列居中
            AdsStyleMode_Google: 2, // 0-不带css;1-单列靠左;2-单列居中;3-双列居中
            AdsStyleMode_Bing: 3, // 0-不带css;1-单列靠左;2-单列居中;3-双列居中
            AdsStyleMode_SoGou: 3, // 0-不带css;1-单列靠左;2-单列居中;3-双列居中

            HuYan_Baidu: false, // 护眼模式-百度
            HuYan_Google: false, // 护眼模式-谷歌
            HuYan_Bing: false, // 护眼模式-必应
            HuYan_SoGou: false, // 护眼模式-必应
            Style_BaiduLite: false, // Baidu_Lite样式表

            defaultHuYanColor: "#DEF1EF",
            isUserColorEnable: true, // 是否开启favicon图标功能
            isFaviconEnable: true, // 是否开启favicon图标功能
            defaultFaviconUrl: "https://ae01.alicdn.com/kf/HTB1dRY0X8OD3KVjSZFFq6An9pXay.jpg", // 默认图标地址
            doDisableSug: true, // 是否禁止百度搜索预测
            isRightDisplayEnable: false, // 是否开启右侧边栏
            isCounterEnable: false, // 是否显示计数器
            isALineEnable: false, // 是否禁止下划线
            isUserStyleEnable: false, // 是否开启自定义样式
            isEnLang: false,
            isGooleInBaiduModeEnable: false, // 是否开启谷歌搜索结果页的百度图标显示
            UserBlockList: [],
            UserStyleText:
                `/**计数器的颜色样式*/
div .AC-CounterT{
    background: #FD9999;
}
/**右侧栏的样式-其实不开启更好看一些*/
#content_right{
    padding: 20px 15px 15px;
    border-radius: 5px;
    background-color: #fff;
    box-sizing: border-box;
    box-shadow: 0 0 20px 2px rgba(0, 0, 0, .1);
    -webkit-box-shadow: 0 0 20px 2px rgba(0, 0, 0, .1);
    -moz-box-shadow: 0 0 20px 2px rgba(0, 0, 0, .1);
}
/****可以加一些自己的背景图片,替换引号内的内容为可外链的图片即可****/
body{
    background-repeat: repeat-y;
    background-size: 100%;
    background-attachment:fixed;
    background-image: url('https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1564756277250&di=868b9eac9be14df1dedd8c7d6a710844&imgtype=0&src=http%3A%2F%2Fphotocdn.sohu.com%2F20130530%2FImg377502333.jpg');
}
/*****窗口背景的透明虚化效果*****/
body>#wrapper,body>.wrap,body>#main,body #appbar,body #hdtbSum{
    background: rgba(225,225,225,0.8);
}
/**隐藏首页的大图标-修复可能导致外援样式异常**/
body[baidu] #s_lg_img_new{
    display:none !important;
}
#wrapper #content_left .result, #wrapper #content_left .c-container{
    border-radius: 5px;
}`,
            oldVersion: "",
            lastSaveTime: new Date().getTime(),
        };
        let CONST = {
            hasNewFuncNeedDisplay: true,
            sortIndex: 1,
            isGoogleImageUrl: false,
            AdsStyleMode: ACConfig.AdsStyleMode_Baidu,
            keySite: "baidu",
            StyleManger: function () {},
            curHosts: [],
        };
        let curSite = {
            SiteTypeID: 1,    // 当前站点的ID
            MainType:"",      // 主体节点,很多个的父节点
            Stype_Normal: "", // 重定向选择器,只有百度-搜狗-好搜
            FaviconType: "",  // favicon的域名检查器cite,用于获取host用
            FaviconAddTo: "", // favicon选择器,用于插入到title之前的
            CounterType: "",  // 计数器添加的位置,一般和favicon位置一致
            BlockType: "",    // 屏蔽按钮的位置,一般在title之后
        };
        let DBSite = {
            baidu: {
                SiteTypeID: 1,
                MainType: "#content_left .c-container",
                Stype_Normal: "h3.t>a, #results .c-container>.c-blocka",
                FaviconType: ".result-op, .c-showurl", // baidu 似乎要改版了?
                FaviconAddTo: "h3",
                CounterType: "#content_left>#double>div[srcid] *[class~=t],[class~=op_best_answer_question],#content_left>div[srcid] *[class~=t],[class~=op_best_answer_question]",
                BlockType: "h3 a",
                pager:{
                    nextLink: '//div[@id="page"]/a[contains(text(),"下一页")][@href]',
                    pageElement: "css;div#content_left > *",
                    HT_insert: [ "css;div#content_left", 2 ],
                    replaceE: "css;#page",
                    stylish: ".autopagerize_page_info, div.sp-separator {margin-bottom: 10px !important;}",
                }
            },
            sogou: {
                SiteTypeID: 2,
                MainType: "#main .results>div",
                Stype_Normal: "h3.pt>a, h3.vrTitle>a",
                FaviconType: "cite[id*='cacheresult_info_']",
                FaviconAddTo: "h3",
                CounterType: ".results>div",
                BlockType: "h3 a",
                pager:{
                    nextLink: "//div[@id=\"pagebar_container\"]/a[@id=\"sogou_next\"]",
                    pageElement: "//div[@class=\"results\"]",
                    HT_insert: ["//div[@class=\"results\"]", 2],
                    replaceE: "id(\"pagebar_container\")"
                }
            },
            haosou: {
                SiteTypeID: 3,
                MainType: ".res-list",
                Stype_Normal: ".res-list h3>a",
                FaviconType: ".res-linkinfo cite",
                FaviconAddTo: "h3",
                CounterType: ".results>div",
                BlockType: "h3 a",
                pager:{
                    nextLink: "//div[@id=\"page\"]/a[text()=\"下一页>\"] | id(\"snext\")",
                    pageElement: "//div[@id=\"container\"]/div",
                    HT_insert: ["//div[@id=\"container\"]", 1],
                    replaceE: "id(\"page\")"
                }
            },
            google: {
                SiteTypeID: 4,
                MainType: "#rso .g *[class~=rc]",
                FaviconType: ".iUh30",
                FaviconAddTo: "h3",
                CounterType: "#rso .g *[class~=r] h3,._yE>div[class~=_kk] h3",
                BlockType: ".rc>.r>a",
                pager:{
                    nextLink: 'id("pnnext") | id("navbar navcnt nav")//td[span]/following-sibling::td[1]/a | id("nn")/parent::a',
                    pageElement: '//div[@id="res"]',
                    HT_insert: [ "css;#res", 2 ],
                    replaceE: '//div[@id="navcnt"] | //div[@id="foot"][@role="navigation"]'
                }
            },
            bing: {
                SiteTypeID: 5,
                MainType: "#b_results>li",
                FaviconType: ".b_attribution>cite",
                FaviconAddTo: "h2",
                CounterType: "#b_results>li[class~=b_ans]>h2,#b_results>li[class~=b_algo]>h2,#b_results>li[class~=b_algo]>h2",
                BlockType: "h2 a",
                pager:{
                    nextLink: "//a[contains(@class,\"sb_pagN\")]",
                    pageElement: "id(\"b_results\")/li[not(contains(@class,\"b_pag\") or contains(@class,\"b_ans b_top\"))]",
                    HT_insert: ["id(\"b_results\")/li[@class=\"b_pag\"]", 1],
                    replaceE: "id(\"b_results\")//nav[@role=\"navigation\"]",
                }
            },
            mBaidu:{
                SiteTypeID: 6,
                MainType: "#b_results>li",
                FaviconType: ".b_attribution>cite",
                FaviconAddTo: "h2",
                CounterType: "#b_results>li[class~=b_ans]>h2,#b_results>li[class~=b_algo]>h2,#b_results>li[class~=b_algo]>h2",
                BlockType: "h2 a",
            },
            zhihu: {
                SiteTypeID: 7,
            },
            baidu_xueshu:{
                SiteTypeID: 8,
                MainType: "#content_left .result",
                Stype_Normal: "h3.t>a, #results .c-container>.c-blocka",
                FaviconType: ".result-op, .c-showurl", // baidu 似乎要改版了?
                FaviconAddTo: "h3",
                CounterType: "#content_left>#double>div[srcid] *[class~=t],[class~=op_best_answer_question],#content_left>div[srcid] *[class~=t],[class~=op_best_answer_question]",
                BlockType: "h3 a",
            },
            other: {
                SiteTypeID: 9,
            }
        };
        let SiteType = {
            BAIDU: DBSite.baidu.SiteTypeID,
            MBAIDU: DBSite.mBaidu.SiteTypeID,
            SOGOU: DBSite.sogou.SiteTypeID,
            SO: DBSite.haosou.SiteTypeID,
            GOOGLE: DBSite.google.SiteTypeID,
            BING: DBSite.bing.SiteTypeID,
            ZHIHU: DBSite.zhihu.SiteTypeID,
            BAIDU_XUESHU: DBSite.baidu_xueshu.SiteTypeID,
            OTHERS: 8
        };
        /**初始化所有的设置**/
        Promise.all([GM.getValue("Config")]).then(function (data) {
            if (data[0] != null) {
                try{
                    ACConfig = JSON.parse(data[0]);
                }catch (e) {
                    ACConfig = data[0];
                }
            } else {
                ACConfig = DefaultConfig;
            }
            for(var key in DefaultConfig){
                if(typeof(ACConfig[key]) == "undefined"){
                    ACConfig[key] = DefaultConfig[key];
                }
            }
            if(ACConfig.isUserStyleEnable == false && (new Date().getTime() - ACConfig.lastSaveTime > 2592000000)){ // 大约30天时间
                // 如果用户取消了设置,并且长时间(3天)没有进行过处理,那么直接将数据置空 -> 用于刷新数据
                console.log("ac-baidu css reset for time");
                ACConfig.lastSaveTime = new Date().getTime();
                ACConfig.UserStyleText = DefaultConfig.UserStyleText;
            }
            useCNLan = !ACConfig.isEnLang;
            // 初始化完成之后才能调用正常函数
            callback();
        }).catch(function (except) {
            console.log(except);
        });
        function Reg_Get(HTML, reg) {
            let RegE = new RegExp(reg);
            try {
                return RegE.exec(HTML)[1];
            } catch (e) {
                return "";
            }
        }
        function getElementByXpath(e, t, r) {
            r = r || document, t = t || r;
            try {
                return r.evaluate(e, t, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
            } catch (t) {
                return void console.error("无效的xpath");
            }
        }
        function getAllElementsByXpath(e, t, r) {
            return r = r || document, t = t || r, r.evaluate(e, t, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
        }
        function getAllElements(e, t, r, n, o) {
            var i, s = [];
            if (!e) return s;
            if (r = r || document, n = n || window, o = o || void 0, t = t || r, "string" == typeof e) i = 0 === e.search(/^css;/i) ? function getAllElementsByCSS(e, t) {
                return (t || document).querySelectorAll(e);
            }(e.slice(4), t) : getAllElementsByXpath(e, t, r); else {
                if (!(i = e(r, n, o))) return s;
                if (i.nodeType) return s[0] = i, s;
            }
            return function makeArray(e) {
                var t, r, n, o = [];
                if (e.pop) {
                    for (t = 0, r = e.length; t < r; t++) (n = e[t]) && (n.nodeType ? o.push(n) : o = o.concat(makeArray(n)));
                    return a()(o);
                }
                if (e.item) {
                    for (t = e.length; t; ) o[--t] = e[t];
                    return o;
                }
                if (e.iterateNext) {
                    for (t = e.snapshotLength; t; ) o[--t] = e.snapshotItem(t);
                    return o;
                }
            }(i);
        }
        function callback() {
            if (ACConfig.oldVersion == GM_info.script.version) {
                CONST.hasNewFuncNeedDisplay = false;
            } else {
                CONST.hasNewFuncNeedDisplay = needDisplayNewFun;
            }

            !function () {
                let BaiduVersion = " V" + GM_info.script.version;
                let insertLocked = false;
                if(GM_getResourceText){
                    // 仅在支持GM_getResourceText的容器上进行动态数据更新
                    // 且能防止谷歌百度页面规则大变动又需要更新脚本 - 特别是涉及翻页参数
                    let config = GM_getResourceText("SiteConfigRules");
                    eval(config);
                    if(typeof(onlineDB) != "undefined") DBSite = onlineDB;
                }
                if (location.host.indexOf("xueshu.baidu.com") > -1) {
                    curSite = DBSite.baidu_xueshu;
                }else if (location.host.indexOf(".baidu.com") > -1) {
                    if(navigator.userAgent.replace(/(android|mobile|iphone)/igm, "") != navigator.userAgent){
                        curSite = DBSite.mBaidu;
                    }else{
                        curSite = DBSite.baidu;
                    }
                } else if (location.host.indexOf("zhihu.com") > -1) {
                    curSite = DBSite.zhihu;
                } else if (location.host.indexOf("sogou") > -1) {
                    curSite = DBSite.sogou;
                } else if (location.host.indexOf("so.com") > -1) {
                    curSite = DBSite.haosou;
                } else if (location.host.indexOf("google") > -1) {
                    curSite = DBSite.google;
                } else if (location.host.indexOf("bing") > -1) {
                    curSite = DBSite.bing;
                }else {
                    curSite = DBSite.other;
                }
                curSite.pageNum = 1; // 当前页数
                curSite.pageLoading = false;
                curSite.pageUrl = "";
                if (curSite.SiteTypeID == SiteType.GOOGLE && location.href.replace(/tbm=(isch|lcl|shop|flm)/, "") != location.href) {
                    // 图片站 、地图站、购物站
                    console.log("特殊站,不加载样式,不添加menu");
                    CONST.isGoogleImageUrl = true;
                }
                if (ACConfig.AdsStyleEnable) {
                    if (curSite.SiteTypeID == SiteType.BAIDU) {
                        CONST.AdsStyleMode = ACConfig.AdsStyleMode_Baidu;
                        CONST.HuYanMode = ACConfig.HuYan_Baidu;
                        CONST.keySite = "baidu";
                    } else if (curSite.SiteTypeID == SiteType.GOOGLE) {
                        CONST.AdsStyleMode = ACConfig.AdsStyleMode_Google;
                        CONST.HuYanMode = ACConfig.HuYan_Google;
                        CONST.keySite = "google";
                    } else if (curSite.SiteTypeID == SiteType.BING) {
                        CONST.AdsStyleMode = ACConfig.AdsStyleMode_Bing;
                        CONST.HuYanMode = ACConfig.HuYan_Bing;
                        CONST.keySite = "bing";
                    } else if (curSite.SiteTypeID == SiteType.SOGOU){
                        CONST.AdsStyleMode = ACConfig.AdsStyleMode_SoGou;
                        CONST.HuYanMode = ACConfig.HuYan_SoGou;
                        CONST.keySite = "sogou";
                    } else if(curSite.SiteTypeID == SiteType.BAIDU_XUESHU){
                        CONST.AdsStyleMode = 2; // 单列居中即可
                    }
                    CONST.StyleManger = FSBaidu(); // 添加设置项-单双列显示
                }
                console.log("%c[AC-Redirect] %cLet Me Introduce you a Very Good Search Engine:%c %s %cSearch Engine.", "font-weight:bold;color:cornflowerblue", "color:0", "font-weight:bold;color:darkorange", CONST.keySite.replace(CONST.keySite[0],CONST.keySite[0].toUpperCase()), "font-weight:normal;color:0");
                let bodyNameresetTimer = setInterval(function () {
                    if (document.body != null) {
                        document.body.setAttribute(CONST.keySite, "1");
                        if (curSite.SiteTypeID == SiteType.BAIDU && location.href.indexOf("tn=news") >= 0) {
                            document.body.setAttribute("news", "1");
                        }else{
                            document.body.removeAttribute("news");
                        }
                        // clearInterval(bodyNameresetTimer);
                    }
                }, 300);
                let SiteBlock = {
                    /**
                     * 初始化Block样式
                     */
                    initStyle: function(){
                        AC_addStyle("button.ghhider.ghhb[ac-user-alter='1']::before{content:'取消 - ';}#sp-ac-container .ac-block-item{color:#AAA;margin-left:48px;}#sp-ac-container .ac-block-itemdel{float:right;margin-left:0;padding:0 20px;cursor:pointer;}#sp-ac-container .ac-block-itemdel:hover{color:red;}#sp-ac-container .ac-block-high{color:#000;}.ac-blockList li:hover{background-color:#a3caff;color:white !important;cursor:pointer;} *[ac-needhide] *{display:none} *[ac-needhide] .blockShow{display:unset;cursor:pointer;} *[ac-needhide] .blockShow:hover{border:1px solid #DDD}button.ghhider{color:#555;background-color:#fcfcfc;font-family:sans-serif;font-size:.85em;margin:auto 2px;border:1px solid #ccc;border-radius:4px;padding:2px 3px}h3>button.ghhider{font-size:.75em}button.ghhider:hover{color:#006aff;background:#fff}",
                            "AC-BlockStyle");
                    },
                    /**
                     * 初始化屏蔽按钮加载
                     */
                    init: function () {
                        let checkNodes = document.querySelectorAll(curSite.MainType+":not([acblock])");
                        for (let i = 0; i < checkNodes.length; i++) {
                            try{
                                let curNode = checkNodes[i];
                                let faviconNode = curNode.querySelector(curSite.FaviconType);
                                // if(curNode.hasAttribute("acblock")) continue;
                                let host = getBaiduHost(faviconNode);
                                // if(host == null) continue;
                                let faNode = curNode.querySelector(curSite.BlockType);
                                let nodeStyle = "display:unset;";
                                if(!ACConfig.isBlockBtnDisplay){
                                    nodeStyle = "display:none;";
                                }
                                faNode.insertAdjacentHTML("afterend", ``);

                                curNode.setAttribute("acblock", "0");
                                curNode.setAttribute("acblock", "0");
                            }catch (e) {
                            }
                        }
                        this.initListener();
                        this.renderDisplay();
                    },
                    initListener: function(){
                        let checkNodes = document.querySelectorAll("button.ghhider:not([acEnv])");
                        for(let i = 0; i < checkNodes.length; i++){
                            checkNodes[i].addEventListener("click", this.doHideEnv);
                            checkNodes[i].setAttribute("acEnv", "0");
                        }
                    },
                    doHideEnv: function(env){
                        // 先插入数据---记得还要写入存储
                        let node = env.sourceTarget || env.target;
                        let host = node.dataset.host;
                        if(node.getAttribute("ac-user-alter") == 1){
                            // 已经屏蔽之后,再次点击block应该是取消状态
                            node.removeAttribute("ac-user-alter");
                            ACConfig.UserBlockList.acremove(host);
                            GM.setValue("Config", JSON.stringify(ACConfig)); // 点击一次,保存一次
                        }else{
                            // 正常屏蔽操作
                            node.removeAttribute("ac-user-alter");
                            ACConfig.UserBlockList.acpush(host);
                            GM.setValue("Config", JSON.stringify(ACConfig)); // 点击一次,保存一次
                        }
                        reloadBlockList();
                        SiteBlock.renderDisplay();
                        env.stopPropagation();
                    },
                    // 刷新显示效果--耗时操作
                    renderDisplay: function(){
                        let checkNodes = document.querySelectorAll(curSite.MainType);
                        let flag = "ac-needhide";
                        for (let i = 0; i < checkNodes.length; i++) {
                            try{
                                let curNode = checkNodes[i];
                                let curHost = getBaiduHost(curNode.querySelector(curSite.FaviconType));
                                if(curHost == null) continue;
                                {
                                    let BlockBtn = curNode.querySelector(".ghhider.ghhb");
                                    BlockBtn.dataset.host = BlockBtn.dataset.meta = curHost;
                                }
                                if(curNode.querySelector("button[ac-user-alter]") != null) continue; // 用户手动点过显示的,那么跳过check
                                if(ACConfig.UserBlockList.findIndex(
                                    m => {
                                        try {
                                            return new RegExp(m.replace("*", ".*")).test(curHost);
                                        }catch(e){
                                            return m == curHost;
                                        }
                                    }
                                ) >= 0){
                                    // 只检查在屏蔽表中的数据
                                    if(! curNode.hasAttribute(flag)){
                                        if(ACConfig.isBlockDisplay){
                                            curNode.remove();
                                            continue;
                                        }
                                        let curTitle = curNode.querySelector(curSite.BlockType);
                                        curTitle = curTitle.innerText || curTitle.textContent;
                                        curNode.insertAdjacentHTML("afterBegin", `${curTitle}      -block by ${curHost}`);
                                        curNode.setAttribute(flag, "1");
                                        (function(xcur){
                                            // 已经屏蔽之后的内容,点击一下显示原始内容
                                            xcur.querySelector(".blockShow").addEventListener("click", function (env) {
                                                this.parentNode.querySelector("button.ghhider").setAttribute("ac-user-alter", "1"); // 这个属性用于保持在DOM更新时,按钮不变
                                                xcur.removeAttribute(flag);
                                                safeFunction(function(){
                                                    xcur.querySelector(".blockShow").remove();
                                                });
                                                env.stopPropagation();
                                            });
                                        })(curNode);
                                    }
                                }else{
                                    curNode.removeAttribute(flag);
                                    safeFunction(function(){
                                        curNode.querySelector(".blockShow").remove();
                                    });
                                }
                            }catch (e) {
                            }
                        }
                    }
                };
                function addStyle(css) { //添加CSS的代码--copy的
                    let pi = document.createProcessingInstruction(
                        'xml-stylesheet',
                        'type="text/css" must="false" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"'
                    );
                    return document.insertBefore(pi, document.documentElement);
                }

                if (ACConfig.isAdsEnable) {
                    // display已经无法隐藏他们了,需要用绝对的隐藏
                    addStyle("#bottomads{display:none;} #content_left>div:not([id])>div[cmatchid], #content_left>div[id*='300']:not([class*='result']),#content_right td>div:not([id]),#content_right>br{position:absolute;top:-6666px;}");
                }
                if (curSite.SiteTypeID == SiteType.GOOGLE && ACConfig.isGooleInBaiduModeEnable){
                    safeWaitFunc("#logo img, #logocont img", function(node){
                        let faNode = node.parentNode.parentNode;
                        faNode.classList.add("baidu");
                        node.removeAttribute("src");
                        node.src = "https://pic.rmb.bdstatic.com/c86255e8028696139d3e3e4bb44c047b.png";
                        node.width = "125";
                        node.removeAttribute("height");
                    });
                    safeWaitFunc("#main .logo img[alt='Google']", function(node){
                        node.removeAttribute("srcset");
                        node.src = "https://www.baidu.com/img/bd_logo1.png?where=super";
                        node.setAttribute("height", "129");
                        node.style = "padding-top: 59px;";
                    }, 300);
                    safeWaitFunc("form[role='search'] .logo img", function(node){
                        node.removeAttribute("srcset");
                        node.src = "https://www.baidu.com/img/bd_logo1.png?where=super";
                        node.setAttribute("height", "129");
                        node.style = "padding-top: 59px;";
                    }, 300);
                    document.title = document.title.replace(/^Google/, "百度一下,你就知道")
                        .replace(/ - Google 搜索/, "_百度搜索")
                        .replace(/ - Google Search/, "_百度搜索");
                    safeWaitFunc("head", function(){
                        console.log("缇欧换");
                        let linkTarget = document.querySelector("link[type='image/x-icon']") || document.createElement('link');
                        linkTarget.type = 'image/x-icon';
                        linkTarget.rel = 'shortcut icon';
                        linkTarget.href = 'https://www.baidu.com/favicon.ico';
                        document.head.appendChild(linkTarget);
                    })
                }
                try {
                    if (curSite.SiteTypeID != SiteType.OTHERS) {
                        document.addEventListener('DOMNodeInserted', MainCallback, false);
                        document.addEventListener('keyup', MainCallback, false);
                        RAFFunction(function(){
                            rapidDeal(); // 定期调用,避免有时候DOM插入没有执行导致的问题
                        }, 800);
                    }
                } catch (e) {
                    console.log(e);
                }

                function MainCallback(e) {
                    if (e.target != null && typeof(e.target.className) == "string" && e.target.className.toUpperCase().indexOf("AC-") == 0) {
                        return;
                    } //屏蔽掉因为增加css导致的触发insert动作
                    rapidDeal();
                }

                function ShowSearchBox(){
                    // TODO 待完成
                }
                /*以下代码大部分来源于SuprePreloader 感谢 swdyh && ywzhaiqi && NLF 以及 mach6 大佬*/
                function ac_spfunc(e){
                    e.stopPropagation();
                    var t, r = e.currentTarget;
                    var Tween = {
                        Linear: function Linear(e, t, r, n) {
                            return r * e / n + t;
                        },
                        Quad: {
                            easeIn: function easeIn(e, t, r, n) {
                                return r * (e /= n) * e + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return -r * (e /= n) * (e - 2) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return (e /= n / 2) < 1 ? r / 2 * e * e + t : -r / 2 * (--e * (e - 2) - 1) + t;
                            }
                        },
                        Cubic: {
                            easeIn: function easeIn(e, t, r, n) {
                                return r * (e /= n) * e * e + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return r * ((e = e / n - 1) * e * e + 1) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return (e /= n / 2) < 1 ? r / 2 * e * e * e + t : r / 2 * ((e -= 2) * e * e + 2) + t;
                            }
                        },
                        Quart: {
                            easeIn: function easeIn(e, t, r, n) {
                                return r * (e /= n) * e * e * e + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return -r * ((e = e / n - 1) * e * e * e - 1) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return (e /= n / 2) < 1 ? r / 2 * e * e * e * e + t : -r / 2 * ((e -= 2) * e * e * e - 2) + t;
                            }
                        },
                        Quint: {
                            easeIn: function easeIn(e, t, r, n) {
                                return r * (e /= n) * e * e * e * e + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return r * ((e = e / n - 1) * e * e * e * e + 1) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return (e /= n / 2) < 1 ? r / 2 * e * e * e * e * e + t : r / 2 * ((e -= 2) * e * e * e * e + 2) + t;
                            }
                        },
                        Sine: {
                            easeIn: function easeIn(e, t, r, n) {
                                return -r * Math.cos(e / n * (Math.PI / 2)) + r + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return r * Math.sin(e / n * (Math.PI / 2)) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return -r / 2 * (Math.cos(Math.PI * e / n) - 1) + t;
                            }
                        },
                        Expo: {
                            easeIn: function easeIn(e, t, r, n) {
                                return 0 == e ? t : r * Math.pow(2, 10 * (e / n - 1)) + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return e == n ? t + r : r * (1 - Math.pow(2, -10 * e / n)) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return 0 == e ? t : e == n ? t + r : (e /= n / 2) < 1 ? r / 2 * Math.pow(2, 10 * (e - 1)) + t : r / 2 * (2 - Math.pow(2, -10 * --e)) + t;
                            }
                        },
                        Circ: {
                            easeIn: function easeIn(e, t, r, n) {
                                return -r * (Math.sqrt(1 - (e /= n) * e) - 1) + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return r * Math.sqrt(1 - (e = e / n - 1) * e) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return (e /= n / 2) < 1 ? -r / 2 * (Math.sqrt(1 - e * e) - 1) + t : r / 2 * (Math.sqrt(1 - (e -= 2) * e) + 1) + t;
                            }
                        },
                        Elastic: {
                            easeIn: function easeIn(e, t, r, n, a, o) {
                                return 0 == e ? t : 1 == (e /= n) ? t + r : (o || (o = .3 * n), !a || a < Math.abs(r) ? (a = r,
                                    i = o / 4) : i = o / (2 * Math.PI) * Math.asin(r / a), -a * Math.pow(2, 10 * (e -= 1)) * Math.sin((e * n - i) * (2 * Math.PI) / o) + t);
                                var i;
                            },
                            easeOut: function easeOut(e, t, r, n, a, o) {
                                return 0 == e ? t : 1 == (e /= n) ? t + r : (o || (o = .3 * n), !a || a < Math.abs(r) ? (a = r,
                                    i = o / 4) : i = o / (2 * Math.PI) * Math.asin(r / a), a * Math.pow(2, -10 * e) * Math.sin((e * n - i) * (2 * Math.PI) / o) + r + t);
                                var i;
                            },
                            easeInOut: function easeInOut(e, t, r, n, a, o) {
                                return 0 == e ? t : 2 == (e /= n / 2) ? t + r : (o || (o = n * (.3 * 1.5)), !a || a < Math.abs(r) ? (a = r,
                                    i = o / 4) : i = o / (2 * Math.PI) * Math.asin(r / a), e < 1 ? a * Math.pow(2, 10 * (e -= 1)) * Math.sin((e * n - i) * (2 * Math.PI) / o) * -.5 + t : a * Math.pow(2, -10 * (e -= 1)) * Math.sin((e * n - i) * (2 * Math.PI) / o) * .5 + r + t);
                                var i;
                            }
                        },
                        Back: {
                            easeIn: function easeIn(e, t, r, n, a) {
                                return null == a && (a = 1.70158), r * (e /= n) * e * ((a + 1) * e - a) + t;
                            },
                            easeOut: function easeOut(e, t, r, n, a) {
                                return null == a && (a = 1.70158), r * ((e = e / n - 1) * e * ((a + 1) * e + a) + 1) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n, a) {
                                return null == a && (a = 1.70158), (e /= n / 2) < 1 ? r / 2 * (e * e * ((1 + (a *= 1.525)) * e - a)) + t : r / 2 * ((e -= 2) * e * ((1 + (a *= 1.525)) * e + a) + 2) + t;
                            }
                        },
                        Bounce: {
                            easeIn: function easeIn(e, t, r, n) {
                                return r - Tween.Bounce.easeOut(n - e, 0, r, n) + t;
                            },
                            easeOut: function easeOut(e, t, r, n) {
                                return (e /= n) < 1 / 2.75 ? r * (7.5625 * e * e) + t : e < 2 / 2.75 ? r * (7.5625 * (e -= 1.5 / 2.75) * e + .75) + t : e < 2.5 / 2.75 ? r * (7.5625 * (e -= 2.25 / 2.75) * e + .9375) + t : r * (7.5625 * (e -= 2.625 / 2.75) * e + .984375) + t;
                            },
                            easeInOut: function easeInOut(e, t, r, n) {
                                return e < n / 2 ? .5 * Tween.Bounce.easeIn(2 * e, 0, r, n) + t : .5 * Tween.Bounce.easeOut(2 * e - n, 0, r, n) + .5 * r + t;
                            }
                        }
                    }, TweenM = [ "Linear", "Quad", "Cubic", "Quart", "Quint", "Sine", "Expo", "Circ", "Elastic", "Back", "Bounce" ], TweenEase = [ "easeIn", "easeOut", "easeInOut" ];
                    var prefs = {
                        s_method: 3,
                        s_ease: 2,
                        s_FPS: 60,
                        s_duration: 333,
                    };
                    function getRelativeDiv(e) {
                        var t = r.id;
                        return (t = t.replace(/(sp-separator-)(.+)/, (function(t, r, n) {
                            return r + String(Number(n) + ("pre" == e ? -1 : 1));
                        }))) ? document.getElementById(t) : null;
                    }
                    function sp_transition(e, t) {
                        var r = sp_transition.TweenF;
                        r || (r = (r = Tween[TweenM[prefs.s_method]])[TweenEase[prefs.s_ease]] || r, sp_transition.TweenF = r);
                        var n = 1e3 / prefs.s_FPS, a = 0, o = e, i = t - e, s = Math.ceil(prefs.s_duration / n), c = window.scrollX;
                        !function transition() {
                            var e = Math.ceil(r(a, o, i, s));
                            window.scroll(c, e), a < s && (a++, setTimeout(transition, n));
                        }();
                    }
                    function scrollIt(e, t) {
                        sp_transition(e, t);
                    }
                    switch (e.target.id) {
                        case "sp-sp-gotop":
                            scrollIt(window.scrollY, 0);
                            break;

                        case "sp-sp-gopre":
                            var n = getRelativeDiv("pre");
                            if (!n) return;
                            t = window.scrollY;
                            var a = n.getBoundingClientRect().top;
                            a = t - (r.getBoundingClientRect().top - a);
                            scrollIt(t, a);
                            break;

                        case "sp-sp-gonext":
                            var o = getRelativeDiv("next");
                            if (!o) return;
                            t = window.scrollY;
                            var i = o.getBoundingClientRect().top;
                            i = t + (-r.getBoundingClientRect().top + i);
                            scrollIt(t, i);
                            break;

                        case "sp-sp-gobottom":
                            scrollIt(window.scrollY, Math.max(document.documentElement.scrollHeight, document.body.scrollHeight));
                    }
                }
                function windowscroll( fn ) {
                    var beforeScrollTop = document.documentElement.scrollTop,
                        fn = fn || function() {};
                    window.addEventListener("scroll", function(e) {
                        var afterScrollTop = document.documentElement.scrollTop,
                            delta = afterScrollTop - beforeScrollTop;
                        if( delta === 0 ) return false;
                        fn( delta > 0 ? "down" : "up" , e);
                        beforeScrollTop = afterScrollTop;
                    }, false);
                }
                windowscroll(function(direction, e){
                    if(direction === "down"){ // 下滑才准备翻页
                        let spl = document.querySelector("#sp-fw-a_enable");
                        // 开启后,且在非(suprepreloader启用)时均可
                        if(ACConfig.isAutopage == true && !(spl && spl.checked == true)){
                            var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;
                            let scrollDelta = 666;
                            if(curSite.SiteTypeID == SiteType.GOOGLE) scrollDelta = 1024; // 毕竟谷歌加载缓慢的问题
                            if(document.documentElement.scrollHeight <= document.documentElement.clientHeight + scrollTop + scrollDelta && curSite.pageLoading == false) {
                                curSite.pageLoading = true;
                                ShowPager.loadMorePage();
                            }
                        }
                    }
                });
                var ShowPager = {
                    getFullHref: function(e) {
                        "string" != typeof e && (e = e.getAttribute("href"));
                        var t = this.getFullHref.a;
                        return t || (this.getFullHref.a = t = document.createElement("a")), t.href = e, t.href;
                    },
                    createDocumentByString : function(e) {
                        if (e) {
                            if ("HTML" != document.documentElement.nodeName) return (new DOMParser).parseFromString(e, "application/xhtml+xml");
                            var t;
                            try {
                                t = (new DOMParser).parseFromString(e, "text/html");
                            } catch (e) {}
                            if (t) return t;
                            if (document.implementation.createHTMLDocument) t = document.implementation.createHTMLDocument("superPreloader"); else try {
                                (t = document.cloneNode(!1)).appendChild(t.importNode(document.documentElement, !1)),
                                    t.documentElement.appendChild(t.createElement("head")), t.documentElement.appendChild(t.createElement("body"));
                            } catch (e) {}
                            if (t) {
                                var r = document.createRange();
                                r.selectNodeContents(document.body);
                                var n = r.createContextualFragment(e);
                                t.body.appendChild(n);
                                for (var a, o = {
                                    TITLE: !0,
                                    META: !0,
                                    LINK: !0,
                                    STYLE: !0,
                                    BASE: !0
                                }, i = t.body, s = i.childNodes, c = s.length - 1; c >= 0; c--) o[(a = s[c]).nodeName] && i.removeChild(a);
                                return t;
                            }
                        } else console.error("[AC-Script]", "没有找到要转成DOM的字符串");
                    },
                    loadMorePage : function() {
                        if(curSite.pager){
                            let curPageEle = getElementByXpath(curSite.pager.nextLink);
                            var url = this.getFullHref(curPageEle);
                            var sepImgs = {
                                top: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAWtJREFUeNrclE0rRGEUx8c1GUpRJIVIZGdhZCVr38GGhaI0ZXwCkliglChZEcvJxhdgYWOjLEUpm/EyiLzze+o8dTzdO3PljoVTv7rPc8/5d+6555xYrEhWop6boda5+6l9wjWcWpF+WIbqCJJ9hFRcDr3QAIkIhKugz5PDfkSixkphz5aiAnqgE8rgWRxGoSOPyBkswQuUwyscw4HrmFCZL8Kt/JAg7mEFPEmo4FdPwk0BUcsdzIap0TQ8qMAPuICcEjLnd+VjSjcfJNgIc/DkZGSymYGsnK9EZMrxe4MFaNGiZjC2fT5zQ3p7QDK1dR2GSljziclAvRUe8nHYVA4jjvC43NfAuk/smB2QNqcsWxKcLbAKTFnS0hWD6n27Fd6FLqiDI5iQmQ9jpiVT0sNJ6aYd7dAE3QHBbinSAX5JWWaxuLo8F35jh/bBK9Y+/r/Cl6pLcnna8NvuDGMnslpbZRpXZYT/3r4EGACZL3ZL2afNFAAAAABJRU5ErkJggg==",
                                bottom: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAXFJREFUeNrM1c8rBGEcx/FdtCEkLqYtpdwkKSUHUhxwITdK+Z3yM2cOLnJ39Cc44SgHScmJwlFxsIdlCScO6/2t76Onp52dXTtbnno1M8+Pz84+zzMzkcg/KA3oRTzM0A4cI4VTdIUVPIM3pPGO5aABJTkGx1BqjYmFFZxW7nnBwXmXogWX6bEGc2jEIU7+kNWDUSSwZyqndSvJ3N1g2Bm0oLtB2j+w7rQP4MpqXzRT0YRaPW/BthMedYLs60HsoE2vq9BsPwAJa8XFLUa0fUrvROo/saT1Q9adGimdlt8yj6TT6Q6d2vaida9YRbtP6EqmBZC5fHA6X+AAz1bwEc6cfk9+oaZM4NoZJL70+J2hTaZtNpet041zK8yP/Mgl+rOF1emr0UM1xnAfEPyISd0Jno6vtx+QuM6PZ22lpO7dbEV2Siv6rPeIjNs1HdYC7ixfG+YBqdTVDqPIv6iIWvO7iXGUFxAqi72PraJ9IH8EGACQcYjYRd5GHwAAAABJRU5ErkJggg==",
                                pre: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAASlJREFUeNpiYBjOoBiIrwJxFRAzUsvQViD+CMT/gfgTEPdRy9BPUENh+AsQ91JiaAuSS9HxZ3INb8Hi0v+UurwF6qL/ROBvQNxDrKFfkTT+A+JnQPwBKfJA/L9Ian7ic7kMEHcC8Q80F3UAcRsQv4by30INaUJT9weaWhSQDRUB4uVYvLkYiAWAOBopvEFBlArEPEA8G4ue9UAsATM4EYuCJUgKMtAMLoSKCwPxXCx6c1igClTQgmUZVPNrHMEGy3mgYCkCYiYgTkCSV4UZvA2IjYBYDIgvQbPvOyJTECid5wHxbyA2BuL3QLwRWYEsEJvg0IweFEU41IEMlgcxWJAEH0MxJeAsjMFEq6Jw+Br8BimVfMCTDEkG7EBcA8T3oWUJx4DVYwABBgCannnSzbgwIQAAAABJRU5ErkJggg==",
                                next: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAT1JREFUeNrc1b1KA0EYheEl/iARFFEkKl6D0UK8CrEVrCwEexFCtBIlRWIjsfEiLL0FKzs7QUWxM2piFMUkvhPOwLAs2TGuCn7wkNll5jC7+w0Jgv9avdjAObbQn1TwCu7QwhWW4xakPIOHMKzxGCaSCm6ioXHLZ0Hqpz7KrwRPIvvNvBlM2zYyNY8cMjhDHo9fCBzErnIqKNjgRSxpvIABbOLes2MKWHfuXdhXcR2avKrJ4zGhI9gLhQbq9XaZgGO1kutIOzIHpKp7NawhjYOINSeY6lFwHacw17P6NTWHd4xqnNbcS83LObtsaCPbEW+gXUW8ODswC27xoOsn3ODDmfOGss9XLuE54jGjvPqGuuG1mFDzZIfdNHynnde7DbW1r5DwTstJHP2iE55YqD36ebXZDvr+7L/sU4ABAIpVZWnoA5GkAAAAAElFTkSuQmCC",
                                next_gray: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAtxJREFUeNrclc9L2mEcx7/6NbVZqRVj7pIOlIUuZ1HMgv0BDcqT7JrskH13ELPBF7eTvz10HznWQBlBRIfBXIfBLmqXscvYZWPKrMNIU9Apmrr34/w6i0ovMZjw+H0+z/N8Xt+Pn/fn80hR/+WHYRhBIpFwRKPRz/F4/KnD4RB28xH0Ah4cHHyoUCjsIpFIIZPJHkml0m9Yfn2ZD78XcL1eH6rValIMCmMUtqKbD7/HbNQxaq15oxcH/lXpcmXgtnh2u/2mXC6/DqE+sSxLlUqlniE0TVPBYJAqFot6+GV9Pt+PJthms80sLS2xEonkhlgs/jgwMOBcXV3N5fP5rlCcp9bX1yWLi4uecrk8U6lUshDY3wRbLJYFGKZsNksq4N78/LwY9hOn05k5Ojqi+PzTGePxeFwZUl6vd8hkMvkPDg6sZJ2M5eXlr1wqUu2kA5JOpy2IAO+oO9fW1n5mMpk2nDjmcjkKNU25XC652Wx2pVIp65mXJ2nyjUPpqakpNZxuA8Y5T87OzsobjcYHpVKpGhsbe1CtVkXYqxQKhTdqtfqL1Wr1JpPJxxyU5Lq/vz8aCoX8TTDatYiFhF6vxx5tAJwm8OPj48m5ubmKSqUaAWwSa9eQw6JGo/luNBoNh4eHbAe0JhAINsLh8LNAIJCiudhxB+Qh2ludTifDAQLvI3AIch+Rkl8jJlrhCbOqgfoLmDepOF/BfGNra2sFFZFtvqgzMbFYjAiyp9Vqh4VC4cTJyYmQ90epIQJtHRO1bA5aRhAvdnZ2GI/H87cEz5YPgeOS2RsfHx9B7u+gOi68yQAtYX9zd3eXgZCna/s8By5ypGUUzhOISHgO9BfWXwG6chZ6IbiVc6LwnsFgGIVAepLzjk4rYW1ze3ubcbvd53fjZV2FaqGQ63fT09PDMO9i9BEoon0J9Rm/339xm3dr2f39fVLX7wFvoMVvoYWfRyIRFndD/Z/8nf0WYAA8EC1Z/ZNm4gAAAABJRU5ErkJggg==",
                                pre_gray: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAslJREFUeNrclTtMWmEUxz/uvTzlIUhpNMR0aGNjrNHSmHTqRJyadujQDbSGRwJUaYCmDizqUEw6ODVNGgbpYCfSpFINCQzFR9oyMXRsXFCsAXkIKNL/R7gGWxOsSdPEk5zc3O+e87vn+59zv0vIpbSJiQmyubn5LBKJpNbX11+4XC5Buxy2XYDNZiMOh2OW4ziPTCbTi8XikeHh4SsSieQTXnIxsN1uJ1ardVYgEDgPDw+V9Xqd1Go1Mcuyg7AuuVy+sra29ndgVEnGx8dnhEKhs1qtKgE/eXZ8fCzC+q3+/n6tSqVaSSQS5wM7nU5iMplmsF1XpVI5BeXt6OhIBFkGAe9SKpV/wNmzKjWbzRT6tFwuK86CUqPrkIVWPjQwMKBWKBSn4Ozv0LGxsRmRSDSFSjua0Do8TRWAS+B5+B68g/IhixCNvQPN1WjuieZsS/f1aNQ0wzBuaCqlUCQRtVr9Es1K4kVDWJNhrQjAIiqMlkqle804FnkjBoOhEzv4vrGxkW2ALRaLFrq+QoAV2nE8tLe3dzEYDE5vb2939vX1PcBkiKVSaQ1jForFYq+NRqMum83ebsYzmJq7sGu4xhkKxsDfB/AxnO860ev1oeXlZU8gEMgmk0kFqmw8o9dUKiWfn58vhMPh54h7S+OpQXNSLBYfejyeR1yzw9dbRon09PS8W11dnfL5fJl8Pk+0Wi3hk5vyCNBY4vV6f0Im9+joKJNOp818o8G70ah4aWnpIzSKYCa/dXd3B+PxuHNycjKzs7NzAms1+qFQy+VydDRz0WjUpdPp3tB8TFM0FAqFGxXPzc19plJrNJqraMoXt9tNt3Suc+Tg4ICeJfmFhQVLoVAwoKG7fr//B8cHAL6Fy9ZFDinaG/r5w77ya8y/OhEvKRhjtIup2YMTeBb3mXY53HnAmNkP+/v7NzHTTwAO4f79f/ud/RJgAOLcRNZqLojMAAAAAElFTkSuQmCC",
                            };
                            AC_addStyle(".sp-separator{line-height:1.8 !important;opacity:1 !important;position:relative !important;float:none !important;top:0 !important;left:0 !important;min-width:366px;width:auto;text-align:center !important;font-size:14px !important;display:block !important;padding:3px 0 !important;margin:5px 10px 8px;clear:both !important;border-style:solid !important;border-color:#cccccc !important;border-width:1px !important;-moz-border-radius:30px !important;border-radius:30px !important;background-color:#ffffff !important;}.sp-separator:hover{box-shadow:0 0 11px rgba(33,33,33,0.2);}#sp-separator-hover{display:none;}.sp-separator:hover #sp-separator-hover{display:block;}.sp-separator .sp-someinfo{position:absolute !important;right:10px !important;font-size:12px !important;font-style:italic !important;background:none !important;}.sp-separator span{vertical-align: middle;cursor: pointer;padding: 0;margin: 0 5px;display: inline-block; width:22px;height:22px;}.sp-separator a{margin:0 20px 0 -6px !important;display:inline !important;text-shadow:#fff 0 1px 0 !important;background:none !important;color:#595959 !important;}.sp-separator input{padding:0 !important;line-height:23px !important;}.sp-separator .sp-md-span{font-weight:bold !important;margin:0 20px !important;}#sp-sp-md-number{width:6ch !important;vertical-align:middle !important;display:inline-block !important;text-align:left !important;}"+
                                `.ac_sp_top{background-image:url('${sepImgs.top}')}`+
                                `.ac_sp_pre{background-image:url('${sepImgs.pre}')}`+
                                `.ac_sp_next{background-image:url('${sepImgs.next}')}`+
                                `.ac_sp_bottom{background-image:url('${sepImgs.bottom}')}`+
                                `.ac_sp_next_gray{background-image:url('${sepImgs.next_gray}')}`+
                                `.ac_sp_pre_gray{background-image:url('${sepImgs.pre_gray}')}`,
                                "AC-Preload")
                            if(curSite.pageUrl === url){
                                console.error("[AC-Script]", "翻页到达底部了 - 或者异常 - 出现异常请直接反馈作者修改");
                                return;
                            }// 不会重复加载相同的页面
                            curSite.pageUrl = url;
                            // 对url的数据进行读取
                            curSite.pager.startFilter && curSite.pager.startFilter();
                            GM_xmlhttpRequest({
                                url: url,
                                method: "GET",
                                timeout: 5000,
                                onload: function (response) {
                                    try{
                                        var newBody = ShowPager.createDocumentByString(response.responseText);
                                        let pageElems = getAllElements(curSite.pager.pageElement, newBody);
                                        let toElement = getAllElements(curSite.pager.HT_insert[0])[0];
                                        if(pageElems.length >= 0){
                                            // 处理最后一个翻页按钮
                                            let nextEs = document.querySelectorAll("#sp-sp-gonext");
                                            if(nextEs.length > 0){
                                                let lastE = nextEs[nextEs.length-1];
                                                lastE.classList.replace("ac_sp_next_gray", "ac_sp_next");
                                            }
                                            // 插入翻页按钮元素
                                            curSite.pageNum++;
                                            let addTo = "beforeend";
                                            if(curSite.pager.HT_insert[1] == 1) addTo = "beforebegin";
                                            toElement.insertAdjacentHTML(addTo, ``
                                                .replace(/ACX/gm, curSite.pageNum));
                                            // 插入新页面元素
                                            pageElems.forEach(function(one){
                                                toElement.insertAdjacentElement(addTo, one);
                                            });
                                            document.querySelectorAll(".sp-separator.AC:not([bind])").forEach(function(per){
                                                per.setAttribute("bind", 1);
                                                per.addEventListener("click", ac_spfunc);
                                            });
                                            // 替换待替换元素
                                            try {
                                                let oriE = getAllElements(curSite.pager.replaceE);
                                                let repE = getAllElements(curSite.pager.replaceE, newBody);
                                                if(oriE.length == repE.length){
                                                    for(var i = 0; i < oriE.length; i++){
                                                        oriE[i].innerHTML = repE[i].innerHTML;
                                                    }
                                                }
                                            }catch (e) {
                                                console.log(e);
                                            }
                                        }
                                    }catch (e) {
                                        console.log(e);
                                    }
                                    curSite.pageLoading = false;
                                },
                                onerror:function(){
                                    curSite.pageLoading = false;
                                }
                            });
                        }
                    },
                };

                function AutoRefresh() {
                    if (!ACConfig.isRightDisplayEnable) {
                        // 移除右边栏 -注意在#wrapper>#con-at>#result-op xpath-log有时候很重要,不能隐藏
                        AC_addStyle("#content_right{display:none !important;}#content_right td>div:not([id]){display:none;}#content_right .result-op:not([id]){display:none!important;}#rhs{display:none;}",
                            "AC-RightRemove");
                    } else {
                        if (CONST.AdsStyleMode == 2) {
                            // 非双列模式下尽可能的显示右侧栏
                            AC_addStyle("@media screen and (min-width: 1250px) {#container{width: 80% !important;}.container_l #content_right{margin-right: calc(18% - 210px);position: absolute;right: -200px;display:block !important;overflow:hidden;width: 22vw !important;}",
                                "AC-RightRemove");
                        }
                    }
                    if (!ACConfig.isALineEnable) {
                        AC_addStyle("a,a em{text-decoration:none}", "AC-NoLine");// 移除这些个下划线
                    }
                    if (ACConfig.isUserStyleEnable) {
                        AC_addStyle(ACConfig.UserStyleText, "AC-userStyle");// 用户自定义的样式表
                    }
                    AC_addStyle(
                        ".opr-recommends-merge-imgtext{display:none!important;}" + // 移除百度浏览器推广
                        ".res_top_banner{display:none!important;}" + // 移除可能的百度HTTPS劫持显示问题
                        ".headBlock, body>div.result-op{display:none;}" // 移除百度的搜索结果顶部一条的建议文字 & 移除可能出现的白屏现象
                        , "AC-special-BAIDU"
                    );
                    /*"自定义"按钮效果*/
                    AC_addStyle(".newFuncHighLight{color:red;font-weight: 100;background-color: yellow;font-weight: 600;}#sp-ac-container label{display:inline;}#u{width:319px}#u #myuser{display:inline}#myuser,#myuser .myuserconfig{padding:0;margin:0}#myuser{display:inline-block;}#myuser .myuserconfig{display:inline-block;line-height:1.5;background:#2866bd;color:#fff;font-weight:700;text-align:center;padding:6px;border:2px solid #E5E5E5;}#myuser .myuserconfig{box-shadow:0 0 10px 3px rgba(0,0,0,.1)}#myuser .myuserconfig:hover{background:#2970d4 !important;color:#fff;cursor:pointer;border:2px solid #73A6F8;}",
                        "AC-MENU_Btn");
                    /*自定义页面内容效果*/
                    AC_addStyle('body[baidu]  #sp-ac-container .container-label:not([class*="baidu"])>label,\n' +
                        '   body[google] #sp-ac-container .container-label:not([class*="google"])>label,\n' +
                        '   body[bing]   #sp-ac-container .container-label:not([class*="bing"])>label,\n' +
                        '   body[sogou]   #sp-ac-container .container-label:not([class*="sogou"])>label,\n' +
                        '   body[baidu]  #sp-ac-container .container-label:not([class*="baidu"])>br,\n' +
                        '   body[google] #sp-ac-container .container-label:not([class*="google"])>br,\n' +
                        '   body[bing]   #sp-ac-container .container-label:not([class*="bing"])>br,\n' +
                        '   body[sogou]   #sp-ac-container .container-label:not([class*="sogou"])>br,\n' +
                        '   body[baidu]  #sp-ac-container .container-label[class*="baidu"]>labelhide,\n' +
                        '   body[google] #sp-ac-container .container-label[class*="google"]>labelhide,\n' +
                        '   body[bing] #sp-ac-container .container-label[class*="bing"]>labelhide,\n' +
                        '   body[sogou]   #sp-ac-container .container-label[class*="sogou"]>labelhide\n' +
                        '{' +
                        'display:none;\n' +
                        '}#sp-ac-container labelHide{cursor:pointer;margin-left:8%;color:blue}#sp-ac-container .linkhref,#sp-ac-container labelHide:hover{color:red}#sp-ac-container .linkhref:hover{font-weight:bold}#sp-ac-container label.menu-box-small{max-width:16px;max-height:16px;cursor:pointer;display:inline-block}.AC-CounterT{background:#FD9999}body > #sp-ac-container{position:fixed;top:3.9vw;right:8.8vw}#sp-ac-container{z-index:999999;text-align:left;background-color:white}#sp-ac-container *{font-size:13px;color:black;float:none}#sp-ac-main-head{position:relative;top:0;left:0}#sp-ac-span-info{position:absolute;right:1px;top:0;font-size:10px;line-height:10px;background:none;font-style:italic;color:#5a5a5a;text-shadow:white 0px 1px 1px}#sp-ac-container input{vertical-align:middle;display:inline-block;outline:none;height:auto;padding:0px;margin-bottom:0px;margin-top:0px}#sp-ac-container input[type="number"]{width:50px;text-align:left}#sp-ac-container input[type="checkbox"]{border:1px solid #B4B4B4;padding:1px;margin:3px;width:13px;height:13px;background:none;cursor:pointer;visibility:visible;position:static}#sp-ac-container input[type="button"]{border:1px solid #ccc;cursor:pointer;background:none;width:auto;height:auto}#sp-ac-container li{list-style:none;margin:3px 0;border:none;float:none;cursor:default;}#sp-ac-container fieldset{border:2px groove #ccc;-moz-border-radius:3px;border-radius:3px;padding:4px 9px 6px 9px;margin:2px;display:block;width:auto;height:auto}#sp-ac-container legend{line-height:20px;margin-bottom:0px}#sp-ac-container fieldset > ul{padding:0;margin:0}#sp-ac-container ul#sp-ac-a_useiframe-extend{padding-left:40px}#sp-ac-rect{position:relative;top:0;left:0;float:right;height:10px;width:10px;padding:0;margin:0;-moz-border-radius:3px;border-radius:3px;border:1px solid white;-webkit-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3),0 0 3px rgba(0,0,0,0.8);-moz-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3),0 0 3px rgba(0,0,0,0.8);box-shadow:inset 0 5px 0 rgba(255,255,255,0.3),0 0 3px rgba(0,0,0,0.8);opacity:0.8}#sp-ac-dot,#sp-ac-cur-mode{position:absolute;z-index:9999;width:5px;height:5px;padding:0;-moz-border-radius:3px;border-radius:3px;border:1px solid white;opacity:1;-webkit-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3),0px 1px 2px rgba(0,0,0,0.9);-moz-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3),0px 1px 2px rgba(0,0,0,0.9);box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3),0px 1px 2px rgba(0,0,0,0.9)}#sp-ac-dot{right:-3px;top:-3px}#sp-ac-cur-mode{left:-3px;top:-3px;width:6px;height:6px}#sp-ac-content{padding:0;margin:0px;-moz-border-radius:3px;border-radius:3px;border:1px solid #A0A0A0;-webkit-box-shadow:-2px 2px 5px rgba(0,0,0,0.3);-moz-box-shadow:-2px 2px 5px rgba(0,0,0,0.3);box-shadow:-2px 2px 5px rgba(0,0,0,0.3)}#sp-ac-main{padding:5px;border:1px solid white;-moz-border-radius:3px;border-radius:3px;background-color:#F2F2F7;background:-moz-linear-gradient(top,#FCFCFC,#F2F2F7 100%);background:-webkit-gradient(linear,0 0,0 100%,from(#FCFCFC),to(#F2F2F7))}#sp-ac-foot{position:relative;left:0;right:0;min-height:20px}#sp-ac-savebutton{position:absolute;top:0;right:2px}#sp-ac-container .endbutton{margin-top:8px}#sp-ac-container .sp-ac-spanbutton{border:1px solid #ccc;-moz-border-radius:3px;border-radius:3px;padding:2px 3px;cursor:pointer;background-color:#F9F9F9;-webkit-box-shadow:inset 0 10px 5px white;-moz-box-shadow:inset 0 10px 5px white;box-shadow:inset 0 10px 5px white}#sp-ac-container .sp-ac-spanbutton:hover{background-color:#DDD}label[class="newFunc"]{color:blue}',
                        "AC-MENU_Page");
                }
                AutoRefresh();
                try {
                    GM_registerMenuCommand('AC-重定向脚本设置', function () {
                        document.querySelector("#sp-ac-content").style.display = 'block';
                    });
                } catch (e) {
                }

                function getSearchValue() {
                    let kvl = location.search.substr(1).split("&");
                    let searchV = "";
                    for(let i = 0; i < kvl.length; i++){
                        let value = kvl[i].replace(/^(wd|query|q)=/, "");
                        if(value != kvl[i]){
                            searchV = value;
                        }
                    }
                    //  '+' 百度、搜狗、必应、谷歌、好搜
                    searchV = searchV.replace("+", " ");
                    return searchV;
                }
                function rapidDeal() {
                    try {
                        if (insertLocked == false && curSite.SiteTypeID != SiteType.OTHERS) {
                            insertLocked = true;
                            InsertSettingMenu();
                            ShowSetting();
                            ACHandle(); // 处理主重定向
                            // AutoRefresh();
                            if (ACConfig.isAdsEnable) { // 放进来,减少卡顿
                                removeAD_baidu_sogou();
                            }
                            if (ACConfig.AdsStyleEnable) { // 单独不需要定时器-頻繁触发-载入css
                                FSBaidu();
                            }
                            if (ACConfig.isFaviconEnable) { // 显示favicon图标
                                addFavicon(document.querySelectorAll(curSite.FaviconType)); // 添加Favicon显示
                            }
                            if (ACConfig.doDisableSug) { // 不启用移动预测[默认]
                                acSetCookie("ORIGIN", 2, "www.baidu.com");
                                acSetCookie("ISSW", 1);
                                acSetCookie("ISSW", 1, "www.baidu.com");
                            } else {
                                // 启用移动预测-不知道为什么要设置两个-百度自己会变?,反正有效果
                                acSetCookie("ORIGIN", 1, "www.baidu.com");
                                acSetCookie("ISSW", 1);
                                acSetCookie("ISSW", 1, "www.baidu.com");
                            }
                            if (ACConfig.isAdsEnable) { // 移除多余的广告内容
                                removeAD_baidu_sogou();
                            }
                            if (ACConfig.isCounterEnable) { // 显示计数器
                                addCounter(document.querySelectorAll(curSite.CounterType));
                            }
                            if(ACConfig.isBlockEnable && curSite.SiteTypeID != SiteType.SOGOU){ // 启用屏蔽功能
                                SiteBlock.initStyle();
                                SiteBlock.init();
                            }
                            setTimeout(function () {
                                insertLocked = false;
                            }, 200);
                        }
                    } catch (e) {
                        console.log(e);
                    }
                    function acSetCookie(cname, cvalue, domain, exdays) {
                        exdays = exdays || 30;
                        let d = new Date();
                        domain = (domain ? "domain=" + domain : "") + ";";
                        d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000));
                        let expires = "expires=" + d.toUTCString();
                        document.cookie = cname + "=" + cvalue + "; " + domain + expires + ";path=/";
                    }
                }

                function AutoLoadCustomCSS(){ // 按键触发reload
                    var cssValue = document.querySelector("#sp-ac-userstyleTEXT").value;
                    AC_addStyle(cssValue, "AC-userStyle", "head", true); // 用户自定义的样式表
                }

                function getBaiduHost(sitetpNode){
                    if(curSite.SiteTypeID == SiteType.BAIDU){
                        var href = null;
                        if(sitetpNode instanceof HTMLElement){
                            href = sitetpNode.getAttribute("href")
                        }
                        if(href != null && href.indexOf("baidu.com/link") < 0){
                            // 已经解析出来了
                            return getHost(href);
                        }
                    }
                    return getHost(sitetpNode.innerText || sitetpNode.textContent);
                }

                function ACHandle() {
                    // 处理主重定向
                    if (curSite.SiteTypeID == SiteType.OTHERS || curSite.SiteTypeID == SiteType.SOGOU) return;
                    if (ACConfig.isRedirectEnable) {
                        if (curSite.Stype_Normal != null && curSite.Stype_Normal != ""){
                            // 百度搜狗去重定向-普通模式【注意不能为document.query..】
                            resetURLNormal(document.querySelectorAll(curSite.Stype_Normal));
                            if(checkISBaiduMain()){
                                document.querySelectorAll(".s_form .index-logo-src[src*='gif'], .s_form .index-logo-srcnew[src*='gif']").forEach(function (per) {
                                    per.src = "https://pic.rmb.bdstatic.com/c86255e8028696139d3e3e4bb44c047b.png";
                                    // 神奇的百度百家号
                                    // https://imgsa.baidu.com/fex/pic/item/8718367adab44aedcc91ab2bbe1c8701a08bfb26.jpg
                                    // https://baidu.ntaow.com/newcss/baidu.png
                                });
                            }
                        }
                        if (curSite.SiteTypeID == SiteType.GOOGLE) removeOnMouseDownFunc(); // 移除onMouseDown事件,谷歌去重定向
                        if (curSite.SiteTypeID == SiteType.MBAIDU) removeMobileBaiduDirectLink(); // 处理百度手机版本的重定向地址
                        removeRedirectLinkTarget(); // 只移除知乎的重定向问题 & 百度学术重定向问题
                        safeRemove(".res_top_banner"); // 移除百度可能显示的劫持
                    }

                    try{ // 放入异常捕获,防止由于html插入过慢导致的js终止
                        if(! document.querySelector("#sp-ac-style").checked){
                            document.querySelectorAll("input[name*='sp-ac-a_force_style_']" ).forEach(per => {per.setAttribute("disabled", "disabled");per.parentNode.setAttribute("title", "请开启自定义样式")});
                        }else{
                            document.querySelectorAll("input[name*='sp-ac-a_force_style_']" ).forEach(per => {per.removeAttribute("disabled");per.parentNode.setAttribute("title", "AC-自定义样式内容")});
                        }
                        if(! document.querySelector("#sp-ac-block").checked){
                            document.querySelectorAll("#sp-ac-removeBlock, #sp-ac-blockBtnDisplay" ).forEach(per => {per.setAttribute("disabled", "disabled");per.parentNode.setAttribute("title", "请开启自定义样式")});
                        }else{
                            document.querySelectorAll("#sp-ac-removeBlock, #sp-ac-blockBtnDisplay" ).forEach(per => {per.removeAttribute("disabled");per.parentNode.setAttribute("title", "AC-自主拦截功能")});
                        }
                    }catch (e) {
                    }
                }

                function ACtoggleSettingDisplay(e) {
                    e.stopPropagation();
                    // 显示?隐藏设置界面
                    if(document.querySelector(".iframe-father iframe") == null){
                        document.querySelector(".iframe-father").insertAdjacentHTML("beforeend", "");
                    }
                    setTimeout(function () {
                        if (document.querySelector("#sp-ac-content").style.display == 'block') {
                            document.querySelector("#sp-ac-content").style.display = 'none';
                        } else {
                            ACConfig.oldVersion = GM_info.script.version;
                            GM.setValue("Config", JSON.stringify(ACConfig));
                            document.querySelector(".ac-newversionDisplay").style.display = 'none';
                            document.querySelector("#sp-ac-content").style.display = 'block';
                        }
                    }, 100);
                    return false;
                }

                function getBlockList(){ // 同时处理高亮
                    let insHTML = "";
                    for(let i = 0; i < ACConfig.UserBlockList.length; i++){
                        let insClass = CONST.curHosts.findIndex(m => {
                            try {
                                return new RegExp(ACConfig.UserBlockList[i].replace("*", ".*")).test(m);
                            }catch(e){
                                return m == ACConfig.UserBlockList[i];
                            }
                        }) >= 0 ? " ac-block-high":""; // 如果当前页面存在,则高亮
                        insHTML += `
  • \n`
    ; } return insHTML; } function reloadBlockList(){ // 初始化表格内容并绑定按钮事件 document.querySelector(".ac-blockList ul").innerHTML = getBlockList(); } function initBlockPage(){ try{ if(useCNLan){ document.querySelector(".setting-second").innerHTML = `
  •  拦截列表  想要生效的话需要手动保存
    • ${getBlockList()}
  • 全匹配拦截:新增
  • `
    ; }else{ document.querySelector(".setting-second").innerHTML = `
  •  Block List  Click Save Button if you want wo save the list
    • ${getBlockList()}
  • Same host Insert :Insert
  • `
    ; } document.querySelector("#sp-ac-blockdiybutton-back").addEventListener("click", function () { document.querySelector(".setting-main").style = ""; document.querySelector(".setting-second").style = "display:none;"; }); document.querySelector(".ac-blockList").addEventListener("click", function (e) { // 点击移除某个host数据时 let target = e.srcElement || e.target; if(target.tagName.toLowerCase() == "label"){ let host = target.dataset.host; ACConfig.UserBlockList.acremove(host, function(){ document.querySelectorAll("button[ac-user-alter]").forEach(function (perNode) { // 移除用户diy之后的属性 perNode.removeAttribute("ac-user-alter"); }); SiteBlock.renderDisplay(); reloadBlockList(); }); } }); function ckAddRule(){ // 手动增加移除规则 let inputN = document.querySelector(".sp-ac-addRuleOne"); ACConfig.UserBlockList.acpush(inputN.value, reloadBlockList); inputN.value = ""; } document.querySelector("#sp-ac-addRulebutton").addEventListener("click", ckAddRule); document.querySelector(".sp-ac-addRuleOne").addEventListener("keypress", function(evt){ let e = evt || window.event; if(e.keyCode == 13) ckAddRule(); }); }catch (e) { } } function ShowSetting() { if (curSite.SiteTypeID == SiteType.OTHERS) return; // 如果不存在的话,那么自己创建一个-copy from superPreload if (document.body != null && document.querySelector("#sp-ac-container") == null) { let Container = document.createElement('div'); Container.id = "sp-ac-container"; if(useCNLan){ Container.innerHTML = " "; }else{ Container.innerHTML = " "; } try { document.body.appendChild(Container); } catch (e) { console.log(e); } try { document.querySelector("#sp-ac-savebutton").addEventListener("click", function () { // 点击之后的保存功能 ACConfig.isRedirectEnable = document.querySelector("#sp-ac-redirect").checked; ACConfig.isEnLang = document.querySelector("#sp-ac-isEnLang").checked; // 是否选择为对立语言 ACConfig.isAdsEnable = document.querySelector("#sp-ac-ads").checked; ACConfig.isAutopage = document.querySelector("#sp-ac-isAutopage").checked; ACConfig.isBlockEnable = document.querySelector("#sp-ac-block").checked; ACConfig.isBlockDisplay = document.querySelector("#sp-ac-removeBlock").checked; ACConfig.isBlockBtnDisplay = !document.querySelector("#sp-ac-blockBtnDisplay").checked; ACConfig.AdsStyleEnable = document.querySelector("#sp-ac-style").checked; ACConfig.AdsStyleMode_Baidu = document.querySelector('input[name="sp-ac-a_force_style_baidu"]:checked').value; ACConfig.AdsStyleMode_Google = document.querySelector('input[name="sp-ac-a_force_style_google"]:checked').value; ACConfig.AdsStyleMode_Bing = document.querySelector('input[name="sp-ac-a_force_style_bing"]:checked').value; ACConfig.AdsStyleMode_SoGou = document.querySelector('input[name="sp-ac-a_force_style_sogou"]:checked').value; ACConfig.HuYan_Baidu = document.querySelector('input[name="sp-ac-huyan_style_baidu"]').checked; ACConfig.Style_BaiduLite = document.querySelector('input[name="sp-ac-a_force_style_baidulite"]').checked; ACConfig.HuYan_Google = document.querySelector('input[name="sp-ac-huyan_style_google"]').checked; ACConfig.isGooleInBaiduModeEnable = document.querySelector('input[name="sp-ac-google_in_baidumode"]').checked; ACConfig.HuYan_Bing = document.querySelector('input[name="sp-ac-huyan_style_bing"]').checked; ACConfig.HuYan_SoGou = document.querySelector('input[name="sp-ac-huyan_style_sogou"]').checked; let imgurl = document.querySelector("#sp-ac-faviconUrl").value.trim(); imgurl = (imgurl == "https://ws1.sinaimg.cn/large/6a155794ly1foijtdzhxhj200w00wjr5.jpg") ? "" : imgurl; // 如果是旧的新浪地址,那么重置 imgurl = (imgurl == "" || imgurl == null) ? "https://ae01.alicdn.com/kf/HTB1dRY0X8OD3KVjSZFFq6An9pXay.jpg" : imgurl; ACConfig.isUserColorEnable = document.querySelector("#sp-ac-usercolor").checked; ACConfig.defaultHuYanColor = document.querySelector(".sp-ac-menuhuyanColor").value; ACConfig.isFaviconEnable = document.querySelector("#sp-ac-favicon").checked; ACConfig.defaultFaviconUrl = imgurl; ACConfig.doDisableSug = document.querySelector("#sp-ac-sug_origin").checked; ACConfig.isRightDisplayEnable = document.querySelector("#sp-ac-right").checked; ACConfig.isCounterEnable = document.querySelector("#sp-ac-counter").checked; ACConfig.isALineEnable = document.querySelector("#sp-ac-aline").checked; ACConfig.isUserStyleEnable = document.querySelector("#sp-ac-userstyle").checked; if(ACConfig.isUserStyleEnable){ ACConfig.UserStyleText = document.querySelector("#sp-ac-userstyleTEXT").value.trim(); } ACConfig.lastSaveTime = new Date().getTime(); GM.setValue("Config", JSON.stringify(ACConfig)); setTimeout(function () { window.location.reload(); }, 400); }, false); initBlockPage(); document.querySelector("#sp-ac-blockdiybutton").addEventListener("click", function () { document.querySelector(".setting-main").style = "display:none;"; document.querySelector(".setting-second").style = ""; }); document.querySelector(".menu-box-container").addEventListener("click", function (e) { let cur = e.srcElement || e.target; if (typeof(cur.dataset.color) != "undefined") { document.querySelector(".sp-ac-menuhuyanColor").value = cur.dataset.color; CONST.StyleManger.loadHuYanStyle(cur.dataset.color); } e.stopPropagation(); }); document.querySelector(".sp-ac-menuhuyanColor").addEventListener("input", function (e) { CONST.StyleManger.loadHuYanStyle(document.querySelector(".sp-ac-menuhuyanColor").value); e.stopPropagation(); }); document.querySelectorAll("labelHide").forEach(function (per) { per.addEventListener("click", function (e) { let cur = e.srcElement || e.target; let className = cur.parentNode.className.replace("container-label ", ""); AC_addStyle(".XX>label,.XX>br{display:unset !important;}.XX>labelhide{display:none !important;}".replace(/XX/gm, className), "AC-ShowHideItem-" + className, "body"); e.stopPropagation(); }); }); if(ACConfig.isUserStyleEnable){ document.querySelector("#sp-ac-userstyleTEXT").addEventListener("paste", AutoLoadCustomCSS); document.querySelector("#sp-ac-userstyleTEXT").addEventListener("keyup", AutoLoadCustomCSS); document.querySelector("#sp-ac-userstyleTEXT").addEventListener("change", AutoLoadCustomCSS); } } catch (e) { } } let allNodes = document.querySelectorAll(".AC-faviconT, .AC-CounterT"); for (let i = 0; i < allNodes.length; i++) { if (allNodes[i].getAttribute('acClick') == null) { allNodes[i].setAttribute('acClick', '1'); try { allNodes[i].addEventListener('click', function (e) { return ACtoggleSettingDisplay(e); }, true); } catch (e) { console.log(e); } } } try { document.querySelector("body>#sp-ac-container").addEventListener('click', function (e) { e.stopPropagation(); // 阻止点击自身的时候关闭 }, false); document.querySelector("body").addEventListener('click', function (e) { safeRemove(function(){ document.querySelector("#sp-ac-content").style.display = 'none'; }); }, false); document.querySelector("#sp-ac-cancelbutton").addEventListener('click', function (e) { safeRemove(function(){ document.querySelector("#sp-ac-content").style.display = 'none'; e.stopPropagation(); }); }, false); } catch (e) { } } function removeMobileBaiduDirectLink(){ let nodes = document.querySelectorAll("#page #page-bd #results .result:not([ac_redirectStatus])"); for(let i = 0; i < nodes.length; i++){ let curNode = nodes[i]; safeFunction(function(){ let curData = JSON.parse(curNode.dataset.log.replace(/'/gm, "\"")); let trueLink = curData.mu; curNode.querySelector("article").setAttribute("rl-link-href", trueLink); curNode.querySelectorAll("a").forEach(function (per) { per.setAttribute("href", trueLink); }); }); curNode.setAttribute("ac_redirectStatus", "1"); } } function removeOnMouseDownFunc() { try { let resultNodes = document.querySelectorAll(".g .rc .r a"); for (let i = 0; i < resultNodes.length; i++) { let one = resultNodes[i]; one.setAttribute("onmousedown", ""); // 谷歌去重定向干扰 one.setAttribute("target", "_blank"); // 谷歌链接新标签打开 } } catch (e) { console.log(e); } } function removeRedirectLinkTarget() { if (curSite.SiteTypeID == SiteType.ZHIHU) { let nodes = document.querySelectorAll(".RichText a[href*='//link.zhihu.com/?target']"); for (let i = 0; i < nodes.length; i++) { let url = decodeURIComponent(nodes[i].href.replace(/https?:\/\/link\.zhihu\.com\/\?target=/, "")); nodes[i].href = url; } } else if (curSite.SiteTypeID == SiteType.BAIDU_XUESHU) { let xnodes = document.querySelectorAll("a[href*='sc_vurl=http']"); for (let j = 0; i < xnodes.length; j++) { let xurl = getUrlAttribute(xnodes[j].href, "sc_vurl", true); xnodes[j].href = xurl; } } } // 提取url元素的参数值 function getUrlAttribute(url, attribute, needDecode) { let searchValueS = (url.substr(1) + "").split("&"); for (let i = 0; i < searchValueS.length; i++) { let key_value = searchValueS[i].split("="); let reg = new RegExp("^" + attribute + "$"); if (reg.test(key_value[0])) { let searchWords = key_value[1]; return needDecode ? decodeURIComponent(searchWords) : searchWords; } } } function resetURLNormal(list) { for (var i = 0; i < list.length; i++) { // 此方法是异步,故在结束的时候使用i会出问题-严重! // 采用闭包的方法来进行数据的传递 let curNode = list[i]; let curhref = curNode.href; if (list[i] != null && list[i].getAttribute("ac_redirectStatus") == null) { list[i].setAttribute("ac_redirectStatus", "0"); if (curhref.indexOf("www.baidu.com/link") > -1 || curhref.indexOf("m.baidu.com/from") > -1 || curhref.indexOf("www.sogou.com/link") > -1 || curhref.indexOf("so.com/link") > -1) { (function (c_curnode, c_curhref) { let url = c_curhref.replace(/^http:/, "https:"); if (curSite.SiteTypeID == SiteType.BAIDU && url.indexOf("eqid") < 0) { // 如果是百度,并且没有带有解析参数,那么手动带上 url = url + "&wd=&eqid="; } let gmRequestNode = GM_xmlhttpRequest({ // from: "acxhr", extData: c_curhref, // 用于扩展 url: url, headers: {"Accept": "*/*", "Referer": c_curhref.replace(/^http:/, "https:")}, method: "GET", timeout: 5000, onreadystatechange: function (response) { // 由于是特殊返回-并且好搜-搜狗-百度都是这个格式,故提出 DealRedirect(gmRequestNode, c_curhref, response.responseText, "URL='([^']+)'") // 这个是在上面无法处理的情况下,备用的 tm-finalurldhdg tm-finalurlmfdh if (response.responseHeaders.indexOf("tm-finalurl") >= 0) { let relURL = Reg_Get(response.responseHeaders, "tm-finalurl\\w+: ([^\\s]+)"); if (relURL == null || relURL == "" || relURL.indexOf("www.baidu.com/search/error") > 0) return; DealRedirect(gmRequestNode, c_curhref, relURL); } } }); })(curNode, curhref); //传递旧的网址过去,读作c_curhref } } } } var DealRedirect = function (request, curNodeHref, respText, RegText) { if (respText == null || typeof(respText) == "undefined") return; let resultResponseUrl = ""; if (RegText != null) { resultResponseUrl = Reg_Get(respText, RegText); } else { resultResponseUrl = respText; } if (resultResponseUrl != null && resultResponseUrl != "" && resultResponseUrl.indexOf("www.baidu.com/link") < 0) { try { if (curSite.SiteTypeID == SiteType.SOGOU) curNodeHref = curNodeHref.replace(/^https:\/\/www.sogou.com/, ""); let host = getHost(resultResponseUrl); document.querySelectorAll("*[href*='" + curNodeHref + "']").forEach(function (per) { if(per.querySelector("span") != null){ per.lastChild.insertAdjacentHTML("beforeEnd", " - " + host); } per.setAttribute("ac_redirectStatus", "2"); per.setAttribute("href", resultResponseUrl); if(per.hasAttribute("meta")){ per.setAttribute("meta", host); per.dataset.host = host; } }); CONST.curHosts.acpush(host, reloadBlockList); request.abort(); } catch (e) { // console.log(e); } } }; function removeAD_baidu_sogou() { // 移除网站自有广告 if (curSite.SiteTypeID == SiteType.BAIDU) { // safeRemove(".c-container /deep/ .c-container"); // 移除shadowDOM广告;搜索关键字:淘宝;然后点击搜索框,广告会多次重现shadowdom safeRemove(function () { $('.c-container /deep/ .c-container').has('.f13>span:contains("广告")').remove(); }); safeRemove(function () { $('#content_right>div').has('a:contains("广告")').remove(); }); // 移除标准广告 safeRemove(function () { $('#content_left>div').has('span:contains("广告")').remove(); }); // 移除右侧栏顶部-底部无用广告 safeRemove(function () { $("#content_right td>div:not([id]),#content_right>br").remove(); }); } else if(curSite.SiteTypeID == SiteType.MBAIDU){ /****移除手机模式上的部分广告****/ safeRemove(function(){ $('#page-bd #results>div:not([class*="result"])').remove(); }); safeRemove(function(){ $('#page-bd #results>div:not([class])').remove(); }); } else if (curSite.SiteTypeID == SiteType.SOGOU) { safeRemove("#promotion_adv_container"); safeRemove("#kmap_business_title"); safeRemove("#kmap_business_ul"); safeRemove(".sponsored"); try { document.querySelector(".rvr-model[style='width:250px;']").style = "display:none"; } catch (e) { } } else if (curSite.SiteTypeID == SiteType.SO) { safeRemove("#so_kw-ad"); safeRemove("#m-spread-left"); safeRemove("#m-spread-bottom"); } else if (curSite.SiteTypeID == SiteType.BING) { safeRemove(".b_ad"); } else if (curSite.SiteTypeID == SiteType.GOOGLE) { safeRemove("#bottomads"); } } function IsNumber(val) { if (val === "" || val == null) { return false; } if (!isNaN(val)) { return true; } else { return false; } } function addCounter(citeList) { let cssText = "position:relative;z-index:1;margin-right:4px;display:inline-block;color:white;font-family:'微软雅黑';font-size:16px;text-align:center;width:22px;line-height:22px;border-radius:50%;"; let div = document.createElement('div'); for (let i = 0; i < citeList.length; i++) { let index = citeList[i].getAttribute('SortIndex'); if (index==null || typeof(index) == "undefined") { citeList[i].setAttribute('SortIndex', CONST.sortIndex); citeList[i].inner = citeList[i].innerHTML; div.innerHTML = "+ cssText + ">" + CONST.sortIndex + ""; citeList[i].innerHTML = div.innerHTML + citeList[i].inner; CONST.sortIndex++; } else { if(index != (i + 1) % 100){ // 按需更新 citeList[i].querySelector(".AC-CounterT").innerText = (i + 1) % 100; } } } } function getHost(sbefore) { sbefore = (sbefore && sbefore.trim()) || ""; let send; let result = sbefore.split('-'); // --搜狗百度专用;如果第一个是中文的话,地址就是第二个 if((result.length > 1 && new RegExp("[\\u4E00-\\u9FFF]+","g").test(sbefore)) && (curSite.SiteTypeID == SiteType.BAIDU || curSite.SiteTypeID == SiteType.SOGOU)){ sbefore = result[1]; } send = sbefore.replace(/(\/[^/]*|\s*)/, "").replace(/<[^>]*>/g, "").replace(/https?:\/\//g, "").replace(/<\/?strong>/g, "").replace(/<\/?b>/g, "").replace(/?/g, "").replace(/( |\/).*/g, "").replace(/\.\..*/, ""); if(send.indexOf(".") < 0) return null; if(send.indexOf("↵")>=0) return null; return send.trim(); } function addFavicon(citeList) { for (let index = 0; index < citeList.length; index++) { if (null == citeList[index].getAttribute("ac_faviconStatus")) { let curNode = citeList[index]; let targetNode = curNode; let url = getBaiduHost(targetNode); if(url == null){ // 跳过baidu.click continue; }else{ CONST.curHosts.acpush(url); } let faviconUrl = url; let II = 0; for (; II <= 5; II++) { targetNode = targetNode.parentNode; if (targetNode != null && targetNode.querySelector(curSite.FaviconAddTo) != null) { break; } } //console.log(index+"."+faviconUrl+"--"+II); if (II <= 5) { // 先用父节点判断一下是否存在img let tmpHTML = targetNode.innerHTML; let pos = tmpHTML.indexOf("fav-url") & tmpHTML.indexOf("favurl") & tmpHTML.indexOf("tit-ico") & tmpHTML.indexOf("img_fav rms_img") & tmpHTML.indexOf("c-tool-") & tmpHTML.indexOf("span class=\"c-icon c-icon-") & tmpHTML.indexOf("img class=\"xA33Gc"); //他自己已经做了favicon了 if (pos > -1) { // console.log("已有图片:"); curNode.setAttribute("ac_faviconStatus", "-2"); continue; } targetNode = targetNode.querySelector(curSite.FaviconAddTo); // 特殊处理BING // if (curSite.SiteTypeID == SiteType.BING) curNode = curNode.querySelector("h2"); //https://api.byi.pw/favicon/?url=???? 不稳定 //http://"+faviconUrl+"/cdn.ico?defaulticon=http://soz.im/favicon.ico 不稳定 //https://www.xtwind.com/api/index.php?url=???? 挂了。。。 //https://statics.dnspod.cn/proxy_favicon/_/favicon?domain=sina.cn //www.google.com/s2/favicons?domain=764350177.lofter.com //如果地址不正确,那么丢弃 let host = faviconUrl.replace(/[^.]+\.([^.]+)\.([^.]+)/, "$1.$2"); if (targetNode.querySelector(".AC-faviconT") == null && host.length > 3) { let insNode = document.createElement("img"); // curNode = curNode.children[0] || curNode.firstChild ; // firstChild容易遇到text对象 curNode.setAttribute("ac_faviconStatus", "1"); // curNode.insertBefore(insNode, curNode.firstChild); insNode.className = "AC-faviconT"; insNode.setAttribute("referrerpolicy", "no-referrer"); insNode.style = "position:relative;z-index:1;vertical-align:sub;height:16px;width:16px;margin-right:5px;margin-bottom: 2px;"; insNode.src = "https://favicon.yandex.net/favicon/" + host; insNode.setAttribute("faviconID", "0"); // curNode.innerHTML = insNode.outerHTML + curNode.innerHTML; // curNode.insertAdjacentHTML("afterEnd", insNode.innerHTML); let beforeIndex = 0; if(targetNode.childNodes[beforeIndex].className == "AC-CounterT"){beforeIndex = 1;} targetNode.insertBefore(insNode, targetNode.childNodes[beforeIndex]); (function(xcur){ insNode.onload = function(env){ let imgNode = xcur.querySelector(".AC-faviconT"); if(imgNode.naturalWidth < 10){ imgNode.setAttribute("old-src", imgNode.src); imgNode.src = ACConfig.defaultFaviconUrl; } imgNode.onload = "javascript:void(0);"; }; })(targetNode); } } } } } function InsertSettingMenu() { if ((curSite.SiteTypeID != SiteType.OTHERS) && document.querySelector("#myuser") == null) { try { let parent = document.querySelector("#u, #gb>div>div>div, #b_header>#id_h, .top-bar .sogou-set-box"); //baidu; google; bing; 搜狗 parent.style = "width: auto;"; let userAdiv = document.createElement("div"); userAdiv.id = "myuser"; if(useCNLan){ userAdiv.innerHTML = " "; }else{ userAdiv.innerHTML = " "; } parent.insertBefore(userAdiv, parent.childNodes[0]); document.querySelector("#myuser .myuserconfig").addEventListener("click", function (e) { return ACtoggleSettingDisplay(e); }, true); } catch (e) { } } } }(); // 读取个人设置信息 /** * @param callback 回调函数,需要返回是否结束True、False、否则相当于定时器 * callback return: * true = 定时器 * false = 计时器 * none = 计时器 * @param period 周期,如:200ms */ function RAFFunction(callback, period){ // 一秒60次,对应1秒1000ms let needCount = period / 1000 * 60; let times = 0; let hasFinish = false; function step(){ if(!hasFinish) requestAnimationFrame(step); if(times == 0){ times = needCount; hasFinish = callback(); // 只有返回true才会终止,不返回也会继续 } times--; } requestAnimationFrame(step); } function safeFunction(func){ safeRemove(func); } function safeWaitFunc(selector, callbackFunc, time, notClear){ time = time || 50; notClear = notClear || false; let doClear = !notClear; RAFFunction(function () { if((typeof (selector) == "string" && document.querySelector(selector) != null)) { callbackFunc(document.querySelector(selector)); if(doClear) return true; }else if((typeof(selector) == "function" && selector().length > 0)){ callbackFunc(selector()[0]); if(doClear) return true; } }, time); } function AC_addStyle(css, className, addToTarget, isReload, initType) { // 添加CSS代码,不考虑文本载入时间,只执行一次-无论成功与否,带有className RAFFunction(function() { /** * addToTarget这里不要使用head标签,head标签的css会在html载入时加载, * html加载后似乎不会再次加载,body会自动加载 * **/ let addTo = document.querySelector(addToTarget); if (typeof(addToTarget) == "undefined") addTo = (document.head || document.body || document.documentElement || document); isReload = isReload || false; // 默认是非加载型 initType = initType || "text/css"; // 如果没有目标节点(则直接加) || 有目标节点且找到了节点(进行新增) if (typeof(addToTarget) == "undefined" || (typeof(addToTarget) != "undefined" && document.querySelector(addToTarget) != null)) { // clearInterval(tout); // 如果true 强行覆盖,不管有没有--先删除 // 如果false,不覆盖,但是如果有的话,要退出,不存在则新增--无需删除 if (isReload == true) { safeRemove("." + className); } else if (isReload == false && document.querySelector("." + className) != null) { // 节点存在 && 不准备覆盖 return true; } let cssNode = document.createElement("style"); if (className != null) cssNode.className = className; cssNode.setAttribute("type", initType); cssNode.innerHTML = css; try { addTo.appendChild(cssNode); } catch (e) { console.log(e.message); } return true; } }, 20); } function safeRemove(cssSelector_OR_NEWfunction) { if (typeof(cssSelector_OR_NEWfunction) == "string") { try { let removeNodes = document.querySelectorAll(cssSelector_OR_NEWfunction); for (let i = 0; i < removeNodes.length; i++) removeNodes[i].remove(); } catch (e) { } } else if (typeof(cssSelector_OR_NEWfunction) == "function") { try { cssSelector_OR_NEWfunction(); } catch (e) { } } else { console.log("未知命令:" + cssSelector); } } function checkISBaiduMain(){ // 如果是百度 && 没有(百度搜索结果的标志-[存在]百度的内容) return; return !(curSite.SiteTypeID == SiteType.BAIDU && !(location.href.replace(/(&|\?)(wd|word)=/, "") != location.href || document.querySelector("#content_left") || ((document.querySelector("#kw") && document.querySelector("#kw").getAttribute("value")) || "") != "") ) } function FSBaidu() { // thanks for code from 浮生@未歇 @page https://greasyfork.org/zh-TW/scripts/31642 debug("初始化FSBAIDU"); /** * 检查document的子节点是否含有元素 * @param nodeClass 待检查元素 * @returns {boolean} T|F */ function checkDocmentHasNode(nodeClass) { for (let i = 0; i < document.childNodes.length; i++) { if (document.childNodes[i].data && document.childNodes[i].data.indexOf(nodeClass) > 0) return true; } return false; } CONST.StyleManger = { /** * 导入css内容为【文本格式】!!! * @param data css内容 * @param toClassName 预期的类名 */ importStyle: function (data, toClassName, useNormalCSS, mustLoad) { if(typeof(data) == "undefined") { // 这个居然在VM上出问题了,很奇怪 console.error("GM_getResourceText获取内容数据异常"); return } useNormalCSS = useNormalCSS || false; mustLoad = mustLoad || false; // 普通浏览器模式--但是似乎样式加载的优先级低于head中的style优先级 if (!useNormalCSS) { // 通过must参数来判定style是否加载 // data = data.replace(/baidu.com#\$#/igm, ''); if (data.indexOf("http") != 0) data = "data:text/css;utf-8," + encodeURIComponent(data); if (!checkDocmentHasNode(toClassName)) { let pi = document.createProcessingInstruction( "xml-stylesheet", `type="text/css" must="${mustLoad}" class="${toClassName}" href="${data}"` ); // 注意必须要双引号 document.insertBefore(pi, document.documentElement); } } else { /* **********多重样式-兼容edge && 黑夜脚本************ */ AC_addStyle(data, toClassName, "head", false, "text/css"); /* **********多重样式-兼容edge && 黑夜脚本************ */ } }, //加载普通样式 loadCommonStyle: function () { this.loadStyle(CONST.keySite + "CommonStyle", CONST.keySite + "CommonStyle"); }, loadBaiduLiteStyle: function(){ CONST.StyleManger.loadStyle("baiduLiteStyle", "baiduLiteStyle", null, false, true); CONST.StyleManger.loadPlainToCSS("baiduLiteStyle"); }, loadStyle: function (styleName, insClassName, setUrl, useNormalCSS, mustLoad) { // 全部采用text/css的内容来载入 // 如果是debug模式。或者是gm模式 if (isLocalDebug) { debug("本地-加载样式:" + insClassName); setUrl = setUrl || "http://127.0.0.1/" + styleName + ".css"; this.importStyle(setUrl, "AC-" + insClassName, useNormalCSS, mustLoad); } else if (isNewGM == true) { // 仅用于GreaseMonkey4.0+ debug("特殊模式-加载样式:" + insClassName); setUrl = setUrl || "https://baidu.htt5.com/newcss/" + styleName + ".css"; this.importStyle(setUrl, "AC-" + insClassName, useNormalCSS, mustLoad); } else { debug("加载样式:" + insClassName); // TamperMonkey + GreaseMonkey < 4.0 + ViolentMonkey (4.0GreaseMonkey不支持GetResource方法) this.importStyle(GM_getResourceText(styleName), "AC-" + insClassName, useNormalCSS, mustLoad); } }, //加载护眼模式样式 loadHuYanStyle: function (color) { let style = "body[baidu],#wrapper #head,#wrapper #s_tab,form.fm .s_ipt_wr.bg{background-color:#fff}#container #content_left .result-op,#container #content_left .result,#container #rs,#container #content_right{background-color:#aaa;border:1px double #a2d7d4;border-radius:0}#container #content_left .result-op:hover,#container #content_left .result:hover{background-color:#ccc!important}#container #content_left .result-op h3,#container #content_left .c-container h3,#container #rs .tt{background-color:#bbb}.na_cnt .nws_itm,.nws_itmb,#b_content #b_results li,body #b_header{background-color:#aaa;border:1px double #a2d7d4;border-radius:0}#b_content #b_results li:hover{background-color:#ccc!important}#b_content #b_results li h2{background-color:#bbb}#rso .g,.bkWMgd>.g,.bkWMgd g-inner-card,#rhscol #rhs,#rhscol #rhs .g>div,.c2xzTb .g,.ruTcId .g,.fm06If .g,.cUnQKe .g,.HanQmf .g{background-color:#aaa;border:1px double #a2d7d4;border-radius:0}#rso .g:hover,.bkWMgd>.g:hover{background-color:#ccc!important}.bkWMgd .g div.r,#rso .g h3{background-color:#bbb}"; if (ACConfig.isUserColorEnable) { color = color || ACConfig.defaultHuYanColor || "#FFFFFF"; } else { color = color || "#FFFFFF"; } if (color.indexOf("#") != 0 || color.length < 7) return; if (isNewGM == false) { style = GM_getResourceText("MainHuYanStyle"); } style = style .replace(/#aaa(a*)/igm, color) .replace(/#bbb(b*)/igm, this.Lighter(color, -40)) .replace(/#ccc(c*)/igm, this.Lighter(color, 45)); AC_addStyle(style, "AC-" + CONST.keySite + "HuYanStyle" + (isNewGM ? "" : "-File"), "head"); // 需要修改的,所以为true }, clip255: function (value) { if (value > 255) return 255; if (value < 0) return 0; return value; }, Lighter:function (oriRGB, deltaY) { // 按比例缩放 + 1/deltaY // HEX 2 RGB let rgb = oriRGB.replace("#", ""); let R = parseInt("0x" + rgb.substr(0, 2)); let G = parseInt("0x" + rgb.substr(2, 2)); let B = parseInt("0x" + rgb.substr(4, 2)); // RGB 2 YUV let Y = ((66 * R + 129 * G + 25 * B + 128) >> 8) + 16; let U = ((-38 * R - 74 * G + 112 * B + 128) >> 8) + 128; let V = ((112 * R - 94 * G - 18 * B + 128) >> 8) + 128; Y = Y * (1 + 1.0 / deltaY);// 提高亮度 // YUV 2 RGB R = this.clip255((298 * (Y - 16) + 409 * (V - 128) + 128) >> 8); G = this.clip255((298 * (Y - 16) - 100 * (U - 128) - 208 * (V - 128) + 128) >> 8); B = this.clip255((298 * (Y - 16) + 516 * (U - 128) + 128) >> 8); return "#" + ((R << 16) + (G << 8) + B).toString(16); }, //加载单页样式 loadOnePageStyle: function () { this.loadStyle(CONST.keySite + "OnePageStyle", CONST.keySite + "OnePageStyle"); }, //加载双页样式 loadTwoPageStyle: function () { this.loadStyle(CONST.keySite + "TwoPageStyle", CONST.keySite + "TwoPageStyle"); }, // 加载三列样式 loadThreePageStyle: function () { let cssHead = ""; if (curSite.SiteTypeID == SiteType.BAIDU) cssHead = "#container #content_left, body[news] #container #content_left>div:not([class]):not([id])"; if (curSite.SiteTypeID == SiteType.GOOGLE) cssHead = ".srg, #rso"; if (curSite.SiteTypeID == SiteType.BING) cssHead = "#b_content #b_results"; if (curSite.SiteTypeID == SiteType.SOGOU) cssHead = "#main .results"; AC_addStyle(cssHead + "{grid-template-columns: repeat(auto-fit,minmax(33%,1fr));} #container #content_left>*:not([class*='result']):last-child, #rso>div:not(.g), #rso .srg{grid-column-end: 4;}", "AC-ThreePageStyle", "head"); }, // 加载四列样式 loadFourPageStyle: function () { let cssHead = ""; if (curSite.SiteTypeID == SiteType.BAIDU) cssHead = "#container #content_left, body[news] #container #content_left>div:not([class]):not([id])"; if (curSite.SiteTypeID == SiteType.GOOGLE) cssHead = ".srg, #rso"; if (curSite.SiteTypeID == SiteType.BING) cssHead = "#b_content #b_results"; if (curSite.SiteTypeID == SiteType.SOGOU) cssHead = "#main .results"; AC_addStyle(cssHead + "{grid-template-columns: repeat(auto-fit,minmax(25%,1fr));} #container #content_left>*:not([class*='result']), #rso>div:not(.g), #rso .srg{grid-column-end: 5;}", "AC-FourPageStyle", "head"); }, loadPlainToCSS: function(){ for (let i = 0; i < document.childNodes.length; i++) { let curNode = document.childNodes[i]; if(curNode.del) curNode.remove(); } document.querySelectorAll("style[class*='AC'][del='1']").forEach(function (per) { per.remove(); }); }, // 禁止独立的样式加载 loadCSSToPlain: function(){ for (let i = 0; i < document.childNodes.length; i++) { let curNode = document.childNodes[i]; // 如果是存在css, 且非必须数据 if (curNode.target == "xml-stylesheet" && curNode.data.indexOf("must=\"true") < 0) { curNode.data = ""; curNode.del = true; // 对于edge和safari都特殊处理一下吧 if(navigator.userAgent.toLowerCase().indexOf("edge") > 0 || navigator.userAgent.toLowerCase().indexOf("safari") > 0){ curNode.remove(); } } } } }; let ControlManager = { //居中显示 --- 必须是百度和谷歌的搜索结果页面,其他页面不能加载的--已经通过脚本include标签限制了一部分 centerDisplay: function () { AC_addStyle(".minidiv #logo img{width: 100px;height: unset;margin-top: 0.3rem;}", "AC-style-logo", "head"); let result = CONST.AdsStyleMode || null; if (acCssLoadFlag == false && document.querySelector(".ACExtension") == null) { debug("in样式即将加载:"+result); let expandStyle = "#content_left .result-op:hover,#content_left .result:hover{box-shadow:0 0 2px gray;background:rgba(230,230,230,0.1)!important;}#wrapper #rs, #wrapper #content_left .result, #wrapper #content_left .c-container{min-width:670px;}.c-span18{width:78%!important;min-width:550px;}.c-span24{width: auto!important;}"; if (result == 1) { AC_addStyle(expandStyle, "AC-Style-expand", "head"); CONST.StyleManger.loadCommonStyle(); } else if (result == 2) {//单页居中 AC_addStyle(expandStyle, "AC-Style-expand", "head"); CONST.StyleManger.loadCommonStyle(); CONST.StyleManger.loadOnePageStyle(); } else if (result == 3) { //双页居中 CONST.StyleManger.loadCommonStyle(); CONST.StyleManger.loadTwoPageStyle(); } else if (result == 4) { // 三列 CONST.StyleManger.loadCommonStyle(); CONST.StyleManger.loadTwoPageStyle(); CONST.StyleManger.loadThreePageStyle(); } else if (result == 5) { // 四列 CONST.StyleManger.loadCommonStyle(); CONST.StyleManger.loadTwoPageStyle(); CONST.StyleManger.loadFourPageStyle(); } acCssLoadFlag = true; debug("in样式运行结束"); } if(curSite.SiteTypeID == SiteType.BAIDU && ACConfig.Style_BaiduLite == true){ CONST.StyleManger.loadBaiduLiteStyle(); } if (curSite.SiteTypeID != SiteType.BAIDU && curSite.SiteTypeID != SiteType.BAIDU_XUESHU && curSite.SiteTypeID != SiteType.GOOGLE && curSite.SiteTypeID != SiteType.BING && curSite.SiteTypeID != SiteType.SOGOU) return; // 如果是百度 && ((地址替换->包含wd关键词[替换之后不等-是百度结果页面]) || 有右边栏-肯定是百度搜索结果页 || value中存在搜索内容) return; if (!checkISBaiduMain()) { CONST.StyleManger.loadCSSToPlain(); return; } // 如果是谷歌 && (地址替换->是谷歌图像页面 || 是地图页面)[替换要变] return; if (curSite.SiteTypeID == SiteType.GOOGLE && location.href.replace(/tbm=(isch|lcl|shop|flm)/, "") != location.href) { CONST.StyleManger.loadCSSToPlain(); return; } /**护眼Style最后载入**/ if (CONST.HuYanMode == true || document.querySelector("style[class*='darkreader']") != null) CONST.StyleManger.loadHuYanStyle(); CONST.StyleManger.loadPlainToCSS(); }, init: function () { if (CONST.isGoogleImageUrl) return; this.centerDisplay(); } }; debug("调用加载自定义css"); ControlManager.init(); return CONST.StyleManger; } } })(); }();

    你可能感兴趣的:(一些实用的学生向脚本(补))