您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
改善百度的搜索结果界面,提高阅读效率
// ==UserScript== // @name BaiduMonkeyY // @namespace http://userstyles.org // @description 改善百度的搜索结果界面,提高阅读效率 // @version 15.7.2 // @author 【原BaiduMonkeyR脚本作者是SUCCESS】修改自BaiduMonkeyW的版本 // @include https://www.baidu.com/s* // @include https://www.baidu.com/baidu* // @include https://www.baidu.com/#* // @include https://www.baidu.com/ // @run-at document-start // @require http://code.jquery.com/jquery-1.11.0.min.js // @grant GM_getMetadata // @grant GM_addStyle // @grant GM_xmlhttpRequest // @grant GM_log // @grant GM_info // @grant GM_getValue // @grant GM_setValue // ==/UserScript== console.log("Documtnt start"); var url=window.location.href; console.log(url); if (url.indexOf("http://www.baidu.com/#")>=0) { console.log("redirect to s?"); window.location.href=url.replace("http://www.baidu.com/#","http://www.baidu.com/s?"); return; } else if (url=="http://www.baidu.com/") { ajaxSend(window.wrappedJSObject.XMLHttpRequest,callback); console.log("get mainpage’s ajax,then add callback "); return; } addEventListener('DOMContentLoaded', baiduMeiHua, false); console.log("Documtnt DOMContentLoaded Evented!!"); function baiduMeiHua(){ var url=window.location.href; console.log(url); if (url.indexOf("http://www.baidu.com/#")>=0) { console.log("redirect to baidu?"); window.location.href=url.replace("http://www.baidu.com/#","http://www.baidu.com/baidu?"); return; } console.log("Start MeiHua"); // 检查新版本 //setTimeout(checkUpdate, 1000); var isChrome = /Chrome/.test(navigator.userAgent); var scriptUrl = 'https://greasyfork.org/zh-CN/scripts/18704-baidumonkeyy'; var scriptVersion='15.7.1'; var installUrl='https://greasyfork.org/scripts/18704-baidumonkeyy/code/BaiduMonkeyY.user.js'; if (!isChrome){ if (typeof(GM_getMetadata)!='undefined') //兼容Scriptish { scriptVersion = GM_getMetadata("version"); } else if (typeof(GM_info)!='undefined') { scriptVersion = GM_info.script.version; } } var NextPageLink; var pageCount = 1; // 翻页计数 var ResultNum = 1; // 搜索结果计数 var IsLoadingNext; // 是否正在加载下一页 var relatedSearch = matchNode('//div[@id="rs"]').snapshotItem(0); var defaultCSS = '\ .bm_MultiColDiv .rest {\n\ background-color: #EBEFF9 !important;\n\ padding-Left: 0.5em !important;\n\ padding-right: 0.5em !important;\n\ margin-top: 0.5em !important;\n\ padding-top: 0.3em !important;\n\ margin-bottom: 0.2em !important;\n\ padding-bottom: 0.3em !important;\n\ }\n\ .bm_MultiColDiv .bm_num {\n\ font-size: 11pt !important;\n\ font-weight: bold !important;\n\ }\ '; /*********************************************************************************** * 设置参数 ***********************************************************************************/ // GreaseMonkey 的 getValue() 有一些限制,所以重定义一个 getValue() //var getValue = function(n,v){var gmv=isChrome?localStorage.getItem(n):GM_getValue(n);return (gmv==undefined || gmv.length < 1) ? v : gmv;}; //var setValue = function(n,v){var gmv=isChrome?localStorage.setItem(n,v):GM_setValue(n,v);}; var getValue, setValue; if(isChrome){ getValue = function(n,v){var gmv=localStorage.getItem(n);return (gmv==undefined || gmv.length < 1) ? v : gmv;}; setValue = function(n,v){var gmv=localStorage.setItem(n,v);}; }else{ getValue = function(n,v){var gmv=GM_getValue(n);return (gmv==undefined || gmv.length < 1) ? v : gmv;}; setValue = function(n,v){var gmv=GM_setValue(n,v);}; } var Pref = { _:null // 分栏数量,默认 2 ,columns : Number(getValue('numcol', 2)) // 搜索结果的排列方向:1-横向;2-纵向(默认) ,direction : Number(getValue('direction', 2)) // 显示模式:1-紧凑;2-对齐,但比较松散(默认);3-对齐,但比较松散;4-对齐,但比较松散 ,displayMode : Number(getValue('mode', 2)) // 是否自动加载下一页,默认 关闭 ,AutoNextPage : toBoolean(getValue('AutoNextPage',false)) ,Focus2NextPageKeys : getValue('Focus2NextPageKeys', 'ctrl+40') ,Focus2PrevPageKeys : getValue('Focus2PrevPageKeys', 'ctrl+38') // 是否隐藏自动翻页分隔符,默认 不隐藏 ,HideAutoNextPage : toBoolean(getValue('HideAutoNextPage', false)) // 下一页是否包含相关搜索,默认 不包含 ,NextPageWithRS : toBoolean(getValue('NextPageWithRS', false)) // 让搜索结果适合屏幕宽度,默认 打开 ,fitwidth : toBoolean(getValue('fitwidth', true)) // 移除页面右侧的广告,默认 打开 ,removeAd : toBoolean(getValue('removeAd', true)) // 给搜索结果条目添加序号,默认 关闭 ,addResultNum : toBoolean(getValue('addResultNums',false)) // 搜索结果条目添加序号时与标题同行,默认 关闭 ,addResultNum_h : toBoolean(getValue('addResultNums_h',false)) // 添加缩略图预览,默认 关闭 ,addPreview : toBoolean(getValue('addPreviews', false)) // 缩略图大小,默认 100% ,PreviewSize : Number(getValue('PreviewSize', 100)) // 添加 Favicon,默认 关闭 ,addFavicon : toBoolean(getValue('addFavicons', false)) // 若没有 Favicon 则显示空白,默认 否 ,addFavicon_h : toBoolean(getValue('addFavicons_h',false)) // 添加“在此站点中搜索” ,searchSite : toBoolean(getValue('searchSite', false)) // 禁止百度记录我的点击情况,默认 关闭 ,DisableTracking : toBoolean(getValue('DisableTracking', false)) // 快捷键定位到搜索框 ,Focus2Keyword : toBoolean(getValue('Focus2Keyword',false)) ,Focus2KeywordKeys : getValue('Focus2KeywordKeys', 'alt+83') // 快捷键定位到搜索框后的动作:1-清除全部文字(默认);2-紧跟文字之后;3-选中全部文字 ,Focus2KeywordAction : Number(getValue('Focus2KeywordAction',1)) // 在页面上部添加其他搜索引擎 ,EnableSearchInOtherEngines : toBoolean(getValue('SearchInOtherEngines', false)) // 其他搜索引擎地址 ,OtherEngines : getValue('OtherEngines', '搜索searx |https://searx.me/?q={word}') // 其他搜索引擎打开方式,默认“在新页面打开” ,OtherEnginesTarget : getValue('OtherEnginesTarget','_blank') // 跟随搜索框浮动 ,OtherEnginsFloat : toBoolean(getValue('OtherEnginsFloat',false)) // CSS ,CSS : getValue('CSS', defaultCSS) ,customizeCSS : getValue('customizeCSS', '') // 自动检查更新 ,lastCheck : Number(getValue('lastCheck', 0)) ,skipVersion : Number(getValue('skipVersion', 0)) ,newVersion : Number(getValue('newVersion', 0)) }; /********************************************************************************************* * 开始处理 *********************************************************************************************/ //var t0 = new Date().getTime(); var IsBaiduTuijian=0; var OldPrefColumns=Pref.columns; var OldPrefFitwidth=Pref.fitwidth; /* if (matchNode('//div[@class="op_newvideo_left"]').snapshotLength>0 | matchNode('//div[@class="op_newvideo_right"]').snapshotLength>0 | matchNode('//div[@class="result-op"]').snapshotLength>0 | matchNode('//div[@id="app-div"]').snapshotLength>0 | matchNode('//div[contains(@class,"op_new")]').snapshotLength>0 //发现搜索“风云”时 出来的class是op_new_video_tvplay_left等 ) { //addPreferences(); //return; Pref.columns=1; Pref.fitwidth=false; IsBaiduTuijian=1; } */ var sRestTDAttribute='(@class="c-default" or @class="f" or @class="c-container")'; //var sRestElementReal='//table[floor(@id div 1) = ceiling(@id div 1)]/tbody/tr/td['+sRestTDAttribute+' and not (descendant::div[@id="app-div"] or descendant::div[starts-with(@class,"op")] or descendant::a[text() = "推广"])]'; //var sRestElementTuiGuang1='//table[floor(@id div 1) = ceiling(@id div 1)]/tbody/tr/td['+sRestTDAttribute+' and (descendant::div[@id="app-div"] or descendant::div[starts-with(@class,"op")] or descendant::a[text() = "推广"])]'; //var sRestElementTuiGuang2='//div[@id="content_left"]/*[contains(@class,"result-op")]'; var sRestAttribute='(@class="result" or contains(@class," result ") or starts-with(@class,"result ") or @class="rest")'; var sRestElementReal='//div[floor(@id div 1)=ceiling(@id div 1) and '+sRestAttribute+' and not (descendant::div[@id="app-div"] or descendant::div[starts-with(@class,"op")] or descendant::a[text() = "推广"])]'; var sRestElementTuiGuang1='//div[floor(@id div 1)=ceiling(@id div 1) and '+sRestAttribute+' and (descendant::div[@id="app-div"] or descendant::div[starts-with(@class,"op")] or descendant::a[text() = "推广"])]'; var sRestElementTuiGuang2='//div[@id="content_left"]/*[contains(@class,"result-op")] | //div[@id="content_left"]/*[contains(@class,"c-frame")] '; var sRestElementTuiGuang=sRestElementTuiGuang1+' | '+sRestElementTuiGuang2; var sRestElementAll=sRestElementReal+' | '+sRestElementTuiGuang; switch (matchNode(sRestElementAll).snapshotLength > 0) { // 若存在搜索结果 case true: doit(); // 自动加载下一页 if (Pref.AutoNextPage) { NextPageLink = matchNode('//p[@id="page"]/a[text() = "下一页>"]').snapshotItem(0); // 删除第一页的页面导航条 var nav = matchNode('//p[@id="page"]').snapshotItem(0); if (nav) nav.parentNode.removeChild(nav); IsLoadingNext = false; setTimeout(loadNextPage,1000); window.addEventListener('scroll', watch_scroll, true); // 快捷键定位到下一页 var shift_Next = /shift/.test(Pref.Focus2NextPageKeys); var alt_Next = /alt/.test(Pref.Focus2NextPageKeys); var ctrl_Next = /ctrl/.test(Pref.Focus2NextPageKeys); var tmp = Pref.Focus2NextPageKeys.split('+'); var keycode_Next = tmp[tmp.length - 1]; window.addEventListener('keydown', function(event){ if ((event.altKey == alt_Next) && (event.ctrlKey == ctrl_Next) && (event.shiftKey == shift_Next) && (event.keyCode == keycode_Next) && (event.target.localName != 'INPUT') && !document.getElementById('preferences')) { var nextSplit = Pref.HideAutoNextPage?matchNode('//div[contains(@class,"bm_nextpage")]'):matchNode('//p[contains(@class,"bm_nav")]'); var i, len = nextSplit.snapshotLength, headerOffset = (Pref.floatInput && Pref.floatInputPos==1)?document.getElementById('bm_header').offsetHeight:0; for(i=0;i<len;i++){ if(window.scrollY<nextSplit.snapshotItem(i).offsetTop - headerOffset){ window.scrollTo(0, nextSplit.snapshotItem(i).offsetTop - headerOffset); break; } } event.preventDefault(); event.stopPropagation(); } }, true); // 快捷键定位到上一页 var shift_Prev = /shift/.test(Pref.Focus2PrevPageKeys); var alt_Prev = /alt/.test(Pref.Focus2PrevPageKeys); var ctrl_Prev = /ctrl/.test(Pref.Focus2PrevPageKeys); tmp = Pref.Focus2PrevPageKeys.split('+'); var keycode_Prev = tmp[tmp.length - 1]; window.addEventListener('keydown', function(event){ if ((event.altKey == alt_Prev) && (event.ctrlKey == ctrl_Prev) && (event.shiftKey == shift_Prev) && (event.keyCode == keycode_Prev) && (event.target.localName != 'INPUT') && !document.getElementById('preferences')) { var prevSplit = Pref.HideAutoNextPage?matchNode('//div[contains(@class,"bm_nextpage")]'):matchNode('//p[contains(@class,"bm_nav")]'); var i, len = prevSplit.snapshotLength, headerOffset = (Pref.floatInput && Pref.floatInputPos==1)?document.getElementById('bm_header').offsetHeight:0; for(i=len-1;i>=0;i--){ if(window.scrollY>prevSplit.snapshotItem(i).offsetTop - headerOffset){ window.scrollTo(0, prevSplit.snapshotItem(i).offsetTop - headerOffset); break; } } if(i<0){window.scrollTo(0,0);} event.preventDefault(); event.stopPropagation(); } }, true); } // 若不存在搜索结果 case false: // 禁止百度记录我的点击情况 if(Pref.DisableTracking){ removeTracking(document.body); } // 设置“相关搜索”提示框的样式 var tip=matchNode('//div[parent::div[@id="wrapper"] and descendant::td[text() = "相关搜索"]]').snapshotItem(0); if(tip){ tip.setAttribute('style','background-color: rgb(239, 242, 250); height: 60px; width: 100%; clear: both; margin-top: 0.5em;'); } // 添加 “BaiduMonkeyW 设置” addPreferences(); // 添加其他搜索引擎 if (Pref.EnableSearchInOtherEngines) { addSearchInOtherEngines(); } // 快捷键定位到搜索框 if (Pref.Focus2Keyword) { var shift = /shift/.test(Pref.Focus2KeywordKeys); var alt = /alt/.test(Pref.Focus2KeywordKeys); var ctrl = /ctrl/.test(Pref.Focus2KeywordKeys); var tmp = Pref.Focus2KeywordKeys.split('+'); var keycode = tmp[tmp.length - 1]; var lastKeyWord = ''; window.addEventListener('keydown', function(event){ if ((event.altKey == alt) && (event.ctrlKey == ctrl) && (event.shiftKey == shift) && (event.keyCode == keycode) && (event.target.localName != 'INPUT')) { with (document.getElementsByName("wd")[0]) { value = value.replace(/\s*$/, '') + ' '; focus(); switch (Pref.Focus2KeywordAction) { case 1: lastKeyWord = value; value = ''; break; case 2: break; case 3: select(); } } event.preventDefault(); event.stopPropagation(); } }, true); // 如果已选择“清除全部文字”,那么当输入框失去焦点且没有文字的时候,填入上一次的搜索字词 if (Pref.Focus2KeywordAction == 1) { document.getElementsByName("wd")[0].addEventListener('blur', function(event){ var input = event.target; if (input.value == '' && lastKeyWord != '') { input.value = lastKeyWord; } }, false); } } } /********************************************************************************************* * 各功能函数 *********************************************************************************************/ function doit(){ var css = '\ /* 添加圆角效果等 */ \ .rest {display: ' + (isChrome?(Pref.columns==1?'table':'inline-table'):'table') + '; -moz-border-radius: 0.75em;-webkit-border-radius: 0.75em;} .bm_MultiColDiv {padding-right: 0.5em;}\ /* 添加推广链接内容框的样式 */ \ /* #popDiv {-moz-column-count: ' + Pref.columns + '; -moz-column-gap: 0.5em; -webkit-column-count: ' + Pref.columns + '; -webkitcolumn-gap: 0.5em; margin-top: 1em; -moz-border-radius: 0.75em;} */ \ #popDiv {-moz-column-count: 1; -moz-column-gap: 0.5em; -webkit-column-count: 1; -webkitcolumn-gap: 0.5em; margin-top: 1em; -moz-border-radius: 0.75em;} \ /* .bm_SingleColDiv {padding-left: 0.5em;padding-right: 0.5em;} */ \ /* 让搜索结果条目顶部对齐 */ \ .f {vertical-align: top;} \ /* 百度默认的关键字样式 */ \ .bm_kw {color: #c60a00; font-style: normal;}' + // 让搜索结果适合屏幕宽度 (Pref.fitwidth?' .bm_MultiColDiv .f {width: 200em !important;}':'') + // 添加预览缩略图的样式 (Pref.addPreview?' .bm_previewimg {border: 1px solid rgb(187, 187, 187); margin: 2px 4px 5px 0px; width: ' + 111 * Number(Pref.PreviewSize) / 100 + 'px; height: ' + 82 * Number(Pref.PreviewSize) / 100 + 'px; background-position: center center; background-repeat: no-repeat;}':'') + // 添加 favicon 的样式 (Pref.addFavicon?' .bm_favicon {visibility: hidden; margin: 0 4px -3px 0; width: 16px; height: 16px;;}':'') + // 若没有 favicon 则显示空白 (Pref.addFavicon_h?'':'.bm_favicon {display: none;}') + // 添加分栏样式 ' .bm_MultiColDiv {-moz-column-count: ' + Pref.columns + '; -moz-column-gap: 0.2em; -webkit-column-count: ' + Pref.columns + '; -webkit-column-gap: 0.2em;}' + // 隐藏自动翻页分隔符 (Pref.HideAutoNextPage?' .bm_nav {display: none !important;}':'') + // 添加翻页分隔符的样式 (Pref.AutoNextPage?' .bm_nav {font-size: small; background: rgb(230, 230, 230) none repeat scroll 0% 0%; clear: both; line-height: 20px; text-align: center; margin-top: 0.7em;} .bm_nav .n {font-size: small !important;}':'') +Pref.CSS + Pref.customizeCSS; GM_addStyle(css); // 设置分栏格式 movePops_and_MultiCol(document.body, pageCount, Pref); // 给搜索结果条目添加序号 if(Pref.addResultNum){ addResultNums(document.body); } // 移动贴吧栏目至上部 var tbAs = matchNode('//a[starts-with(@href, "http://tieba.baidu.com/f?kw=")][parent::td[not('+sRestTDAttribute+')]]'); var biTds = matchNode('//table[@class="bi"]/descendant::td').snapshotItem(1); var len = tbAs.snapshotLength; if (biTds && len > 0) { for (var i = 0; i < len; i++) { biTds.appendChild(tbAs.snapshotItem(i)); biTds.innerHTML += '    '; } } // 去除右侧的广告 if (Pref.removeAd) { var adTable = matchNode('//div[@id="content_right"]').snapshotItem(0); if (adTable) { adTable.style.display='none'; } var contentLeft = matchNode('//div[@id="content_left"]').snapshotItem(0); if (contentLeft) { contentLeft.style.width='100%'; } } // 添加缩略图预览 if(Pref.addPreview){ addPreviews(document.body); } // 添加站点 Favicon if(Pref.addFavicon){ addFavicons(document.body); } // 添加“在此站点中搜索” if(Pref.searchSite){ addseatchSite(document.body); } // 统一格式,美化版面 // 只有一列或者“紧凑”模式时不需要统一格式 if (Pref.columns > 1 && Pref.displayMode > 1) { format('bm_page_' + pageCount, Pref); } // 把关键字放到<em>标签中,以便控制样式 var kw, kws = matchNode('//font[@color="#c60a00"]'); len = kws.snapshotLength; for (var i = 0; i < len; i++) { kw = kws.snapshotItem(i); var em = document.createElement('em'); em.innerHTML = kw.innerHTML; em.setAttribute('class','bm_kw'); kw.parentNode.replaceChild(em,kw); } } // 用 XPath 匹配元素 function matchNode(xpath, context){ return document.evaluate(context?(xpath.indexOf('.')==0?xpath:'.' + xpath):xpath, context || document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null); } // 添加 “BaiduMonkeyW 设置 ” //用户登录后 页面会执行一个脚本 对id=u的元素重新写值,导致脚本设置按钮丢失。现在改为在u前添加一个元素。 //2013-2-4 因为百度登录后,最上边一行有时候会很长,导致和设置按钮重叠,现在改为放在第二行。 function addPreferences(){ var titDiv = matchNode('//div[@id="u"]').snapshotItem(0); if(titDiv){ var prefDiv = document.createElement('div'); with (prefDiv) { setAttribute('style', 'position: absolute; top: 4px; right:20%; font-size:12px; white-space:pre; z-index: 101; '); innerHTML = '<span></span>'; } var preferences = document.createElement('a'); with (preferences) { setAttribute('href', 'javascript: void(0);'); innerHTML = 'BaiduMonkeyY 设置'; addEventListener('click', function(){ SetPreferences(); }, false); } prefDiv.insertBefore(preferences, prefDiv.firstChild); //当显示了baidu视频推荐的时候,设置按钮下显示提示信息。 if (IsBaiduTuijian== 1) { //prefDiv.insertBefore(document.createElement('br'), prefDiv.lastChild); var videoTip=document.createElement('span'); with (videoTip) { setAttribute('style', 'color:red;'); innerHTML='该页面有百度的整合信息,暂时单栏以适应显示结果!'; } prefDiv.insertBefore(videoTip, prefDiv.firstChild); //prefDiv.appendChild(videoTip); } //titDiv.appendChild(preferences); titDiv.parentNode.insertBefore(prefDiv, titDiv.nextSibling); } } // 添加 其他搜索引擎 function addSearchInOtherEngines(){ //var div = matchNode('//div[@id="tool"]/span[descendant::a[@href="#"]]').snapshotItem(0); //2011-10-15 发现11.8版本无法添加其他搜索引擎链接 查了代码原来 百度去掉了 div[id=tool]的元素,现在改掉这一点 加在查询按钮后。 //var div = matchNode('//form[@class="fm"]/span[@class="tools"]/span[@id="setf"]').snapshotItem(0); //2012-10-24 发现无法添加其他搜索引擎链接 查了代码 原来 百度去掉了span[@id="setf"]的元素,现在改掉这一点 加在查询按钮后。 //var div = matchNode('//form[@class="fm"]/span[@class="tools"]').snapshotItem(0); //2013-4-16 其他搜索引擎再次消失,发现tools在fm下不显示,这次新建立一个div放其他的东西 //2013-4-18 终于发现了为啥tools下内容不显示,原来是ABP给隐藏了。现在这样处理后,如果没有ABP,那么将会显示推荐 //所以这里先去掉推荐 var div = matchNode('//form[@class="fm"]/span[@class="tools"]').snapshotItem(0); if (div) div.innerHTML=''; //然后添加其他搜索引擎,看来以后尽量少在页面的广告内替换东西,最好的方法是去掉广告,新增div var div = matchNode('//form[@class="fm"]').snapshotItem(0); if (div) { var OtherEnginesWith=window.Width-650;//自动设置显示区域宽度为剩余空间 div=div.appendChild(document.createElement('div')); div.style.display='none'; // 将 div 隐藏,避免浏览器频繁重绘。最后将 div 设为可见。 div.setAttribute('style', 'max-width:'+OtherEnginesWith+'px;position: absolute;top:0px;left:650px;align:center;'); var keyword = document.getElementsByName('wd')[0].value; var keywordGB = String(document.body.innerHTML.match(/word=[^'"&]+['"&]/i)).replace(/word=|['"&]/ig, ''); var engines = Pref.OtherEngines.split(/\n/); for (i = 0; i < engines.length; i++) { var engine = engines[i].split('|'); if (engine.length > 1) { var searchEngine = document.createElement('a'); searchEngine.setAttribute('href', engines[i].replace(engine[0] + '|', '').replace(/{word}/ig, encodeURIComponent(keyword)).replace(/{gb:word}/ig, keywordGB)); searchEngine.setAttribute('target', Pref.OtherEnginesTarget); searchEngine.innerHTML = engine[0].replace(/{word}|{gb:word}/ig, keyword.replace('<', '<').replace('>', '>')); //div.innerHTML = div.innerHTML+'<br/>'+searchEngine.outerHTML; //div.appendChild(document.createTextNode(' | ')); div.appendChild(searchEngine); div.appendChild(document.createElement('br')); } } div.style.display=''; } } // 给搜索结果条目添加序号 function addResultNums(doc){ //div[@id="content_left" or @class="bm_nextpage"]/ } var resTds = matchNode(sRestElementReal, doc); console.log('restds:'+resTds.snapshotLength); for (var i = 0; i < resTds.snapshotLength; i++) { var num = document.createElement('span'); num.setAttribute('class','bm_num'); num.innerHTML = ' ' + (ResultNum++) + ' '; var resTd = resTds.snapshotItem(i); if (Pref.addResultNum_h) { //在标题最前边同一行添加序号 var resLinks=matchNode('//descendant::*[@class="t" and child::a]', resTd); if (resLinks.snapshotLength==1) { var resLink = resLinks.snapshotItem(0); resLink.insertBefore(num, resLink.firstChild); } } else { //在标题上一行添加序号(表格采用H3,会保持单独以后那个,造成序号也是单独一行) resTd.insertBefore(num, resTd.firstChild); } } } function isAmazonCOM(href) { return href.toLowerCase().indexOf("www.amazon.com") == 7; } function getASIN(href) { var asin = href.match(/amazon.+\W+([0-9A-Z]{10})(\W+|$)/i); return asin ? asin[1] : null; } function getFullDomain(href) { var domain = href.match(/http(?:s)?:\/\/[^\/]+/i); return domain ? domain[0].toLowerCase() : href; } function getGPSub(href) { var site = getFullDomain(href); site = site.toLowerCase(); if (site.indexOf("https://") == 0) { site = site.substring(8, site.length); } else if (site.indexOf("http://") == 0) { site = site.substring(7, site.length); } if (site.indexOf("www.") == 0) { site = site.substring(4, site.length); } return site.length > 0 ? ""+site.charAt(0) : "a"; } // 根据站点根域名的首字母分配 googlepreview 服务器,分散服务器压力 function getImageURL(href) { var fullDomain = getFullDomain(href); var protocol = "unknown"; var site = fullDomain; if (site.indexOf("http://") == 0) { site = site.substring(7, site.length); protocol = "http://"; } else if (site.indexOf("https://") == 0) { site = site.substring(8, site.length); protocol = "https://"; } var preview = "http://"+getGPSub(site)+".googlepreview.com/preview?s=" + protocol + site + "&ra=1"; if (!isAmazonCOM(href)) { return preview; } var isbn = getASIN(href); if (isbn != null) { if (isAmazonCOM(href)) { return "http://images.amazon.com/images/P/" + isbn + ".01.TZZZZZZZ.jpg"; } } return preview; } // 将字符串转换为二进制,否则 btoa() 方法出错 function data_string(data){ var data_string = ''; for (var i = 0, il = data.length; i < il; i++) data_string += String.fromCharCode(data[i].charCodeAt(0) & 0xff); return data_string; }; /* * googlepreview 会检查 img 请求的 Referer ,如果发现不是来自 google 站点,则会返回 stop 的图片。 * 所以需要用 xmlhttpRequest 发出请求,避免 Referer 。 * 异步请求并得到图片的 base64 编码。(跨域获得图片的方法参见 Cross Domain Images in Userscript,http://pastebin.ca/1425789) */ function getImg(img, imgUrl){ GM_xmlhttpRequest({ method: "GET", url: imgUrl, overrideMimeType: 'text/plain; charset=x-user-defined', onload: function(rsp) { img.src='data:image/jpg;base64,' + btoa(data_string(rsp.responseText)); } }); } // 添加缩略图预览。先使用 thumbshots.org 的服务,如果不能访问则使用 googlepreview 的服务(提取自 googlepreview 扩展,部分修改)。 function addPreviews(doc){ //sina改版 造成链接位置更改 //var resLinks = matchNode('//td[@class="f" and (child::a or child::font/a) and not(descendant::a[text() = "推广"])]/a', doc); var resLinks = matchNode('//td['+sRestTDAttribute+' and (child::h3/a)]/h3/a', doc); var i, len = resLinks.snapshotLength; for (i = 0; i < len; i++) { var resLink = resLinks.snapshotItem(i); var a = document.createElement('a'); a.setAttribute('target','_blank'); a.setAttribute('href',resLink.href); var imgBlank = document.createElement('img'); with(imgBlank){ setAttribute('class', 'bm_previewimg'); setAttribute('align', 'left'); src=""; } var img = document.createElement('img'); with (img) { setAttribute('class', 'bm_previewimg'); setAttribute('title', ''); setAttribute('align', 'left'); setAttribute('src', 'http://open.thumbshots.org/image.pxf?url=' + resLink.href); // GM_log(resLink.href); style.display='none'; addEventListener("load", function(e){ // 先移除空白图,再显示出真正的缩略图 e.target.parentNode.removeChild(e.target.previousSibling); e.target.style.display = ''; }, false); if(!isChrome){ addEventListener("error", function(e){ e.target.style.border = '1px solid blue'; getImg(e.target, getImageURL((e.target.src.match(/\?url=.*/i) + '').replace(/\?url=/ig,''))); }, false); } } a.appendChild(imgBlank); a.appendChild(img); resLink.parentNode.insertBefore(a, resLink); } } // 添加站点 Favicon function addFavicons(doc){ //因为百度隐藏了真是的链接地址,而这里只要获取主站地址即可 var resElements = matchNode('//td['+sRestTDAttribute+' and (descendant::*[@class="g" or @style="color:#008000" or @color="#008000"]) and descendant::*[@class="t"] and not(descendant::a[text() = "推广"])]', doc); var i, len = resElements.snapshotLength; for (i = 0; i < len; i++) { var resElement = resElements.snapshotItem(i); var resSites=matchNode('//descendant::*[@class="g" or @style="color:#008000" or @color="#008000"]', resElement); if (resSites.snapshotLength==1) { var base = resSites.snapshotItem(0).innerHTML.match(/[\w\.\-]+\//); base = 'http://'+base; } var resLinks=matchNode('//descendant::*[@class="t" and child::a]', resElement); if (resLinks.snapshotLength==1) { var resLink = resLinks.snapshotItem(0); } var img = document.createElement('img'); with (img) { setAttribute('class','bm_favicon'); addEventListener("load", function(e){ e.target.style.display = 'inline'; e.target.style.visibility = 'visible'; }, false); src=base + 'favicon.ico'; } if (resLink.firstChild.className=="bm_num") resLink.insertBefore(img, resLink.firstChild.nextSibling); else resLink.insertBefore(img, resLink.firstChild); } } // 添加“在此站点中搜索” function addseatchSite(doc){ if(location.href.indexOf(escape('site:'))>=0){ return; // 如果已经是 site: 搜索了则退出 } // 将点击搜索按钮的 Javascript 添加到 head 中 if (!document.getElementById('ClickSearchBtnJS')) { var head = document.getElementsByTagName("head")[0]; var ClickSearchBtnJS = document.createElement('script'); with(ClickSearchBtnJS){ setAttribute('id', 'ClickSearchBtnJS'); type = "application/x-javascript"; innerHTML = '\ function searchSite(url){\ document.forms[0].wd.value += " site:" + url;\ document.forms[0].submit();\ }'; } head.appendChild(ClickSearchBtnJS); } //百度网站在 百度快照 前写入了空格,采用这个normalize-space可以去掉前后的空格 //var cacheLinks = matchNode('//a[text() = "百度快照"]',doc); var cacheLinks = matchNode('//a[normalize-space(text()) = "百度快照"]',doc); var i, len = cacheLinks.snapshotLength; for (i = 0; i < len; i++) { try { var cacheLink = cacheLinks.snapshotItem(i); var site = cacheLink.previousSibling.previousSibling.innerHTML.replace(/<[^>]*>/ig, '').split('/')[0]; var a = document.createElement('a'); with (a) { innerHTML = '在此站点中搜索'; setAttribute('class', 'm'); setAttribute('title', '在 ' + site + ' 中搜索'); setAttribute('href', 'javascript:searchSite("' + site + '")'); } cacheLink.parentNode.insertBefore(a, cacheLink.nextSibling); cacheLink.parentNode.insertBefore(document.createTextNode(' - '), cacheLink.nextSibling); } catch (e) { } } } // 禁止百度记录我的点击情况 function removeTracking(doc){ var links = matchNode('//table[@class="rest"]/descendant::a[string-length(@onmousedown)>0]',doc); var i, len = links.snapshotLength; for (i = 0; i < len; i++) { links.snapshotItem(i).removeAttribute('onmousedown'); } } // 分栏 function movePops_and_MultiCol(doc, pagecount, Pref){ var i, len; //2013-3-13:已经没有跟搜索结果同级别的br了 所以这句没有用了 // 去除没用的 <br> // var Brs = matchNode('//br[preceding-sibling::table[tbody/tr/td['+sRestTDAttribute+']]]', doc); // len = Brs.snapshotLength; // for (i = 0; i < len; i++) { // Brs.snapshotItem(i).style.display='none'; // } // 在第一个条目前插入一个 DIV ,id = bm_page_1,2,3,etc,用来容纳搜索结果条目。 var firstTable; if (pagecount=='pref')//pagecount=='pref' 说明是预览界面 { firstTable = matchNode('//table[tbody/tr/td['+sRestTDAttribute+']]',doc).snapshotItem(0); } else { firstTable = matchNode(sRestElementAll,doc).snapshotItem(0); } //alert(firstTable); var resContainer = document.createElement('div'); resContainer.setAttribute('id', 'bm_page_' + pagecount); firstTable.parentNode.insertBefore(resContainer, firstTable); // 移动“推广”条目 // var popTables = matchNode('//table[tbody/tr/td[(contains(@class,"f ") or @class="f") and descendant::a[text() = "推广"]]]',doc); //div[@id="content_left"]/ var popTables = matchNode(sRestElementTuiGuang,doc); len = popTables.snapshotLength; console.log("tuiguang:"+len); if (len > 0) { // popContainer 用来盛放推广条目,将它添加在搜索结果 DIV 之前 var popContainer = document.createElement('div'); popContainer.setAttribute('class', 'containerTuiGuang'); //这里推广链接容器样式 ,但不处理格式 popContainer.setAttribute('id', 'hi_abp_not_block_me'); resContainer.parentNode.insertBefore(popContainer, resContainer); var popContainerTable = document.createElement('table'); popContainerTable.innerHTML = '<span> </span><a id="togglePops" href="javascript: void(0);"><font size="-1">显示/关闭' + len + '条推广链接 </font></a><br><div id="popDiv" class="bm_MultiColDiv"></div><br>'; popContainer.appendChild(popContainerTable); var popDiv = document.getElementById('popDiv'); //popDiv.style.display = 'none'; // 添加显示、隐藏“推广”条目的事件 document.getElementById('togglePops').addEventListener('click', function(){ popDiv.style.display = popDiv.style.display == 'none' ? '' : 'none'; }, false); for (i = 0; i < len; i++) { var popTable = popTables.snapshotItem(i); var oldClass=popTable.getAttribute('class'); popTable.setAttribute('class', oldClass+' restTuiGuang'); //这里推广链接宽度样式 可能需要和搜索结果不同, 所以暂定为restTuiGuang,但不处理格式 //GM_log(popTable.outerHTML); popDiv.appendChild(popTable); // 移动结果 Table } } // 移动搜索结果条目 resContainer.setAttribute('id','bm_page_' + pagecount); // 如果打开了设置界面,那么不添加 class ,使得设置界面中的预览能够正常变化 if(!document.getElementById('preferences')) resContainer.setAttribute('class','bm_MultiColDiv'); //var resTables = matchNode('//table[tbody/tr/td/@class="f"][not(descendant::a[text() = "推广"])]', doc); //div[@id="content_left" or @class="bm_nextpage"]/ var resTables; if (pagecount=='pref') //pagecount=='pref' 说明是预览界面 { resTables = matchNode('//table[tbody/tr/td['+sRestTDAttribute+']][not(descendant::div[@id="app-div"] or descendant::div[starts-with(@class,"op")] or descendant::a[text() = "推广"])]', doc); } else { resTables = matchNode(sRestElementReal, doc); } len = resTables.snapshotLength; //GM_log("restTableCount"+len); if (len > 0) { var cols = Pref.columns; var resTable; // 设置搜索结果的排列方向。1-横向;2-纵向 switch (Pref.direction) { case 1: for (var j = 0; j < cols; j++) { for (i = j; i < len; i += cols) { resTable = resTables.snapshotItem(i); resTable.setAttribute('class', 'rest'); resContainer.appendChild(resTable); // 移动结果 Table } } break; case 2: for (i = 0; i < len; i++) { resTable = resTables.snapshotItem(i); resTable.setAttribute('class', 'rest'); resContainer.appendChild(resTable); // 移动结果 Table } break; } } } // 统一格式,美化版面 function format(id, Pref){ var i, j, len; var resContainer = document.getElementById(id); var resTables = matchNode('//div[@id="' + id + '"]/table[@class="rest" or @class="plus"]'); len = resTables.snapshotLength; if (len > 0) { switch (Pref.displayMode) { case 1: break; case 2: /* * 由于使用的 -moz-column-count 样式分列,为了保持每一列顶部对齐,必须使得每列所包含的 child 数量一样,所以要插入 plusNum 个 table 充数 */ var modNum = len % Pref.columns; if (modNum > 0) { // plusNum 为统一格式而补充的 table 数量; insertIndex 为需要插入补充 table 的位置 var plusNum = Pref.columns - modNum; var insertIndex = Math.floor(len / Pref.columns); for (i = 0; i < plusNum; i++) { var plustable = document.createElement('table'); plustable.setAttribute('class', 'plus'); plustable.innerHTML = '<br />'; resContainer.insertBefore(plustable, resTables.snapshotItem(len - 1 - insertIndex * i).nextSibling); } } break; case 3: /* * 由于使用的 -moz-column-count 样式分列,为了保持每一列顶部对齐,必须使得每列所包含的 child 数量一样,所以要插入 plusNum 个 table 充数 */ var modNum = len % Pref.columns; if (modNum > 0) { // plusNum 为统一格式而补充的 table 数量; insertIndex 为需要插入补充 table 的位置 var plusNum = Pref.columns - modNum; var insertIndex = Math.floor(len / Pref.columns); for (i = 1; i <= plusNum; i++) { var plustable = document.createElement('table'); plustable.setAttribute('class', 'plus'); plustable.innerHTML = '<br />'; resContainer.insertBefore(plustable, resTables.snapshotItem(insertIndex * i)); } } break; case 4: /* * 由于使用的 -moz-column-count 样式分列,为了保持每一列顶部对齐,必须使得每列所包含的 child 数量一样,所以要插入 plusNum 个 table 充数 */ var modNum = len % Pref.columns; if (modNum > 0) { // plusNum 为统一格式而补充的 table 数量。这些 table 将补充在末尾。 var plusNum = Pref.columns - modNum; for (i = 0; i < plusNum; i++) { var plustable = document.createElement('table'); plustable.setAttribute('class', 'plus'); plustable.innerHTML = '<br />'; resContainer.appendChild(plustable); } } break; } var Highest, height, isDiff; var tables = matchNode('//div[@id="' + id + '"]/table[@class="rest" or @class="plus"]'); len = tables.snapshotLength; var rows = len / Pref.columns; var modTables = []; for (j = 0; j < rows; j++) { isDiff = false; Highest = tables.snapshotItem(j).offsetHeight; // 找出同一行 table 中的最大高度 for (i = j+rows; i < len; i += rows) { height = tables.snapshotItem(i).offsetHeight; if (height != Highest) { isDiff = true; if (height > Highest) { Highest = height; } } } if (isDiff == true) { // 将需要改变高度的 table 和其所需高度放入数组中 for (i = j; i < len; i += rows) { var tmp = []; tmp.push(tables.snapshotItem(i)); tmp.push(Highest); modTables.push(tmp); } } } // 让同一行的 table 具有相同的高度 len = modTables.length; resContainer.style.display='none'; for(i=0;i<len;i++){ modTables[i][0].setAttribute('style', 'height: ' + (modTables[i][1]) + 'px !important;'); } resContainer.style.display=''; } } // 向 head 中添加 CSS 样式 function addCSS(cssString){ var head = document.getElementsByTagName("head")[0]; var css = document.createElement('style'); css.innerHTML = cssString; head.appendChild(css); return css; } // CSS 样式设置有选项变动时,更新预览效果 function cssOnChange(input){ var i, len, cInput; var css = []; var inputs = matchNode('//input[@class="' + input.className + '"]'); len = inputs.snapshotLength; for(i=0;i<len;i++){ cInput = inputs.snapshotItem(i); if(cInput.value){ css.push(' ' + cInput.name + ': ' + cInput.value + ' !important;'); } } var textarea = matchNode('//textarea[@id="' + input.className + '_gen"]').snapshotItem(0); if(css.length==0){ // 如果没有 CSS 设置,则清空 textarea textarea.innerHTML = textarea.value = ''; // 赋值 innerHTML 是为了可以使用 XPath } else{ switch (input.className) { case 'css_holder': css.unshift('.rest {'); break; case 'css_counter': css.unshift('.bm_num {'); break; case 'css_keyword': css.unshift('.bm_kw {'); break; } css.push('}'); textarea.innerHTML = textarea.value = css.join('\n'); // 赋值 innerHTML 是为了可以使用 XPath } prefOnChange(); } // 设置界面有选项变动时,更新预览效果 var previewCss; function prefOnChange(){ var i, len; var numcol = document.getElementById('numcol'); var direction = document.getElementById('direction'); var mode = document.getElementById('mode'); var bm_pref_Pref = { // 分栏数量,默认 2 columns : Number(numcol.options[numcol.selectedIndex].value) // 搜索结果的排列方向:1-横向;2-纵向(默认) ,direction : Number(direction.options[direction.selectedIndex].value) // 显示模式:1-紧凑;2-对齐,但比较松散(默认);3-对齐,但比较松散;4-对齐,但比较松散 ,displayMode : Number(mode.options[mode.selectedIndex].value) // 给搜索结果条目添加序号,默认 关闭 ,addResultNum : document.getElementById('addResultNums').checked // 添加缩略图预览,默认 关闭 ,addPreview : document.getElementById('addPreviews').checked // 缩略图大小,默认 100% ,PreviewSize : isNaN(document.getElementById('PreviewSize').value)?'100':document.getElementById('PreviewSize').value // 添加站点 Favicon,默认 关闭 ,addFavicon : document.getElementById('addFavicons').checked // 让搜索结果适合屏幕宽度,默认 关闭 ,fitwidth : document.getElementById('fitwidth').checked // 添加“在此站点中搜索” ,searchSite : document.getElementById('searchSite').checked } // 阅读方向为“横向”时,排版模式将固定为“紧凑”或“对齐1” if(bm_pref_Pref.direction==1 && bm_pref_Pref.displayMode>2){ bm_pref_Pref.displayMode=2; document.getElementById('mode').options[1].selected=true; } // 获取 CSS 设置 var css = ''; var textareas = matchNode('//textarea[string-length(text())>0 and ancestor::table[@class="bm_pref_css"]]'); len = textareas.snapshotLength; for (i = 0; i < len; i++) { css += '#bm_pref_gui ' + textareas.snapshotItem(i).value + '\n'; } css += '#bm_pref_gui ' + document.getElementById('customizeCSS').value; if(previewCss) previewCss.parentNode.removeChild(previewCss); previewCss = addCSS(css); var bm_pref_res = document.getElementById('bm_pref_res').cloneNode(true); bm_pref_res.removeAttribute('style'); var resLinks = matchNode('//td['+sRestTDAttribute+'][not(descendant::a[text() = "推广"])]/a', bm_pref_res); var bm_pref_ResultNum = 1; for (var i = 0; i < resLinks.snapshotLength; i++) { var resLink = resLinks.snapshotItem(i); // 添加缩略图预览 if (bm_pref_Pref.addPreview) { var div = document.createElement('div'); div.setAttribute('style', 'border: 1px solid rgb(187, 187, 187); float: left; margin: 2px 4px 5px 0px; width: ' + 111 * Number(bm_pref_Pref.PreviewSize) / 100 + 'px; height: ' + 82 * Number(bm_pref_Pref.PreviewSize) / 100 + 'px; background-color: rgb(170, 170, 170);'); resLink.parentNode.insertBefore(div, resLink); } // 给搜索结果条目添加序号 if (bm_pref_Pref.addResultNum) { var num = document.createElement('span'); num.setAttribute('class', 'bm_num'); num.innerHTML = ' ' + (bm_pref_ResultNum++) + ' '; resLink.parentNode.insertBefore(num, resLink); } // 添加站点 Favicon if (bm_pref_Pref.addFavicon) { var div = document.createElement('div'); div.setAttribute('style', 'border: 1px solid rgb(187, 187, 187); margin: 3px 4px -3px 0px; width: 16px; height: 16px; background-color: rgb(170, 170, 170); display: inline-block;'); resLink.parentNode.insertBefore(div, resLink); } } // 添加“在此站点中搜索” if (bm_pref_Pref.searchSite) { var cacheLinks = matchNode('//a[text() = "百度快照"]', bm_pref_res); len = cacheLinks.snapshotLength; for(i=0;i<len;i++){ var cacheLink = cacheLinks.snapshotItem(i); var a = document.createElement('a'); with(a){ innerHTML = '在此站点中搜索'; setAttribute('class','m'); setAttribute('href','javascript: void(0);'); } cacheLink.parentNode.insertBefore(a,cacheLink.nextSibling); cacheLink.parentNode.insertBefore(document.createTextNode(' - '),cacheLink.nextSibling); } } // 适合宽度 var divs = matchNode('//td['+sRestTDAttribute+']', bm_pref_res); len = divs.snapshotLength; for (i = 0; i < len; i++) { if (bm_pref_Pref.fitwidth) { divs.snapshotItem(i).setAttribute('style','width: 200em !important;'); } else { divs.snapshotItem(i).setAttribute('style','width: 32em !important;'); } } // 设置分栏格式 movePops_and_MultiCol(bm_pref_res, 'pref', bm_pref_Pref); // 先清除现有的预览效果 var div = matchNode('//div[@id="bm_pref_res" and not(contains(@style,"display:"))]').snapshotItem(0); if (div) div.parentNode.removeChild(div); // 添加新的预览效果 document.getElementById('bm_pref_preview').appendChild(bm_pref_res); // 设置分栏数量 var bm_pref_container = document.getElementById('bm_page_pref'); bm_pref_container.setAttribute('style','-moz-column-count: ' + bm_pref_Pref.columns + '; -moz-column-gap: 0.2em; -webkit-column-count: ' + bm_pref_Pref.columns + '; -webkit-column-gap: 0.2em;'); // 统一格式,美化版面 format('bm_page_pref', bm_pref_Pref); } // 添加 CSS 样式候选项 var lstVL=null; function addList(target, options, style){ if (!target || !options) return; if (lstVL != null) { lstVL.parentNode.removeChild(lstVL); lstVL = null; return; } var input; var lst = document.createElement("div"); lst.className = "virtual-list"; if (target.nodeName.toUpperCase() == "INPUT") { input = target; lst.style.marginTop = input.offsetHeight + "px"; } else { input = target.previousSibling; lst.style.marginLeft = -(input.offsetWidth) + "px"; } lst.style.minWidth = (target.offsetWidth + input.offsetWidth - 4) + "px"; lstVL = lst; var setVal = function(ev){ input.value = ev.target.innerHTML; input.focus(); input.blur(); lstVL.parentNode.removeChild(lstVL); lstVL = null; cssOnChange(input); }; var db = options.split(","); var len = db.length; for (var x = 0; x < len; x++) { var p = document.createElement("span"); p.innerHTML = db[x]; p.addEventListener("click", setVal, false); if (input.value == db[x]) p.className = "selected"; lst.appendChild(p); } target.appendChild(lst); return false; }; function getColor(ev){ var x = ev.layerX - 10, y= ev.layerY - 10; var Rmx = 0, Gmx = 0, Bmx = 0; if (y <= 32) { Rmx = 255; Gmx = (y / 32) * 255; Bmx = 0; } else if (y <= 64) { y = y - 32; Rmx = 255 - (y / 32) * 255; Gmx = 255; Bmx = 0; } else if (y <= 96) { y = y - 64; Rmx = 0; Gmx = 255; Bmx = (y / 32) * 255; } else if (y <= 128) { y = y - 96; Rmx = 0; Gmx = 255 - (y / 32) * 255; Bmx = 255; } else if (y <= 160) { y = y - 128; Rmx = (y / 32) * 255; Gmx = 0; Bmx = 255; } else { y = y - 160; Rmx = 255; Gmx = 0; Bmx = 255 - (y / 32) * 255; }; var r, g, b; if (x <= 50) { r = Math.abs(Math.floor(Rmx * x / 50)); g = Math.abs(Math.floor(Gmx * x / 50)); b = Math.abs(Math.floor(Bmx * x / 50)); } else { x -= 50; r = Math.abs(Math.floor(Rmx + (x / 50) * (255 - Rmx))); g = Math.abs(Math.floor(Gmx + (x / 50) * (255 - Gmx))); b = Math.abs(Math.floor(Bmx + (x / 50) * (255 - Bmx))); }; r = r>255?255:r; g = g>255?255:g; b = b>255?255:b; var c = "#"; c += Math.floor(r / 16).toString(16); c += (r % 16).toString(16); c += Math.floor(g / 16).toString(16); c += (g % 16).toString(16); c += Math.floor(b / 16).toString(16); c += (b % 16).toString(16); return c.toUpperCase(); }; function addColorPicker(target){ var cp = document.getElementById("colorpicker"); if (cp) { cp.parentNode.removeChild(cp); return; } cp = document.createElement("div"); cp.id = "colorpicker"; var input; if (target.nodeName.toUpperCase() == "INPUT") { input = target; cp.style.marginTop = input.offsetHeight + "px"; } else { input = target.previousSibling; cp.style.marginLeft = "-100px"; } var pre = document.createElement("span"); var img = document.createElement("img"); with (img) { src = ""; addEventListener("mousemove", function(ev){ var c = getColor(ev); pre.style.background = c; }, false); addEventListener("click", function(ev){ var c = getColor(ev); input.value = c; input.focus(); input.blur(); cp.parentNode.removeChild(cp); cssOnChange(input); }, false); addEventListener("mouseout", function(ev){ cp.parentNode.removeChild(cp); }, false); } cp.appendChild(img); cp.appendChild(pre); target.appendChild(cp); return false; }; // 生成 CSS 选项的 table function addCssTable(type, tableStyle, css){ css = (css + '').replace(/null/ig,''); return ' <table id="bm_pref_css_' + type + '" class="bm_pref_css" style="' + tableStyle +'">\ <tbody>\ <tr>\ <td>\ <label>\ Font-Size:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="font-size" size="8" type="text" value="' + ((css.match(/\sfont-size:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Font-Color:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="color" size="8" type="text" value="' + ((css.match(/\scolor:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Font-Weight:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="font-weight" size="8" type="text" value="' + ((css.match(/\sfont-weight:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Text-Decoration:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="text-decoration" size="8" type="text" value="' + ((css.match(/\stext-decoration:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Text-Align:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="text-align" size="8" type="text" value="' + ((css.match(/\stext-align:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ White-Space:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="white-space" size="8" type="text" value="' + ((css.match(/\swhite-space:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Background-Color:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="background-color" size="8" type="text" value="' + ((css.match(/\sbackground-color:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Border-Color:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="border-color" size="8" type="text" value="' + ((css.match(/\sborder-color:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Border-Style:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="border-style" size="8" type="text" value="' + ((css.match(/\sborder-style:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Border-Width:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="border-width" size="8" type="text" value="' + ((css.match(/\sborder-width:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Margin-Left:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="margin-left" size="8" type="text" value="' + ((css.match(/\smargin-left:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Padding-Left:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="padding-left" size="8" type="text" value="' + ((css.match(/\spadding-left:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Margin-Right:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="margin-right" size="8" type="text" value="' + ((css.match(/\smargin-right:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Padding-Right:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="padding-right" size="8" type="text" value="' + ((css.match(/\spadding-right:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Margin-Top:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="margin-top" size="8" type="text" value="' + ((css.match(/\smargin-top:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Padding-Top:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="padding-top" size="8" type="text" value="' + ((css.match(/\spadding-top:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Margin-Bottom:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="margin-bottom" size="8" type="text" value="' + ((css.match(/\smargin-bottom:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Padding-Bottom:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="padding-bottom" size="8" type="text" value="' + ((css.match(/\spadding-bottom:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td>\ <label>\ Float:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="float" size="8" type="text" value="' + ((css.match(/\sfloat:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ <td>\ <label>\ Clear:\ </label>\ </td>\ <td>\ <input class="css_' + type + '" name="clear" size="8" type="text" value="' + ((css.match(/\sclear:[^!]*!/i) + '').replace(/.*:\s*|\s*!|null/ig,'') + '') + '"><span class="bm_pref_css_span">▼</span>\ </td>\ </tr>\ <tr>\ <td colspan="4">\ <label>\ 生成的 CSS :\ </label><br>\ <label>\ <textarea id="css_' + type + '_gen" rows="3" cols="60" wrap="off" style="font-size: small;" readonly>' + css + '</textarea>\ </label>\ </td>\ </tr>\ </tbody>\ </table>\ '; } // 闪动具有指定 class 的元素 function blink(cls, count){ if(count>5){ return; } var i, len; var eles = matchNode('//*[@class="' + cls + '" and ancestor::div[@id="bm_pref_gui"]]'); len = eles.snapshotLength; for(i=0;i<len;i++){ eles.snapshotItem(i).style.border='1px solid red'; } setTimeout(function(){ for (i = 0; i < len; i++) { eles.snapshotItem(i).style.border = ''; } setTimeout(function(){ blink(cls, ++count); }, 150); }, 150); } // 设置参数 function SetPreferences(){ var i, len; var bodyElements = [], bodyElementsDisplay = []; var allElements = document.body.childNodes; len = allElements.length; for(i=0;i<len;i++){ if (allElements[i].nodeType==1 && getComputedStyle(allElements[i],'').display != 'none'){ bodyElements.push(allElements[i]); bodyElementsDisplay.push(getComputedStyle(allElements[i],'').display); allElements[i].style.display='none'; }; } var code2keyTable={'65':'A','66':'B','67':'C','68':'D','69':'E','70':'F','71':'G','72':'H','73':'I','74':'J','75':'K','76':'L','77':'M','78':'N','79':'O','80':'P','81':'Q','82':'R','83':'S','84':'T','85':'U','86':'V','87':'W','88':'X','89':'Y','90':'Z','48':'0','49':'1','50':'2','51':'3','52':'4','53':'5','54':'6','55':'7','56':'8','57':'9','96':'Numpad 0','97':'Numpad 1','98':'Numpad 2','99':'Numpad 3','100':'Numpad 4','101':'Numpad 5','102':'Numpad 6','103':'Numpad 7','104':'Numpad 8','105':'Numpad 9','106':'Numpad *','107':'Numpad +','108':'Numpad Enter','109':'Numpad -','110':'Numpad .','111':'Numpad /','112':'F1','113':'F2','114':'F3','115':'F4','116':'F5','117':'F6','118':'F7','119':'F8','120':'F9','121':'F10','122':'F11','123':'F12','8':'BackSpace','9':'Tab','12':'Clear','13':'Enter','16':'Shift','17':'Control','18':'Alt','20':'Cape Lock','27':'Esc','32':'Spacebar','33':'Page Up','34':'Page Down','35':'End','36':'Home','37':'←/Left Arrow','38':'↑/Up Arrow','39':'→/Right Arrow','40':'↓/Down Arrow','45':'Insert','46':'Delete','144':'Num Lock','186':';:','187':'=+','188':',<','189':'-_','190':'.>','191':'/?','192':'`~','219':'[{','220':'\|','221':']}','222':'"'}; // 将 keycode 转换成按键名称 function parse2keys(keycodes){ var array = keycodes.split('+'); array[array.length-1]=code2keyTable[array[array.length-1]] || ''; return array.join('+'); } // 将设置界面的 css 添加到 head 中 addCSS('\ #bm_pref_gui {\ background-color: white;\ border: 2px solid black;\ margin: 0 auto;\ text-align: left;\ -moz-border-radius: 0.5em;\ -webkit-border-radius: 0.5em;\ }\ \ #bm_pref_gui_title {\ font-weight: bold;\ background: #CCCCCC;\ color: #666666;\ }\ \ #bm_pref_gui fieldset {\ margin-left: 1em;\ margin-right: 1em;\ margin-top: 0.5em;\ margin-bottom: 0.5em;\ }\ \ #bm_pref_gui legend {\ font-size : 12pt;\ font-weight : bold;\ }\ \ #bm_pref_gui .f {\ line-height: 1.5em;\ }\ \ #bm_pref_gui label {\ font-size: 13px;\ margin-left: 0.5em;\ }\ \ #bm_pref_options div {\ margin-bottom: 0.3em;\ padding-left: 1em;\ }\ \ .bm_pref_css {\ font-size: small;\ padding: 0.5em 0;\ white-space: nowrap;\ }\ \ .bm_pref_css_span {\ display : inline-block;\ font-size : 12px;\ border : 1px solid #999;\ color : #000;\ background-color : #fff;\ padding : 1px;\ margin-right: 0.5em;\ -moz-border-radius-topright :5px;\ -moz-border-radius-topleft :0px;\ -moz-border-radius-bottomright :5px;\ -moz-border-radius-bottomleft :0px;\ -webit-border-radius-topright :5px;\ -webit-border-radius-topleft :0px;\ -webit-border-radius-bottomright :5px;\ -webit-border-radius-bottomleft :0px;\ }\ .bm_pref_css_span:hover {\ color : #fff;\ background-color : #000;\ cursor : default;\ }\ .virtual-list {\ position : absolute;\ display : block !important;\ overflow-y : auto;\ overflow-x : hidden;\ margin : 0;\ margin-top : 2px;\ padding : 0 !important;\ max-height : 200px;\ border : 1px solid #333;\ background-color : white;\ }\ \ .virtual-list span {\ display : block !important;\ margin : 0;\ padding : 2px 0.5em;\ font-family : Arial, Hevetica, sans-serif;\ font-size : 9pt;\ color : #000;\ text-align : left;\ }\ \ .virtual-list span:hover {\ background-color : #33f;\ color : white;\ }\ \ .virtual-list span.selected {\ background-color : #88f;\ color : white;\ }\ \ #colorpicker {\ position : absolute;\ display : block;\ margin-top : 2px;\ margin-left : -30px;\ z-index : 9999999;\ }\ #colorpicker span {\ display : inline-block;\ width : 24px;\ height : 24px;\ border : 2px solid #000;\ margin-left : 2px;\ vertical-align: top;\ }\ #colorpicker img {\ width : 100px;\ height : 192px;\ padding : 7px;\ background-color : #888;\ border : 3px solid #333;\ cursor : crosshair;\ }\ #default_button {\ width: 12em;\ }\ '); var bgDiv = document.createElement('div'); with(bgDiv){ setAttribute('id','preferences'); setAttribute('style','display: table; width:800px; height: 100%;'); innerHTML = '<div style="display: table-cell; text-align: center; vertical-align: middle; padding: 1em;">\ <div id="bm_pref_gui">\ <center>\ <table width="100%">\ <tr id="bm_pref_gui_title">\ <td colspan="2">\ <div style="float: left; padding-left: 0.8em; font-size: small;">BaiduMonkeyY 参数设置 v:' + scriptVersion + '</div>\ <div id="check_update" style="float: right; padding-right: 0.8em; font-size: small;"><a href="' + scriptUrl + '" target="_blank">访问页面</a></div>\ <div style="float: right; padding-right: 0.8em; font-size: small;">欢迎来<a href="mailto:[email protected]" target="_blank">这里</a>发表任何意见或建议。</div>\ </td>\ </tr>\ <tr>\ <td colspan="2">\ <fieldset id="bm_pref_preview">\ <legend>效果预览</legend>\ <div id="bm_pref_res" class="bm_pref_preview_id-res" style="display: none;">\ <table border="0" cellpadding="0" cellspacing="0">\ <tbody>\ <tr>\ <td class="c-default">\ <a href="javascript: void(0);"><font size="3">标题一<em class="bm_kw">关键字</em>标题一</font></a>\ <br>\ <font size="-1">\ 描述一<em class="bm_kw">关键字</em>描述一... 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一 <b>...</b>描述一<em class="bm_kw">关键字</em>描述一. <b>...</b> 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一 描述一描述一描述一...\ <br>\ <font color="#008000">\ www.urlstring1.com/path/ 00K 2000-1-1 \ </font>\ - <a href="javascript: void(0);" class="m">百度快照</a>\ <br>\ </font>\ </td>\ </tr>\ </tbody>\ </table>\ <table border="0" cellpadding="0" cellspacing="0">\ <tbody>\ <tr>\ <td class="c-default">\ <a href="javascript: void(0);"><font size="3">标题二<em class="bm_kw">关键字</em>标题二</font></a>\ <br>\ <font size="-1">\ 描述二<em class="bm_kw">关键字</em>描述二... 描述二描述二描述二 描述二描述二描述二 描述二描述二描述二 描述二描述二描述二 描述二描述二描述二 <b>...</b>\ <br>\ <font color="#008000">\ www.urlstring2.com/path/ 00K 2000-1-1 \ </font>\ - <a href="javascript: void(0);" class="m">百度快照</a>\ <br>\ </font>\ </td>\ </tr>\ </tbody>\ </table>\ <table border="0" cellpadding="0" cellspacing="0">\ <tbody>\ <tr>\ <td class="c-default">\ <a href="javascript: void(0);"><font size="3">标题三<em class="bm_kw">关键字</em>标题三</font></a>\ <br>\ <font size="-1">\ 描述三<em class="bm_kw">关键字</em>描述三... 描述三描述三描述三 描述三描述三描述三 描述三描述三描述三 描述三描述三描述三 描述三描述三描述三 <b>...</b>\ <br>\ <font color="#008000">\ www.urlstring3.com/path/ 00K 2000-1-1 \ </font>\ <br>\ </font>\ </td>\ </tr>\ </tbody>\ </table>\ <table border="0" cellpadding="0" cellspacing="0">\ <tbody>\ <tr>\ <td class="c-default">\ <a href="javascript: void(0);"><font size="3">标题四<em class="bm_kw">关键字</em>标题四</font></a>\ <br>\ <font size="-1">\ 描述四<em class="bm_kw">关键字</em>描述四... 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四 <b>...</b>描述四<em class="bm_kw">关键字</em>描述四. <b>...</b> 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四 描述四描述四描述四...\ <br>\ <font color="#008000">\ www.urlstring1.com/path/ 00K 2000-1-1 \ </font>\ - <a href="javascript: void(0);" class="m">百度快照</a>\ <br>\ </font>\ </td>\ </tr>\ </tbody>\ </table>\ </div>\ </fieldset>\ </td>\ </tr>\ <tr id="bm_pref_options">\ <td width="50%" valign="top">\ <fieldset>\ <legend>常规</legend>\ <div>\ <label> 分栏数量:\ <select name="numcol" id="numcol" class="bm_pref_onchange">\ <option value="1" ' + ((OldPrefColumns==1) ? 'selected="selected"':'') + '>1</option>\ <option value="2" ' + ((OldPrefColumns==2) ? 'selected="selected"':'') + '>2</option>\ <option value="3" ' + ((OldPrefColumns==3) ? 'selected="selected"':'') + '>3</option>\ <option value="4" ' + ((OldPrefColumns==4) ? 'selected="selected"':'') + '>4</option>\ </select>\ </label> \ <label> 阅读方向:\ <select name="direction" id="direction" class="bm_pref_onchange">\ <option value="1" ' + ((Pref.direction==1) ? 'selected="selected"':'') + '>横向</option>\ <option value="2" ' + ((Pref.direction==2) ? 'selected="selected"':'') + '>纵向</option>\ </select>\ </label> \ <label> 排版模式:\ <select name="mode" id="mode" class="bm_pref_onchange">\ <option value="1" ' + ((Pref.displayMode==1) ? 'selected="selected"':'') + '>紧凑</option>\ <option value="2" ' + ((Pref.displayMode==2) ? 'selected="selected"':'') + '>对齐1</option>\ <option value="3" ' + ((Pref.displayMode==3) ? 'selected="selected"':'') + '>对齐2</option>\ <option value="4" ' + ((Pref.displayMode==4) ? 'selected="selected"':'') + '>对齐3</option>\ </select>\ </label> \ <label>\ <input name="fitwidth" id="fitwidth" class="bm_pref_onchange" type="checkbox" ' + (OldPrefFitwidth ? 'checked="true"':'') + '> 适合宽度\ </label><br>\ <label>\ (注:阅读方向为“横向”时,排版模式将固定为“紧凑”或“对齐1”)\ </label>\ </div>\ <div>\ <label>\ <input name="floatInput" id="floatInput"> \ </label>\ </div>\ <div>\ <label>\ <input name="removeAd" id="removeAd" type="checkbox" ' + (Pref.removeAd ? 'checked="true"':'') + '> 移除右侧的广告\ </label>\ </div>\ <div>\ <label>\ <input name="SearchInOtherEngines" id="SearchInOtherEngines" type="checkbox" ' + (Pref.EnableSearchInOtherEngines ? 'checked="true"':'') + '> 添加其他搜索引擎\ </label>\ <label> \ <select name="OtherEnginesTarget" id="OtherEnginesTarget">\ <option value="_blank" ' + ((Pref.OtherEnginesTarget=='_blank') ? 'selected="selected"':'') + '>在新页面打开</option>\ <option value="_self" ' + ((Pref.OtherEnginesTarget=='_self') ? 'selected="selected"':'') + '>在当前页面打开</option>\ </select>\ </label> \ <label style="display:none;">\ <input name="OtherEnginsFloat" id="OtherEnginsFloat" type="checkbox" ' + (Pref.OtherEnginsFloat ? 'checked="true"':'') + '> 跟随搜索框浮动\ </label><br>\ <label>\ (以下内容若不知何意,请勿修改)\ </label><br>\ <label>\ <textarea rows="5" cols="49" id="OtherEngines" style="margin: 0 1.5em;" wrap="off">' + Pref.OtherEngines + '</textarea>\ </label>\ </div>\ <div>\ <label>\ \ </label>\ <label>\ <input name="AutoNextPage" id="AutoNextPage"> \ </label> \ <label>\ <input name="HideAutoNextPage" id="HideAutoNextPage"> \ </label>\ \ <label>\ <input name="NextPageWithRS" id="NextPageWithRS"> \ </label>\ </div>\ <div>\ <label>\ <div>\ <input name="Focus2NextPageKeys" id="Focus2NextPageKeys"\ </div>\ </label>\ <label>\ <div>\ <input name="Focus2PrevPageKeys" id="Focus2PrevPageKeys"\ </div>\ </label>\ </div>\ <div>\ <label>\ <input name="DisableTracking" id="DisableTracking"> \ </label>\ </div>\ <div>\ <label>\ <input name="Focus2Keyword" id="Focus2Keyword" type="checkbox" ' + (Pref.Focus2Keyword ? 'checked="true"':'') + '> 快捷键定位到搜索框并\ </label>\ <label>\ <select name="Focus2KeywordAction" id="Focus2KeywordAction">\ <option value="1" ' + ((Pref.Focus2KeywordAction==1) ? 'selected="selected"':'') + '>清除全部文字</option>\ <option value="2" ' + ((Pref.Focus2KeywordAction==2) ? 'selected="selected"':'') + '>紧跟文字之后</option>\ <option value="3" ' + ((Pref.Focus2KeywordAction==3) ? 'selected="selected"':'') + '>选中全部文字</option>\ </select>\ </label>\ <label> 快捷键:\ <input name="Focus2KeywordKeys" id="Focus2KeywordKeys" size="18" value="' + parse2keys(Pref.Focus2KeywordKeys) + '" >\ </label>\ </div>\ </fieldset>\ <fieldset>\ <legend>搜索条目</legend>\ <div>\ <label>\ <input name="addPreviews" id="addPreviews"> \ </label>\ <label> \ <input id="PreviewSize">\ </label>\ </div>\ <div>\ <label>\ <input name="addResultNums" id="addResultNums" class="bm_pref_onchange" type="checkbox" ' + (Pref.addResultNum ? 'checked="true"':'') + '> 给搜索结果标序号 ( 1, 2, 3... )\ </label>\ <label>\ <input name="addResultNums_h" id="addResultNums_h" class="bm_pref_onchange" type="checkbox" ' + (Pref.addResultNum_h ? 'checked="true"':'') + '> 与标题同行\ </label>\ </div>\ <div>\ <label>\ <input name="addFavicons" id="addFavicons" class="bm_pref_onchange"> \ </label> \ <label>\ <input name="addFavicons_h" id="addFavicons_h" class="bm_pref_onchange"> \ </label>\ </div>\ <div>\ <label>\ <input name="searchSite" id="searchSite" class="bm_pref_onchange"> \ </label>\ </div>\ <div>\ <label>\ \ </label>\ </div>\ </fieldset>\ <div id="bm_pref_buttons" style="float: right;padding: 1.5em 1em 0 0;">\ <input value="保存" name="save_button" id="save_button" class="btn" type="button"> \ <input value="取消" name="cancel_button" id="cancel_button" class="btn" type="button">\ </div>\ </td>\ <td width="50%" valign="top">\ <fieldset>\ <legend>CSS 样式</legend>\ <div>\ <label>\ <select name="bm_pref_css_list" id="bm_pref_css_list">\ <option value="holder" selected="selected">条目</option>\ <option value="counter">序号</option>\ <option value="keyword">关键字</option>\ </select>\ </label> \ <label>\ <input value="全部恢复至默认 CSS" name="default_button" id="default_button" class="btn" type="button">\ </label>\ </div>\ <div>\ ' + addCssTable('holder','border: 1px solid rgb(170, 170, 170);', Pref.CSS.match(/\.rest\s\{[^\}]*\}/i)) + addCssTable('counter','border: 1px solid rgb(170, 170, 170); display: none;', Pref.CSS.match(/\.bm_num\s\{[^\}]*\}/i)) + addCssTable('keyword','border: 1px solid rgb(170, 170, 170); display: none;', Pref.CSS.match(/\.bm_kw\s\{[^\}]*\}/i)) + ' </div>\ <div>\ <table style="padding: 0.5em 0.5em 0 0.5em;">\ <tr>\ <td>\ <label>\ 自定义 CSS :【为推广链接分栏】 需在下框内输入 div.result-op.c-container.restTuiGuang {float: right;}\ </label><br>\ <label>\ <textarea rows="2" cols="60" id="customizeCSS" wrap="off" style="font-size: small;">' + Pref.customizeCSS + '</textarea>\ </label>\ </td>\ </tr>\ </table>\ </div>\ </fieldset>\ </td>\ </tr>\ </table>\ </center>\ </div>\ </div>\ '; } document.body.insertBefore(bgDiv,document.body.firstChild); // 设置好预览效果 prefOnChange(); // 添加 CSS 列表事件,切换不同的设置 document.getElementById('bm_pref_css_list').addEventListener('change', function(event){ var list = event.target; var curCssTable = matchNode('//table[@class="bm_pref_css" and not(contains(@style,"none"))]').snapshotItem(0); curCssTable.setAttribute('style','border: 1px solid rgb(170, 170, 170); display: none;'); var newCssTable = document.getElementById('bm_pref_css_' + list.options[list.selectedIndex].value); newCssTable.setAttribute('style','border: 1px solid rgb(170, 170, 170);'); switch(list.options[list.selectedIndex].value){ case 'holder': blink('rest',1); break; case 'counter': blink('bm_num',1); break; case 'keyword': blink('bm_kw',1); break; } }, false); // 添加相关选项 onchange 时的事件 var onChanges = matchNode('//*[@class="bm_pref_onchange"]'); len = onChanges.snapshotLength; for (i = 0; i < len; i++) { onChanges.snapshotItem(i).addEventListener('change', function(){ prefOnChange(); }, false); } // 添加 CSS 参数变化时,更新预览效果 var cssInputs = matchNode('//input[ancestor::table[@class="bm_pref_css"]]'); len = cssInputs.snapshotLength; for (i=0;i<len;i++){ cssInputs.snapshotItem(i).addEventListener('change', function(event){ cssOnChange(event.target); }, false); } // 自定义 CSS 文本框失去焦点时,更新预览效果 document.getElementById('customizeCSS').addEventListener('blur', function(event){ prefOnChange(); }, false); // 添加 CSS选项中的候选项 var optionSpans = matchNode('//span[@class="bm_pref_css_span"]'); len = optionSpans.snapshotLength; for (i = 0; i < len; i++) { optionSpans.snapshotItem(i).addEventListener('click', function(event){ var input = event.target.previousSibling; switch(input.name){ case 'font-size': addList(this,'6pt,7pt,8pt,9pt,10pt,11pt,12pt,13pt,14pt,15pt,16pt,17pt,18pt,19pt,20pt,21pt,22pt,23pt,24pt,25pt,26pt,27pt,28pt'); break; case 'color': addColorPicker(this); break; case 'font-weight': addList(this,'bold,normal,100,200,300,400,500,600,700,800,900'); break; case 'text-decoration': addList(this,'none,underline,overline,line-through,blink'); break; case 'text-align': addList(this,'left,center,right,justify'); break; case 'white-space': addList(this,'normal,pre,nowrap'); break; case 'background-color': addColorPicker(this); break; case 'border-color': addColorPicker(this); break; case 'border-style': addList(this,'none,hidden,dotted,dashed,solid,double,groove,ridge,inset,outset'); break; case 'border-width': addList(this,'thin,medium,thick,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px') break; case 'margin-left': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'padding-left': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'margin-right': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'padding-right': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'margin-top': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'padding-top': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'margin-bottom': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'padding-bottom': addList(this,'0px,1px,2px,3px,4px,5px,6px,7px,8px,9px,10px,11px,12px,13px,14px,15px,16px,17px,18px,19px,20px,21px,22px,23px,24px,25px,26px,27px,28px,29px,30px,31px,32px,33px,34px,35px,36px,37px,38px,39px,40px,41px,42px,43px,44px,45px,46px,47px,48px,49px,50px'); break; case 'float': addList(this,'none,left,right'); break; case 'clear': addList(this,'none,left,right,both'); break; } }, false); } // 2012-4-26 去掉 脚本自身自动更新,因为greasemonkey已经支持更新 // 检查是否有新版本 //getNewVersion(function(version){ // if (Number(scriptVersion) < Number(version)) { // document.getElementById('check_update').innerHTML = '<font color="red"> 检测到新版本,请点击'+ // ' <a href="' + scriptUrl + '" target="_blank">查看</a> 或'+ // ' <a href="' + installUrl + '">升级</a> </font>'; // } //}) // 将 CSS 全部恢复至默认 document.getElementById('default_button').addEventListener('click',function(){ if(confirm("除自定义 CSS 外的其他所有 CSS 设置将恢复到默认状态。\n继续吗?")) { setValue('CSS', defaultCSS); alert('除自定义 CSS 外的其他所有 CSS 设置已恢复到默认状态,刷新页面后生效。'); } }, false); // 保存设置 document.getElementById('save_button').addEventListener('click',function(){ var len, tmp; // 保存分栏数量 tmp = document.getElementById('numcol'); setValue('numcol', Number(tmp.options[tmp.selectedIndex].value)); // 保存搜索结果的排列方向 tmp = document.getElementById('direction'); setValue('direction', Number(tmp.options[tmp.selectedIndex].value)); // 保存排版模式 tmp = document.getElementById('mode'); setValue('mode', Number(tmp.options[tmp.selectedIndex].value)); // 让搜索结果适合屏幕宽度 setValue('fitwidth', document.getElementById('fitwidth').checked); // 移除右侧的广告 setValue('removeAd', document.getElementById('removeAd').checked); // 给搜索结果标序号 setValue('addResultNums', document.getElementById('addResultNums').checked); // 搜索结果标序号,要在标题同行 setValue('addResultNums_h', document.getElementById('addResultNums_h').checked); // 添加缩略图预览 setValue('addPreviews', document.getElementById('addPreviews').checked); // 缩略图大小。如果包含非数字,则替换成默认值 100 setValue('PreviewSize', isNaN(document.getElementById('PreviewSize').value)?'100':document.getElementById('PreviewSize').value); // 添加站点的 Favicon setValue('addFavicons', document.getElementById('addFavicons').checked); // 若没有 Favicon 则显示空白 setValue('addFavicons_h', document.getElementById('addFavicons_h').checked); // 在页面上部添加其他搜索引擎,默认【在Google中搜索xx】 setValue('SearchInOtherEngines', document.getElementById('SearchInOtherEngines').checked); setValue('OtherEngines', document.getElementById('OtherEngines').value.replace(/\'/ig,'"').replace(/^\s*|\s*$/ig,'').replace(/\s*[\n\r]+\s*/ig,'\n').replace(/\s*\|\s*http/ig,'|http')); setValue('OtherEnginsFloat', document.getElementById('OtherEnginsFloat').checked); tmp = document.getElementById('OtherEnginesTarget'); setValue('OtherEnginesTarget', tmp.options[tmp.selectedIndex].value); // 自动加载下一页 setValue('AutoNextPage', document.getElementById('AutoNextPage').checked); setValue('HideAutoNextPage', document.getElementById('HideAutoNextPage').checked); setValue('NextPageWithRS', document.getElementById('NextPageWithRS').checked); // 快捷键定位到搜索框 setValue('Focus2Keyword', document.getElementById('Focus2Keyword').checked); tmp = document.getElementById('Focus2KeywordAction'); setValue('Focus2KeywordAction', Number(tmp.options[tmp.selectedIndex].value)); // 禁止Baidu记录我的点击情况 setValue('DisableTracking', document.getElementById('DisableTracking').checked); // 添加“在此站点中搜索” setValue('searchSite', document.getElementById('searchSite').checked); var css = ''; // 保存 CSS 设置 var cssTextareas = matchNode('//textarea[string-length(text())>0 and ancestor::table[@class="bm_pref_css"]]'); len = cssTextareas.snapshotLength; for(var i=0;i<len;i++){ css +='.bm_MultiColDiv ' + cssTextareas.snapshotItem(i).value + '\n'; } setValue('CSS', css); // 保存自定义的 CSS setValue('customizeCSS', document.getElementById('customizeCSS').value); // 滚动到页面顶部,刷新一下页面 window.scrollTo(0, 0); location.href = location.href; },false); // 取消 document.getElementById('cancel_button').addEventListener('click',function(){ var bgDiv = document.getElementById('preferences'); bgDiv.parentNode.removeChild(bgDiv); len = bodyElements.length; for(i=0;i<len;i++){ bodyElements[i].style.display = bodyElementsDisplay[i]; } window.scrollTo(0, 0); if(Pref.AutoNextPage) loadNextPage(); },false); // “快捷键定位到搜索框” 的快捷键设定 document.getElementById('Focus2KeywordKeys').addEventListener('keydown',function(event){ var keycode = event.keyCode; var shift = event.shiftKey; var ctrl = event.ctrlKey; var alt = event.altKey; var Keys = ''; if (shift) { Keys += 'shift+'; } if (ctrl) { Keys += 'ctrl+'; } if (alt) { Keys += 'alt+'; } this.value = Keys + (code2keyTable[keycode] || ''); Keys += String(event.keyCode); setValue('Focus2KeywordKeys', Keys); // 立即保存快捷键 event.preventDefault(); event.stopPropagation(); },false); // “快捷键定位到下一页”的快捷键设定 document.getElementById('Focus2NextPageKeys').addEventListener('keydown',function(event){ var keycode = event.keyCode; var shift = event.shiftKey; var ctrl = event.ctrlKey; var alt = event.altKey; var Keys = ''; if (shift) { Keys += 'shift+'; } if (ctrl) { Keys += 'ctrl+'; } if (alt) { Keys += 'alt+'; } this.value = Keys + (code2keyTable[keycode] || ''); Keys += String(event.keyCode); setValue('Focus2NextPageKeys', Keys); // 立即保存快捷键 event.preventDefault(); event.stopPropagation(); },false); // “快捷键定位到上一页”的快捷键设定 document.getElementById('Focus2PrevPageKeys').addEventListener('keydown',function(event){ var keycode = event.keyCode; var shift = event.shiftKey; var ctrl = event.ctrlKey; var alt = event.altKey; var Keys = ''; if (shift) { Keys += 'shift+'; } if (ctrl) { Keys += 'ctrl+'; } if (alt) { Keys += 'alt+'; } this.value = Keys + (code2keyTable[keycode] || ''); Keys += String(event.keyCode); setValue('Focus2PrevPageKeys', Keys); // 立即保存快捷键 event.preventDefault(); event.stopPropagation(); },false); } // 加载下一页 function loadNextPage(){ // 如果剩余页面高度小于两倍窗口高度,而且存在下一页、没有在加载下一页、没有打开设置界面 if (!IsLoadingNext && NextPageLink && document.body.scrollHeight - window.scrollY < window.innerHeight * 3 && !document.getElementById('preferences')) { IsLoadingNext = true; var splitDiv = document.createElement('div'); splitDiv.setAttribute('style', 'font-size: small; background: rgb(230, 230, 230) none repeat scroll 0% 0%; clear: both; line-height: 20px; text-align: center; margin-top: 0.7em;'); splitDiv.setAttribute('id','isLoading'); splitDiv.setAttribute('class','bm_nav'); splitDiv.innerHTML = '<img style="vertical-align: middle;" src="">\ BaiduMonkeyW 正在加载下一页 ...'; var clr = matchNode('//div[@id="search" and descendant::form[@name="f2"]]').snapshotItem(0); clr.parentNode.insertBefore(splitDiv, clr); GM_xmlhttpRequest({ method: 'GET', url: String(NextPageLink.href), overrideMimeType: 'text/html; charset=' + document.characterSet, onload: function(d){ // 如果已打开设置界面,那么不加载下一页 if(document.getElementById('preferences')){ IsLoadingNext = false; document.body.removeChild(document.getElementById('isLoading')); return; } var i, len; pageCount ++; var lastNextPageLink = NextPageLink; var ContainerDiv = document.createElement('div'); ContainerDiv.innerHTML = d.responseText; var tempDivs = matchNode(sRestElementReal, ContainerDiv); len = tempDivs.snapshotLength; var ResultCellsDiv = document.createElement('div'); for (i = 0; i < len; i++) { ResultCellsDiv.appendChild(tempDivs.snapshotItem(i)); } ResultCellsDiv.setAttribute('class','bm_nextpage'); // 给搜索结果条目添加序号 if (Pref.addResultNum) { addResultNums(ResultCellsDiv, Pref); } // 设置分栏格式 movePops_and_MultiCol(ResultCellsDiv, pageCount, Pref); // 添加缩略图预览 if(Pref.addPreview){ addPreviews(ResultCellsDiv); } // 添加站点 Favicon if (Pref.addFavicon) { addFavicons(ResultCellsDiv); } // 禁止百度记录我的点击情况 if (Pref.DisableTracking) { removeTracking(ResultCellsDiv); } // 添加“在此站点中搜索” if(Pref.searchSite){ addseatchSite(ResultCellsDiv); } NextPageLink = matchNode('//p[@id="page"]/a[text() = "下一页>"]', ContainerDiv).snapshotItem(0); if(!NextPageLink){ // 如果没有下一页了则移除滚动监视 window.removeEventListener('scroll', watch_scroll, true); } // 取得页面导航条 var splitDiv = matchNode('//p[@id="page"]', ContainerDiv).snapshotItem(0); splitDiv.innerHTML = '<a style="width:auto;" href="' + lastNextPageLink.href + '">第' + (pageCount) + '页</a>' + splitDiv.innerHTML.replace('找到相关结果', '') + ''; splitDiv.setAttribute('style', 'margin: 8px 0 0 0;'); splitDiv.setAttribute('class',splitDiv.getAttribute('class')+' bm_nav'); // 在当前页插入自动翻页分隔符 document.getElementById('isLoading').parentNode.replaceChild(splitDiv, document.getElementById('isLoading')); // 插入下一页 clr.parentNode.insertBefore(ResultCellsDiv, clr); // 插入相关搜索 if (relatedSearch && Pref.NextPageWithRS) { clr.parentNode.insertBefore(relatedSearch.cloneNode(true), clr); } // 统一格式,美化版面 // 只有一列或者“紧凑”模式时不需要统一格式 if (Pref.columns > 1 && Pref.displayMode > 1) { // 加载第二页后,可能出现纵向滚动条,导致第一页宽度发生变化,所以要重新排版第一页的对齐格式 if (pageCount == 2) { format('bm_page_1', Pref); } format('bm_page_' + pageCount, Pref); } delete ContainerDiv; var ev = document.createEvent('Event'); ev.initEvent('bm_NextPageLoaded', true, false); document.dispatchEvent(ev); IsLoadingNext = false; } }); } } // 滚动停止 300ms 后,开始判断并加载下一页 var t = setTimeout(function(){},10); function watch_scroll(){ clearTimeout(t); var last = window.scrollY; t = setTimeout(function(){ if (last == window.scrollY){ loadNextPage(); } }, 300); } // 检查新版本 //function checkUpdate() { // var now = Math.round(new Date().getTime() / 1000); // // if (Number(Pref.newVersion)) { // 如果已经检查到新版本 // showUpdateMessage(Pref.newVersion); // } // else if (now - Pref.lastCheck > 86400) { // 如果上一次没有检查到新版本,并且上一次检查距今超过24小时,那么现在检查新版本 // setValue('lastCheck',now); // getNewVersion(function(version){ // if(Number(version)>Number(scriptVersion) && version != Pref.skipVersion){ // 如果最新版大于现有版本,并且不等于跳过的版本 // setValue('newVersion',version); // showUpdateMessage(version); // } // else { // setValue('newVersion',0); // } // }) // } //} // 显示新版本提示 function showUpdateMessage(newVersion){ var seperate = document.createElement('span'); seperate.innerHTML = ' - '; var ignore = document.createElement('a'); ignore.innerHTML = '暂时忽略'; ignore.href='javascript:void(0)'; ignore.addEventListener("click", ignoreUpdate, false); var skip = document.createElement('a'); skip.innerHTML = '跳过此版'; skip.href='javascript:void(0)'; skip.addEventListener("click", function(){ skipUpdate(newVersion) }, false); var view = document.createElement('a'); view.innerHTML = '查看更新'; view.href = scriptUrl; view.target = '_blank'; var update = document.createElement('a'); update.innerHTML = '立即升级'; update.href='javascript:void(0)'; update.addEventListener("click", updateScript, false); var msg = document.createElement('div'); with (msg) { setAttribute('id', 'bm_UpdateMsg'); innerHTML = '<strong>BaiduMonkeyW</strong> 发现新版本 v' + newVersion + ' (当前版本 v' + scriptVersion + ') '; appendChild(ignore); appendChild(seperate.cloneNode(true)); appendChild(skip); appendChild(seperate.cloneNode(true)); appendChild(view); appendChild(seperate.cloneNode(true)); appendChild(update); } document.body.insertBefore(msg,document.body.firstChild); var css; if(Pref.floatInput && Pref.floatInputPos == 1){ css = '.gbh {display: none;} \ #bm_UpdateMsg {background-color: rgb(240, 247, 249); margin: 1em; padding: 3px; text-align: center; -moz-border-radius: 5px; -webkit-border-radius: 5px;} \ #bm_header {top: 48px;}\ '; } else { css = '.gbh {display: none;} \ #bm_UpdateMsg {background-color: rgb(240, 247, 249); margin: 1em; padding: 3px; text-align: center; -moz-border-radius: 5px; -webkit-border-radius: 5px;} \ '; } GM_addStyle(css); } function hideUpdateMessage(){ document.body.removeChild(document.getElementById('bm_UpdateMsg')); } // 暂时忽略 function ignoreUpdate(){ hideUpdateMessage(); setValue('lastCheck',Math.round(new Date().getTime() / 1000)); setValue('newVersion',0); } // 跳过此版 function skipUpdate(newVersion){ hideUpdateMessage(); setValue('skipVersion',newVersion); setValue('newVersion',0); } // 立即升级 function updateScript(){ if(isChrome){ alert('Chrome用户请先卸载旧版本,再去脚本页面(点击查看更新即可)安装新版。\n卸载前请务必记好自定义的各项设置。'); setValue('newVersion',0); }else{ hideUpdateMessage(); setValue('newVersion',0); window.location.replace(installUrl); } } //// 查询最新版本号 //function getNewVersion(funcbind){ // if(isChrome){ // GM_xmlhttpRequest({ // method: 'GET', // url: 'http://' + location.host+ '/s?wd=site:(userscripts.org)+BaiduMonkey+version', // overrideMimeType: 'text/html; charset=' + document.characterSet, // onload: function(d){ // var versionCode = d.responseText.match(/Version.*Recently/i); // if (versionCode) { // 如果找到 Version // funcbind(String(versionCode).replace(/[^\d\.]/ig, '')); // } // } // }); // } // else{ // GM_xmlhttpRequest({ // method: 'GET', // url: scriptUrl, // overrideMimeType: 'text/html; charset=utf-8', // onload: function(d){ // var divContainer = document.createElement('div'); // divContainer.innerHTML = d.responseText; // var versionCode = matchNode('//h3[contains(text(),"当前版本")]', divContainer).snapshotItem(0).nextSibling; // delete divContainer; // if (versionCode) { // 如果找到 Version 标签 // funcbind(versionCode.textContent.replace(/^\s*|\s*$|v/ig, '')); // } // } // }); // } //} // 转换为 Boolean 类型 function toBoolean(s){ return typeof(s)=='boolean'?s:(s=='true'?true:false); } //////////////////删除 推广链接 function RemoveTuiGuang(){ //f16 EC_PP // 删除“推广”条目 var popTables = matchNode('//table[tbody/tr/td[contains(@class,"f16 EC_PP") ]]'); len = popTables.snapshotLength; if (len > 0) { for (i = 0; i < len; i++) { var popTable = popTables.snapshotItem(i); popTable.parentNode.removeChild(popTable); } } } /********************************************************************************************* * 各功能函数 结束 *********************************************************************************************/ RemoveTuiGuang(); } //baiduMeiHua(); function ajaxSend(objectOfXMLHttpRequest, callback) { console.log(objectOfXMLHttpRequest); console.log(callback); // http://stackoverflow.com/questions/3596583/javascript-detect-an-ajax-event if(!callback){ return; } var s_ajaxListener = new Object(); s_ajaxListener.tempOpen = objectOfXMLHttpRequest.prototype.open; s_ajaxListener.tempSend = objectOfXMLHttpRequest.prototype.send; s_ajaxListener.callback = function () { // this.method :the ajax method used // this.url :the url of the requested script (including query string, if any) (urlencoded) // this.data :the data sent, if any ex: foo=bar&a=b (urlencoded) callback(this.method, this.url, this.data); } objectOfXMLHttpRequest.prototype.open = function(a,b) { if (!a) var a=''; if (!b) var b=''; s_ajaxListener.method = a; s_ajaxListener.url = b; if (a.toLowerCase() == 'get') { s_ajaxListener.data = b.split('?'); s_ajaxListener.data = s_ajaxListener.data[1]; } var realLink=findRealLink(s_ajaxListener.method, s_ajaxListener.url, s_ajaxListener.data); if (realLink!="" ) { var bCanTo=false; var eles; console.log(typeof($)=="undefined"); eles=document.getElementsByClassName("bdsug"); console.log(eles.length); if (eles.length==0) { bCanTo=true; } else { console.log(eles[0].style.display); if (eles[0].style.display=="none") { console.log(4); bCanTo=true; } } //bRedirect=$(".bdsug").length==0 || $(".bdsug").is(":hidden"); console.log(bCanTo); if (bCanTo) { console.log("redirest to :"+realLink); window.location.href=realLink; } else { console.log("not redirest "); objectOfXMLHttpRequest.abort(); } return false; } s_ajaxListener.tempOpen.apply(this, arguments); } objectOfXMLHttpRequest.prototype.send = function(a,b) { if (!a) var a=''; if (!b) var b=''; s_ajaxListener.tempSend.apply(this, arguments); if(s_ajaxListener.method.toLowerCase() == 'post') { s_ajaxListener.data = a; } s_ajaxListener.callback(); } } function callback(method,url,data) { console.log("ajax:"+method+" "+url+ " Data:" + data); } function findRealLink(method,url,data) { console.log("RealTest ajax:"+method+" "+url+ " Data:" + data); if (method=="GET" && url.indexOf("/s?")>=0) { var kw; var wd; kw=document.getElementById("kw"); if (kw) { wd=kw.value; } else { kw=document.getElementById("kw1"); if (kw) { wd=kw.value; } } //var wd=$("#kw").val(); //if (!wd) wd=$("#kw1").val(); //if (!wd) { // console.log("未发现查询关键字控件"); // return ""; if (wd=="") { console.log("查询关键字为空"); return ""; } console.log("wd="+wd); if (url.split("?")[1].indexOf("wd="+wd+"&")) { console.log("have find wd :"+wd); return "http://www.baidu.com/s?"+"wd="+wd; } } return ""; }