// ==UserScript==
// @name BaiduMonkeyW
// @namespace http://userstyles.org
// @description 改善百度的搜索结果界面,提高阅读效率
// @version 15.7
// @author weiwsy(weiwsy@qq.com) 【原BaiduMonkeyR脚本作者是SUCCESS】
// @include http://www.baidu.com/s*
// @include http://www.baidu.com/baidu*
// @include http://www.baidu.com/#*
// @include http://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==
/* 更新记录 ***********************************************************************
【2014.5.20】 更新 V15.7
修正:推广信息整个不显示了,没想到被abp干掉了(abp写规则的人真偷懒啊,就只看id就判广告了),好吧,总不能让大家都把abp禁用吧,我妥协。
【2014.4.22】 更新 V15.6
修正:油猴子中无法保存配置问题。
【2014.4.22】 更新 V15.5
修正:对于scriptish中无效的问题进行了处理。(scriptish中当使用run-at document-start时 ,@require jquery加载jquery失败,求解)
【2014.4.4】 更新 V15.4
修正:上次修正,只能解决百度主页,手工输入搜索关键字的情况,而粘贴进去的无效,这次处理了这种情况。
【2014.3.26】 更新 V15.3
修正:简单修正上次的bug。
【2014.3.25】 更新 V15.2
修正:上个版本不能完美处理从百度主页直接过去的搜索,因为从主页开始 就只有xhr调用了。这次改动较大,本人测试正常,大家试试吧。
【2014.3.21】 更新 V15.1
修正:百度默认搜索链接改成了 /#wd= 这个页面采用了动态加载,导致脚本失效,现在把#重定向到baidu?来实现效果。
【2014.3.20】 更新 V15.0
修正:caliban 反馈的 搜索 “陈美嘉” 等信息时,会有推广条目不在推广内 。
【2014.3.12】 更新 V14.9
修正:百度改版导致大部分功能失效,这次改变了部分处理方式。
【2014.1.23】 更新 V14.8
修正:14.7版本的修改导致了设置界面无法保存和取消 的问题。
【2014.1.15】 更新 V14.7
修正:caliban反映的(搜索 毓婷、聚酯纤维 弹性等信息时,脚本不完全生效)问题。
【2013.9.25】 更新 V14.6
修正:设置界面预览无法分栏问题。
修正:浮动框挡住了搜索结果第一行的部分。
【2013.9.24】 更新 V14.5
修正:百度改版导致脚本无法生效。已知问题:设置界面预览暂时有点问题,有时间再看。
【2013.5.20】 更新 V14.4
修正:改为把推广信息单列显示。
【2013.5.15】 更新 V14.3
修正:对于有百度推广内容的页面,现在改为把推广信息单独放在页面最上边的一个容器里, 可以隐藏或者显示。
感谢:gameking和 caliban 的建议。这样改过后,显示效果好多了。
【2013.4.18】 更新 V14.2
修正:感谢用户rothyu反馈新版本中其他引擎的地方重叠显示了推荐内容
找到了原来推荐链接不显示的真正原因,竟然是ABP更新了规则,默认屏蔽了推荐这个元素导致的
现在仍采用新方式显示其他引擎,只是同时把推荐元素内容置为空。
【2013.4.17】 更新 V14.1
修正:窗口改变大小时,导致其他引擎和文字重叠。
【2013.4.16】 更新 V14.0
修正:百度改版导致无法显示其他搜索引擎的问题。
【2013.3.13】 更新 V13.9
修正:百度改版导致只有设置按钮,但是功能失效的问题。
【2013.2.7】 更新 V13.8
修正:如果选择添加序号,原来因为标题是H3,造成序号也自己是一行,现在增加选项"与标题同行“
修正:如果选择添加favicon,原来因为标题是H3,造成favicon也自己是一行,现在修改为同一行。
【2013.2.5】 更新 V13.7
修正:搜索“风云”,出来了另一个百度的整合页面,现在改为对class部分匹配op_new来判断。
修正:“显示站点的 Favicon”显示的都是百度的图标,因为百度对源地址加密了,现在从后边的部分文本中判断站点。
【2013.2.4】 更新 V13.6
修正:caliban反馈,如果搜索人名,第一页排版混乱。经查此问题类似视频推荐,同视频推荐同样处理,若发现有百度整合信息就单列显示。
【2013.2.4】 更新 V13.5
修正:因百度登录后增加了成就显示,还有用户名长的情况都会造成设置按钮重叠, 现在改为放在上边第二行,以避免重复。
【2013.1.5】 更新 V13.4
修正:当搜索的是电影名时,百度左边第一项和右边会列出一些视频推荐信息,这是如果设置多栏显示搜索结果就会被挡住,
所以现在检测到baidu视频推荐时,临时自动使分栏为1,使显示结果不凌乱。
【2012.12.27】 更新 V13.3
修正:修复 baidu 改版导致 无法去掉右侧广告栏。
【2012.12.20】 更新 V13.2
修正:修复 添加多个其他搜索引擎的时候只显示最后一个 的问题。
【2012.11.22】 更新 V13.1
兼容: 兼容 Scriptish (原来由于Scriptish不支持GM_info导致无法使用脚本)。
兼容: 兼容 chrome (其实chrome用户可以使用Tampermonkey来兼容所有GM脚本。此更新仅用于不愿意使用Tampermonkey的用户,但同时键无法获取当前版本号)。
【2012.11.20】 更新 V12.9
修正: 修复 设置“搜索框浮动在页面上方” 并设置“其他搜索引擎 跟随搜索框浮动”时 无法显示BaiduMonkeyW设置按钮 的问题。
因为现在其他搜索引擎本来就在浮动框中,所以这个选项去掉。
【2012.11.20】 更新 V12.8
修正: 修复 设置“搜索框浮动在页面上方”时 无法显示BaiduMonkeyW设置按钮 的问题。z-index101
【2012.11.20】 更新 V12.7
修正: 修复 登录后无法显示BaiduMonkeyW设置按钮 的问题。
为了解决登录后按钮失效,现在把 设置按钮 放在 原页面登录区的前边。
【2012.10.24】 更新 V12.6
修正: 百度改版导致 无法添加“在此站点中搜索” 的问题
【2012.10.24】 更新 V12.5
修正: 百度改版导致 无法添加其他搜索引擎 的问题
【2012.6.11】 更新 V12.4
修正: 百度改版导致 显示页面缩略图不能用 的问题
【2012.5.22】 更新 V12.3
修正: 优化 自动翻页分隔符、页面导航条 的显示效果,避免信息显示不全问题
修正: 设置界面 当前版本号 改为获取真正的 脚本的版本号
【2012.5.19】 更新 V12.2
修正: 自动加载下一页 因baidu链接名字更改(多了一个>)导致的问题。
【2012.4.26】 更新 V12.1
修正: 因原脚本已经作者很久没有更新,别的用户上传的修改版也存在问题,这里开始自己修改bug
脚本自己重新命名为 BaiduMonkeyW
修正: 修复 无法添加其他搜索引擎链接 的问题 (替换掉页面的 设置为收藏的 链接)
修正: 修复 无法显示BaiduMonkeyW设置按钮 的问题
修正: 新方法 直接删除 推广链接
-----------------------------
【2010.9.20】 更新 V11.8
增加: 自动加载下一页中包含相关搜索。
修正: 百度继续改版,继续修正由此引起的若干问题。
【2010.9.20】 更新 V11.7
修正: 百度页面结构改版后引起的若干问题。
【2010.9.17】 更新 V11.6
修正: 打开“清除右侧广告”后,顶部搜索框消失的问题。
【2010.7.30】 更新 V11.5
增加: 自动加载下一页后,document 会抛出 bm_NextPageLoaded 事件,方便和其他脚本的配合。
增加: 自定义快捷键定位到下/上一页。
修正: CSS 样式设置中颜色选择器有时不能正确生成颜色值的问题。
修正: 其他几个细节问题。
初步支持 Chrome。
已知在 Chrome 中有如下问题:
勉强支持脚本的自动检查更新
【2010.3.31】 更新 V11.4
修正: 不能正确加载下一页的问题。
【2009.9.25】 更新 V11.3
修正: 百度改版后右侧广告不能移除的问题。
【2009.9.15】 更新 V11.2
修正: 百度改版后不能处理推广链接的问题。
增加: 对搜索结果中关键字样式的自定义。
【2009.6.23】 更新 V11.1
修正: @ # $& = : / ; ? + ' 当关键字包含这些字符时,用其他搜索引擎搜索会不正常的问题。
修正: 3.0 版火狐无法打开设置界面的问题。
【2009.6.19】 更新 V11.0
增加: 自动检查新版本。不用像之前那样要打开设置界面才检查了。
增加: 显示缩略图。如果图片无法显示,那么也不显示图像占位符。
再次增加: 快捷键定位到搜索框后允许全部选中文本。
修正: 提高与某些脚本如 Display original image 的兼容性。
【2009.5.20】 更新 V10.9
修正: 10.8 版不能正常显示贴吧链接的问题。
【2009.5.4】 更新 V10.8
增加: 允许隐藏自动翻页分隔符。
增加: 允许显示站点 favicon。
增加: 允许搜索框固定在页面顶部或底部。
修正: 搜索关键字包含 HTML 标签文字时产生的问题。
修正: 如果不选中“自动加载下一页”,打开设置界面再取消时仍然加载第二页的问题。
改进了排版对齐的处理方式和判断是否应该加载下一页的方式。
其他一些小的修改。
【2009.1.6】 更新 V10.7
修正: 由于 userscripts.org 页面变化导致的自动检查更新功能失效的问题。
【2009.1.2】 更新 V10.6
更新成 GoogleKingKong 的设置界面。
修正:排版有时不能对齐的问题。
【2008.10.20】 更新 V10.5
发布到 userscripts 页面,同时启用自动检查更新功能。
【2008.10.18】 更新 V10.4
修正:某些特殊情况下排版错乱的问题。
【2008.10.16】 更新 V10.3
增加:允许 设置搜索结果的排列方向。
【2008.10.14】 更新 V10.2
增加:允许 自动加载下一页。
【2008.10.11】 更新 V10.1
修正:百度贴吧的搜索结果消失/错位的问题。
增加:“适合宽度”选项。方便宽屏阅读。
************************************************************************/
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 = 'http://userscripts.org/scripts/show/131861';
var scriptVersion='15.7';
var installUrl='https://userscripts.org/scripts/source/131861.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\
margin-left: 0.5em !important;\n\
margin-right: 0 !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))
// 搜索框浮动,1-顶部;2-底部
,floatInput : toBoolean(getValue('floatInput', false))
,floatInputPos : Number(getValue('floatInputPos', 1))
// 是否自动加载下一页,默认 关闭
,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', false))
// 给搜索结果条目添加序号,默认 关闭
,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', true))
// 其他搜索引擎地址
,OtherEngines : getValue('OtherEngines', '在Google中搜索【{word}】|http://www.google.com/search?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);
}
// 浮动搜索框
if(Pref.floatInput){
floatInput();
}
// 设置“相关搜索”提示框的样式
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 {border: 1px solid red; -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 {border: 1px solid red; -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: 24px; right:10px; 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 = 'BaiduMonkeyW 设置';
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 floatInput(){
var css, header = matchNode('//div[@id="head"]').snapshotItem(0);
var headerContainer = document.createElement('div');
header.parentNode.insertBefore(headerContainer, header);
with (headerContainer) {
setAttribute('id', 'bm_header');
switch (Pref.floatInputPos) {
case 1: // 顶部
var rplheader = document.createElement('div');
headerContainer.parentNode.insertBefore(rplheader, headerContainer);
appendChild(header);
// if (Pref.OtherEnginsFloat) {
//
// var bi = matchNode('//div[@id="tool"]').snapshotItem(0);
// appendChild(bi);
// rplheader.style.height = header.offsetHeight + bi.offsetHeight + 'px';
// css = '#bm_header {position: fixed; top: 0px; width: 100%; background-color: white; z-index: 100;}';
// }
// else
{
//header.margin-bottom=20px,padding-top=6px,这些导致了浮动框挡住了搜索结果第一行的部分。所以把这个空出来。
rplheader.style.height = headerContainer.offsetHeight + 20+6 + 'px';
css = '#bm_header {position: fixed; top: 0px; width: 100%; background-color: white; border-bottom: 1px solid blue; z-index: 100;}';
}
break;
case 2: // 底部
var rplheader = document.createElement('div');
var tmp = matchNode('//div[@id="search" and descendant::form[@name="f2"]]').snapshotItem(0).nextSibling;
tmp.parentNode.insertBefore(rplheader, tmp);
// if (Pref.OtherEnginsFloat) {
// var bi = matchNode('//form[@class="fm"]/span[@class="tools"]').snapshotItem(0);
// appendChild(bi);
// appendChild(header);
// rplheader.style.height = header.offsetHeight + bi.offsetHeight + 'px';
// css = '#bm_header {position: fixed; bottom: 0px; width: 100%; background-color: white; border-top: 1px solid blue; z-index: 100;}';
// }
// else
{
appendChild(header);
rplheader.style.height = headerContainer.offsetHeight + 'px';
css = '#bm_header {position: fixed; bottom: 0px; width: 100%; background-color: white; border-top: 1px solid blue; z-index: 100;}';
}
break;
}
}
GM_addStyle(css);
}
// 添加 其他搜索引擎
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;">BaiduMonkeyW 参数设置 v:' + scriptVersion + '</div>\
<div id="check_update" style="float: right; padding-right: 0.8em; font-size: small;"><a href="' + scriptUrl + '" target="_blank">访问 userscripts 页面</a></div>\
<div style="float: right; padding-right: 0.8em; font-size: small;">欢迎来<a href="http://userscripts.org/scripts/show/131861" 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" type="checkbox" ' + (Pref.floatInput ? 'checked="true"':'') + '> 搜索框浮动在页面\
</label>\
<label>\
<select name="floatInputPos" id="floatInputPos">\
<option value="1" ' + ((Pref.floatInputPos==1) ? 'selected="selected"':'') + '>顶部</option>\
<option value="2" ' + ((Pref.floatInputPos==2) ? 'selected="selected"':'') + '>底部</option>\
</select>\
</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>\
<input name="AutoNextPage" id="AutoNextPage" type="checkbox" ' + (Pref.AutoNextPage ? 'checked="true"':'') + '> 自动加载下一页\
</label> \
<label>\
<input name="HideAutoNextPage" id="HideAutoNextPage" type="checkbox" ' + (Pref.HideAutoNextPage ? 'checked="true"':'') + '> 隐藏自动翻页分隔符\
</label>\ \
<label>\
<input name="NextPageWithRS" id="NextPageWithRS" type="checkbox" ' + (Pref.NextPageWithRS ? 'checked="true"':'') + '> 下一页包含相关搜索\
</label>\
<label style="margin-left: 1em; font-size: 0.9em; color: red; font-style: italic;">\
NEW~\
</label>\
</div>\
<div>\
<label style=" margin-left: 1.5em;">\
<div style="display:inline-block;">快捷键定位到下一页\
<input name="Focus2NextPageKeys" id="Focus2NextPageKeys" size="15" value="' + parse2keys(Pref.Focus2NextPageKeys) + '"\
</div>\
</label>\
<label style=" margin-left: 1em;">\
<div style="display:inline-block;">上一页\
<input name="Focus2PrevPageKeys" id="Focus2PrevPageKeys" size="15" value="' + parse2keys(Pref.Focus2PrevPageKeys) + '"\
</div>\
</label>\
</div>\
<div>\
<label>\
<input name="DisableTracking" id="DisableTracking" type="checkbox" ' + (Pref.DisableTracking ? 'checked="true"':'') + '> 禁止百度记录我的点击情况\
</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" class="bm_pref_onchange" type="checkbox" ' + (Pref.addPreview ? 'checked="true"':'') + '> 显示页面缩略图\
</label>\
<label> 缩略图大小:\
<input id="PreviewSize" class="bm_pref_onchange" size="3" value="' + Pref.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 style="color:red">\
<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" type="checkbox" ' + (Pref.addFavicon ? 'checked="true"':'') + '> 显示站点的 Favicon\
</label> \
<label>\
<input name="addFavicons_h" id="addFavicons_h" class="bm_pref_onchange" type="checkbox" ' + (Pref.addFavicon_h ? 'checked="true"':'') + '> 若没有则显示空白\
</label>\
</div>\
<div>\
<label>\
<input name="searchSite" id="searchSite" class="bm_pref_onchange" type="checkbox" ' + (Pref.searchSite ? 'checked="true"':'') + '> 添加“在此站点中搜索”\
</label>\
</div>\
<div>\
<label>\
改变搜索条目背景色在: 【CSS 样式】 -> 【条目】 -> 【Background-Color】\
</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 :\
</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('floatInput', document.getElementById('floatInput').checked);
tmp = document.getElementById('floatInputPos');
setValue('floatInputPos', 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 "";
}
痛苦苦苦苦苦苦苦苦苦并快乐着