// ==UserScript== // @name 百度搜索 - 优化 // @namespace http://tampermonkey.net/ // @home-url https://greasyfork.org/zh-CN/scripts/31642 // @description 1、屏蔽百度推广 2、关闭百度广告联盟信息收集 3、绑定快捷键 4、布局调整 5、居中单列(可选) 6、居中双列(可选) // @version 3.2.2 // @author 浮生未歇 // @include http://www.baidu.com/* // @include https://www.baidu.com/* // @require https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js // @resource baiduIndexStyle https://SSHIN.coding.me/Baidu/2018-06-05/baiduIndexStyle.css // @resource baiduIndexStyleNo https://SSHIN.coding.me/Baidu/2018-06-05/baiduIndexStyleNo.css // @resource baiduCommonStyle https://SSHIN.coding.me/Baidu/2018-06-05/commonStyle.css // @resource baiduMyMenuStyle https://SSHIN.coding.me/Baidu/2018-06-05/customMenuStyle.css // @resource baiduOnePageStyle https://SSHIN.coding.me/Baidu/2018-06-05/onePageCenterStyle.css // @resource baiduTwoPageStyle https://SSHIN.coding.me/Baidu/2018-06-05/twoPageCenterStyle.css // @run-at document-body // @connect * // @grant GM_addStyle // @grant GM_getResourceText // @grant GM_setValue // @grant GM_getValue // @grant GM_xmlhttpRequest // @downloadURL none // ==/UserScript== (function() { 'use strict'; /** * 模块:配置 **/ var Config = { //是否开启DEBUG。true:表示开启,false:表示关闭 isDebug:false, //是否开启重定向。true:表示开启,false表示关闭 redirect:GM_getValue("redirect",false), //是否开启自动加载下一页。true:表示开启,false表示关闭 //preLoader:GM_getValue("preLoader",false), //是否导入首页样式 isImportIndexStyple:false, //Run刷新名称, runResetElementName:"#isRunReset", //功能选择页。0:普通页,1:居中单页,2:居中双页, 3:居中双页(高级版) option:GM_getValue("option",0), //监测点元素默认最大高度。检测值在最高和最低间,触发脚本 testDefinedMaxHeight:50, //监测元素默认最小高度 testDefinedMinHeight:5, //监测点元素 testElementName:"#form", //样式集 styles:[{ //百度首页(已登录) indexStyle : "baiduIndexStyle", //百度首页(未登录) indexStyleNo : "baiduIndexStyleNo", //普通样式 commonStyle : "baiduCommonStyle", //居中单页样式 onePageStyle : "baiduOnePageStyle", //居中双页样式 twoPageStyle : "baiduTwoPageStyle", //自定义菜单样式 menuStyle : "baiduMyMenuStyle", }], //需要安装重置Run的选择器(让函数可以再次运行) resetSelectors:[ "#page a", "#su", "#result_logo", "#s_kw_wrap", ], //需要屏蔽的广告 ads:[ "#content_left>div[style*='display:block !important;']", "#content_left>div:not([id])", "#content_left>#clone", ], //需要重定向的元素(重定向过的元素会添加 "redirect"类) redirectElements:[ "#content_left .c-container h3 > a:not([class*='redirect'])", ], //重定向地址 redirectURL:"www.baidu.com/link", //自动加载下一页 preLoaderConfig:[{ //当前域名 hostName : "https://www.baidu.com" , //下一页按钮 nextPageButton : "#page a[href*='rsv_page=1']" , //页码按钮 pageButton : "#page > a:first", //条目块 itemSelector : ".c-container" , //条目总数可能值(即一页加载多少结果) itemNums:[10,20,50], }], }; /** * 模块:Debug **/ var Debug = { isDebug:Config.isDebug, printDebugInfo:function(name,message){ if(this.isDebug){ console[name](message); } }, group:function(message){ this.printDebugInfo("group",message); }, groupEnd:function(message){ this.printDebugInfo("groupEnd",message); }, log:function(message){ this.printDebugInfo("log",message); }, info:function(message){ this.printDebugInfo("info",message); }, error:function(message){ this.printDebugInfo("error",message); }, count:function(message){ this.printDebugInfo("count",message); } }; /** * 模块:Run运行 * **/ var Run = { _ready:function(callback){ return function(){ $(document).ready(callback); }; }, ready:function(callback){ this._ready(callback)(); }, }; /* 模块:样式 */ var Style ={ //缓存 cache: [], //清除缓存 clearCache:function(){ this.cache = []; }, //加入样式队列 addQueue:function(style){ this.cache.push(style); }, //开始导入样式(必须先将样式加入队列) import:function(){ var styles = null; this.cache.forEach(function(style,index,arr){ styles += GM_getResourceText (style); Debug.log("import( " + style + " )style……" ); }); try{ GM_addStyle(styles); }catch(e){ Debug.log(e); } this.clearCache(); }, }; /** * 模块:数据 **/ var Data={ getGmValue(name){ return GM_getValue(name,Config[name]); }, setGmValue(name,value){ GM_setValue(name,value); }, resetCount(){ Config.count = 0; }, resetRun(){ Config.runCache = []; }, resetAll(){ Data.resetCount(); Data.resetRun(); } }; /** * 模块:检查 **/ var Check = { //获取到顶部的距离 isOffsetHight:function(){ var offsetTopHight = $(Config.testElementName).offset().top;// 0 < top < 50 Debug.log("offsetTopHight : " + offsetTopHight); //异常处理(有时出现 offsetTopHight 异常大的情况) if( offsetTopHight > 200 && location.href.indexOf("https://www.baidu.com/s?" ) > -1 ){ offsetTopHight = 30; } return Config.testDefinedMinHeight < offsetTopHight && offsetTopHight < Config.testDefinedMaxHeight; }, //页布局 0: 普通页,1:单页居中,2:双页居中,3: isLayout:function(num){ return Data.getGmValue("option") == num; }, //存在元素 isExist:function(elementName){ return $(elementName).length > 0; }, //是否重定向 isRedirect:function(){ return Data.getGmValue("redirect"); }, }; /** * 模块:多页布局 **/ var MultiColumnLayout = { //添加LIST类,用于存放ITEM addList:function($parent,list,colsum){ //if( $parent.children(list).length > 0)return; var div = ""; for(var i = 1; i <= colsum; i++){ div += "
"; } $parent.prepend(div); }, //将结果移动到list addItem:function($item){ var $list = $("#content_left > .list"); if($item.length == 0 || $list.length == 0)return; $item.each(function(){ var heightArray = [] ; //高度集合 var minHightIndex = 0; //最小高度 INDEX $list.each(function(){ heightArray.push($(this).height()); }); minHightIndex = heightArray.indexOf(Math.min.apply(window,heightArray)); $(this).appendTo($list.eq(minHightIndex)); }); } }; /** * 模块 - 重定向 **/ var Redirect = { isRedirect:Check.isRedirect(), start:function(){ if(!this.isRedirect)return; $(Config.redirectElements.join()).each(function(){ var that = this; var URL = $(that).attr("href"); if(URL.indexOf(Config.redirectURL) > 0){ $(that).removeAttr("data-click"); GM_xmlhttpRequest({ url:URL, method:"HEAD", onload:function(xhr){ //Debug.log("finalUrl:" + xhr.finalUrl); try{ //将真实地址替换原来地址,并添加标志类(防止再次重定向) $(that).attr("href",xhr.finalUrl).addClass("redirect"); }catch(e){ Debug.log("重定向发生错误:" + e); } }, }); } }); }, }; /** * 自动加载下一页 **/ function PreLoader(config){ //当前配置 this.config = config; //条目计数器 this.item_sum = 0; //页地址 (需要初始化) this.page_url = null; //缓存数据(需要初始化) this.cache = []; //第几页(0表示本页)(需要初始化) this.page_count = 1; } PreLoader.prototype={ //是否存在缓存 hasCache:function(){ return this.cache.length > 0; }, //重置 reset:function(){ this.cache = []; this.page_count = 1; this.page_url = null; }, //获取解析地址 getPageURL:function(){ if(this.page_url == null){ this.page_url = this.config.hostName + $(this.config.pageButton).attr("href"); } return this.page_url; }, //获取条目数量 getItemSum:function(){ if(this.item_sum == 0){ var URL = this.getPageURL(); this.config.itemNums.forEach($.proxy(function(num){ if(URL.indexOf("pn=" + num) > 0){ this.item_sum = num; } },this)); } return this.item_sum; }, //获取下一页地址 getNextPageURL:function(pageCount){ var url = this.getPageURL(); var sum = this.getItemSum(); return url.replace(/pn=\d+/g, "pn="+ pageCount * sum); }, //发送请求 send:function(callback){ Debug.log("sendRequest"); var that = this; var isNeedSend = false; var URL = this.getNextPageURL(this.page_count++); $.ajax({ url : URL, async : true, timeOut : 5000 , type : "GET", dataType : "html", beforeSend:function(){ if(that.hasCache()){ //导入数据到网页 that.addDataToWeb(); //回调函数 if(typeof callback === "function"){ callback(); } }else{ isNeedSend = true; } }, success : function(data,status){ //处理数据 var reg = //g; var body = reg.exec(data)[0]; var item = $(body).find(that.config.itemSelector); that.cache.push(item); //重新发送 if(isNeedSend){ that.send(callback); } }, error : function(e){ Debug.log("自动加载下一页->发送数据失败: " + e); } }); }, //将数据加载到网页中 addDataToWeb:function(){ Debug.log("addDataToWeb"); MultiColumnLayout.addItem(this.cache.shift()); Redirect.start(); }, //加载(中间件) load:function(callback){ //发送数据 this.send(callback); }, //启动 start:function(callback){ var $parent = $("#content_left"); var className = "PreLoaderInit"; var hide = ["#rs","#page"]; //如果还没有初始化 if( $parent.length && !$parent.hasClass(className)){ $parent.addClass(className); $(hide.join()).hide(); //重置数据 this.reset(); //开始发送数据 this.load(callback); } } }; /*****************************************************************************************/ /* 函数功能化 */ /*****************************************************************************************/ var Launch = { //导入首页样式(已登录版) importIndexStyles:function(){ Style.addQueue(Config.styles[0].indexStyle); Style.import(); }, //导入首页样式(未登录版) importIndexStylesNo:function(){ Style.addQueue(Config.styles[0].indexStyleNo); Style.import(); }, //导入搜索页样式 importStyles:function(itemOption){ var styles = Config.styles[0]; var option = itemOption || Data.getGmValue("option"); Debug.log("option:"+option); Style.addQueue(styles.commonStyle); Style.addQueue(styles.menuStyle); switch(option){ case 1:Style.addQueue(styles.onePageStyle);break; case 2: case 3:Style.addQueue(styles.twoPageStyle);break; } Style.import(); }, //屏蔽广告 removeAds:function(){ //1. 屏蔽普通广告 var removeCommonAds = function(){ $( Config.ads.join()).remove(); }; //2. 屏蔽再次出现的广告 var removeLaterAds = function(){ /* var $selector = $("#content_left > div[id='1']"); var $result1 = $selector.next().attr('id') == 2; var $result2 = $("#content_left > div[id]").length != 1; if($result1){ $selector.attr("id","a1"); } if($result2){ GM_addStyle("#content_left > div[id='1'],#content_left .result~div[id='1'] {display: none!important;}"); } */ var $selector = $("#2,#3"); //结果改id $selector.prev("#1").attr("id","a1"); $("#1").remove(); GM_addStyle("#content_left .c-container[id='1'],#content_left .result~div[id='1'] {display: none!important;}"); }; //自执行 (function(){ removeCommonAds(); removeLaterAds(); })(); }, //插入自定义菜单 inserCustomMenu:function(){ if(Check.isExist("#CustomMenu") ) return; var parent = "#u"; var content = ""; var div = ""; //1.添加三种排版 content += "