diff --git a/Super_preloaderPlus/Gruntfile.js b/Super_preloaderPlus/Gruntfile.js
index 2fb9b2ca..e3c49be4 100644
--- a/Super_preloaderPlus/Gruntfile.js
+++ b/Super_preloaderPlus/Gruntfile.js
@@ -1,64 +1,51 @@
module.exports = function(grunt) {
- var concatOptions = {
- banner: '(function() {\n',
- footer: '\n})();',
- separator: '\n\n//----------------------------------\n',
- process: true
- };
-
- grunt.initConfig({
- pkg: grunt.file.readJSON('package.json'),
- concat: {
- dist: {
- options: concatOptions,
- src: ['src/meta.js', 'src/rule.js', 'src/main.js'],
- dest: '<%= pkg.name %>.user.js'
- },
- },
- watch: {
- files: ['src/**/*.js'],
- tasks: ['default']
- }
- })
-
-
- grunt.registerTask('split', 'split file', function () {
- grunt.file.expand('src/*').forEach(function(path){
- grunt.file.delete(path);
- });
-
- var source = grunt.file.read('super_preloaderplus_one.user.js');
-
- // 去除首行和尾行
- source = source.replace(/^\(function\(\).*/, '')
- .replace(/\}\)\(\);$/, '');
-
- var arr = source.split(/\n\/\/\-+/);
-
- arr.forEach(function (text, index) {
- if (index === 0) {
- grunt.file.write('src/meta.js', text);
- } else {
- var match = text.match(/\n\/\/\s*(.*)/);
- var name = match ? match[1] : ('split' + index + '.js' );
- grunt.file.write('src/' + name, text);
- }
- });
-
- // grunt.log.writeln();
- });
-
-
- grunt.registerTask('default', [
- //'jshint',
- 'concat',
- ])
-
- grunt.registerTask('watch', ['watch'])
-
- grunt.loadNpmTasks('grunt-contrib-concat')
- grunt.loadNpmTasks('grunt-contrib-clean')
- grunt.loadNpmTasks('grunt-contrib-watch')
-
-}
\ No newline at end of file
+ grunt.initConfig({
+ pkg: grunt.file.readJSON('package.json'),
+ concat: {
+ dist: {
+ options: {
+ banner: '(function() {\n',
+ footer: '\n})();',
+ separator: '\n\n',
+ process: true
+ },
+ src: [
+ 'src/meta.js', 'src/rule.js', 'src/libs.js',
+ 'src/FloatWindow.js', 'src/prefetcher.js', 'src/autopager.js',
+ 'src/setting.js', 'src/main.js'
+ ],
+ dest: '<%= pkg.name %>.user.js'
+ },
+ },
+ jshint: {
+ beforeconcat: ['gruntfile.js', 'src/*.js'],
+ afterconcat: ['<%= pkg.name %>.user.js'],
+ options: {
+ 'browser': true,
+ 'multistr': true,
+ 'evil': true,
+ 'globals': {
+ 'GM_addStyle': true,
+ 'GM_getValue': true,
+ 'GM_setValue': true,
+ 'GM_xmlhttpRequest': true,
+ 'GM_openInTab': true,
+ 'GM_setClipboard': true,
+ 'GM_registerMenuCommand': true
+ }
+ }
+ },
+ watch: {
+ files: ['src/**/*.js'],
+ tasks: [ 'jshint', 'concat']
+ }
+ });
+
+ grunt.registerTask('default', ['jshint', 'concat', 'watch']);
+
+ grunt.loadNpmTasks('grunt-contrib-concat');
+ grunt.loadNpmTasks('grunt-contrib-watch');
+ grunt.loadNpmTasks('grunt-contrib-jshint');
+
+};
\ No newline at end of file
diff --git a/Super_preloaderPlus/package.json b/Super_preloaderPlus/package.json
index b52bacf4..ee8eafe1 100644
--- a/Super_preloaderPlus/package.json
+++ b/Super_preloaderPlus/package.json
@@ -1,10 +1,10 @@
{
- "name": "super_preloaderplus_one",
- "version": "6.4.6",
- "devDependencies": {
- "grunt": "~0.4.5",
- "grunt-contrib-clean": "~0.5.0",
- "grunt-contrib-concat": "~0.4.0",
- "grunt-contrib-watch": "~0.6.1"
- }
-}
\ No newline at end of file
+ "name": "Super_preloaderPlus_one",
+ "version": "6.4.6",
+ "devDependencies": {
+ "grunt": "~0.4.5",
+ "grunt-contrib-concat": "~0.4.0",
+ "grunt-contrib-jshint": "^0.10.0",
+ "grunt-contrib-watch": "~0.6.1"
+ }
+}
diff --git a/Super_preloaderPlus/src/FloatWindow.js b/Super_preloaderPlus/src/FloatWindow.js
new file mode 100644
index 00000000..a90aaf81
--- /dev/null
+++ b/Super_preloaderPlus/src/FloatWindow.js
@@ -0,0 +1,509 @@
+// 悬浮窗
+function FloatWindow() {
+ this.init.apply(this, arguments);
+}
+
+FloatWindow.prototype = {
+
+ init: function(SSS, autoPO) {
+ this.SSS = SSS;
+ this.autoPO = autoPO;
+
+ this.addStyle();
+
+ this.addContaner();
+
+ this.initContainer();
+ },
+ destory: function() {
+ this.removeStyle();
+
+ this.removeContainer();
+ },
+ addStyle: function() {
+ this.style = GM_addStyle('\
+ #sp-fw-container {\
+ z-index:999999!important;\
+ text-align:left!important;\
+ }\
+ #sp-fw-container * {\
+ font-size:13px!important;\
+ color:black!important;\
+ float:none!important;\
+ }\
+ #sp-fw-main-head{\
+ position:relative!important;\
+ top:0!important;\
+ left:0!important;\
+ }\
+ #sp-fw-span-info{\
+ position:absolute!important;\
+ right:1px!important;\
+ top:0!important;\
+ font-size:10px!important;\
+ line-height:10px!important;\
+ background:none!important;\
+ font-style:italic!important;\
+ color:#5a5a5a!important;\
+ text-shadow:white 0px 1px 1px!important;\
+ }\
+ #sp-fw-container input {\
+ vertical-align:middle!important;\
+ display:inline-block!important;\
+ outline:none!important;\
+ height: auto !important;\
+ padding: 0px !important;\
+ margin-bottom: 0px !important;\
+ }\
+ #sp-fw-container input[type="number"] {\
+ width:50px!important;\
+ text-align:left!important;\
+ }\
+ #sp-fw-container input[type="checkbox"] {\
+ border:1px solid #B4B4B4!important;\
+ padding:1px!important;\
+ margin:3px!important;\
+ width:13px!important;\
+ height:13px!important;\
+ background:none!important;\
+ cursor:pointer!important;\
+ }\
+ #sp-fw-container input[type="button"] {\
+ border:1px solid #ccc!important;\
+ cursor:pointer!important;\
+ background:none!important;\
+ width:auto!important;\
+ height:auto!important;\
+ }\
+ #sp-fw-container li {\
+ list-style:none!important;\
+ margin:3px 0!important;\
+ border:none!important;\
+ float:none!important;\
+ }\
+ #sp-fw-container fieldset {\
+ border:2px groove #ccc!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ padding:4px 9px 6px 9px!important;\
+ margin:2px!important;\
+ display:block!important;\
+ width:auto!important;\
+ height:auto!important;\
+ }\
+ #sp-fw-container legend {\
+ line-height: 20px !important;\
+ margin-bottom: 0px !important;\
+ }\
+ #sp-fw-container fieldset>ul {\
+ padding:0!important;\
+ margin:0!important;\
+ }\
+ #sp-fw-container ul#sp-fw-a_useiframe-extend{\
+ padding-left:40px!important;\
+ }\
+ #sp-fw-rect {\
+ position:relative!important;\
+ top:0!important;\
+ left:0!important;\
+ float:right!important;\
+ height:10px!important;\
+ width:10px!important;\
+ padding:0!important;\
+ margin:0!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ border:1px solid white!important;\
+ -webkit-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
+ -moz-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
+ box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
+ opacity:0.8!important;\
+ }\
+ #sp-fw-dot,\
+ #sp-fw-cur-mode {\
+ position:absolute!important;\
+ z-index:9999!important;\
+ width:5px!important;\
+ height:5px!important;\
+ padding:0!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ border:1px solid white!important;\
+ opacity:1!important;\
+ -webkit-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
+ -moz-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
+ box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
+ }\
+ #sp-fw-dot{\
+ right:-3px!important;\
+ top:-3px!important;\
+ }\
+ #sp-fw-cur-mode{\
+ left:-3px!important;\
+ top:-3px!important;\
+ width:6px!important;\
+ height:6px!important;\
+ }\
+ #sp-fw-content{\
+ padding:0!important;\
+ margin:5px 5px 0 0!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ border:1px solid #A0A0A0!important;\
+ -webkit-box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
+ -moz-box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
+ box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
+ }\
+ #sp-fw-main {\
+ padding:5px!important;\
+ border:1px solid white!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ background-color:#F2F2F7!important;\
+ background: -moz-linear-gradient(top, #FCFCFC, #F2F2F7 100%)!important;\
+ background: -webkit-gradient(linear, 0 0, 0 100%, from(#FCFCFC), to(#F2F2F7))!important;\
+ }\
+ #sp-fw-foot{\
+ position:relative!important;\
+ left:0!important;\
+ right:0!important;\
+ min-height:20px!important;\
+ }\
+ #sp-fw-savebutton{\
+ position:absolute!important;\
+ top:0!important;\
+ right:2px!important;\
+ }\
+ #sp-fw-container .sp-fw-spanbutton{\
+ border:1px solid #ccc!important;\
+ -moz-border-radius:3px!important;\
+ border-radius:3px!important;\
+ padding:2px 3px!important;\
+ cursor:pointer!important;\
+ background-color:#F9F9F9!important;\
+ -webkit-box-shadow:inset 0 10px 5px white!important;\
+ -moz-box-shadow:inset 0 10px 5px white!important;\
+ box-shadow:inset 0 10px 5px white!important;\
+ }\
+ ');
+ },
+ removeStyle: function() {
+ if (this.style) {
+ this.style.parentNode.removeChild(this.style);
+ this.style = null;
+ }
+ },
+ addContaner: function() {
+ var div = document.createElement('div');
+ div.id = 'sp-fw-container';
+ div.innerHTML = '\
+
\
+ \
+
\
+
\
+ 使用翻页模式\
+ Super_preloaderPlus\
+
\
+
\
+ \
+ \
+
\
+
\
+ ';
+ document.body.appendChild(div);
+
+ // 缓存变量
+ this.container = div;
+ this.rect = this.getId('sp-fw-rect'); // 悬浮窗的小正方形,用颜色描述当前的状态.
+ this.dot = this.getId('sp-fw-dot'); // 设置面板.
+ this.cur_mode = this.getId('sp-fw-cur-mode');
+ },
+ removeContainer: function() {
+ if (this.container) {
+ this.container.parentNode.removeChild(this.container);
+ this.container = null;
+ }
+ },
+ // 有待进一步优化
+ initContainer: function() {
+ var spanel = this.getId('sp-fw-content');
+
+ var spanelc = {
+ show: function() {
+ spanel.style.display = 'block';
+ },
+ hide: function() {
+ spanel.style.display = 'none';
+ },
+ };
+
+ var rectt1,
+ rectt2;
+
+ // 设置面板显隐
+ this.rect.addEventListener('mouseover', function(e) {
+ rectt1 = setTimeout(spanelc.show, 100);
+ }, false);
+ this.rect.addEventListener('mouseout', function(e) {
+ clearTimeout(rectt1);
+ }, false);
+
+ this.container.addEventListener('mouseover', function(e) {
+ clearTimeout(rectt2);
+ }, false);
+
+ this.container.addEventListener('mouseout', function(e) {
+ if (e.relatedTarget && e.relatedTarget.disabled) return; // for firefox and chrome
+ rectt2 = setTimeout(spanelc.hide, 288);
+ }, false);
+
+ // 载入完成后,显示的小点
+ this.dot.style.backgroundColor = FWKG_color.dot;
+
+ // 当载入状态时,用来描述当前是翻页模式,还是预读模式.
+ this.cur_mode.style.backgroundColor = this.SSS.a_enable ? FWKG_color.autopager : FWKG_color.prefetcher;
+
+ this.loadSetting();
+ },
+ // 有待进一步优化
+ loadSetting: function() {
+ var SSS = this.SSS,
+ autoPO = this.autoPO,
+ div = this.container;
+
+ function $(id) {
+ return document.getElementById(id);
+ }
+
+ // 启用翻页模式
+ var a_enable = $('sp-fw-a_enable');
+ // 翻页设置区域
+ var autopager_field = $('sp-fw-autopager-field');
+
+ //预读设置
+ var useiframe = $('sp-fw-useiframe');
+ var viewcontent = $('sp-fw-viewcontent');
+
+ //翻页设置
+ var a_useiframe = $('sp-fw-a_useiframe');
+ var a_iloaded = $('sp-fw-a_iloaded');
+ var a_itimeout = $('sp-fw-a_itimeout');
+ var a_manualA = $('sp-fw-a_manualA');
+ var a_remain = $('sp-fw-a_remain');
+ var a_maxpage = $('sp-fw-a_maxpage');
+ var a_separator = $('sp-fw-a_separator');
+ var a_ipages_0 = $('sp-fw-a_ipages_0');
+ var a_ipages_1 = $('sp-fw-a_ipages_1');
+ var a_force = $('sp-fw-a_force');
+
+ // newIframe 输入框的点击
+ var a_newIframe = $('sp-fw-a_newIframe');
+ a_newIframe.addEventListener('click', function(){
+ a_useiframe.checked = a_newIframe.checked;
+ }, false);
+
+ var a_starti = $('sp-fw-a_starti'); // 开始立即翻页
+ a_starti.addEventListener('click', function() {
+ if (this.disabled) return;
+ var value = Number(a_ipages_1.value);
+ if (isNaN(value) || value <= 0) {
+ value = SSS.a_ipages[1];
+ a_ipages_1.value = value;
+ }
+ autoPO.startipages(value);
+ }, false);
+
+ //总开关
+ var enable = $('sp-fw-enable');
+ $('sp-fw-setup').addEventListener('click', setup, false);
+
+ // 保存设置按钮.
+ var savebutton = $('sp-fw-savebutton');
+ savebutton.addEventListener('click', function(e) {
+ var value = {
+ Rurl: SSS.Rurl,
+ useiframe: gl(useiframe),
+ viewcontent: gl(viewcontent),
+ enable: gl(enable),
+ };
+
+ function gl(obj) {
+ return (obj.type == 'checkbox' ? obj.checked : obj.value);
+ }
+ if (SSS.a_enable !== undefined) {
+ value.a_enable = gl(a_enable);
+ value.a_useiframe = gl(a_useiframe);
+ value.a_newIframe = gl(a_newIframe);
+ value.a_iloaded = gl(a_iloaded);
+ value.a_manualA = gl(a_manualA);
+ value.a_force = gl(a_force);
+ var t_a_itimeout = Number(gl(a_itimeout));
+ value.a_itimeout = isNaN(t_a_itimeout) ? SSS.a_itimeout : (t_a_itimeout >= 0 ? t_a_itimeout : 0);
+ var t_a_remain = Number(gl(a_remain));
+ value.a_remain = isNaN(t_a_remain) ? SSS.a_remain : Number(t_a_remain.toFixed(2));
+ var t_a_maxpage = Number(gl(a_maxpage));
+ value.a_maxpage = isNaN(t_a_maxpage) ? SSS.a_maxpage : (t_a_maxpage >= 1 ? t_a_maxpage : 1);
+ var t_a_ipages_1 = Number(gl(a_ipages_1));
+ value.a_ipages = [gl(a_ipages_0), (isNaN(t_a_ipages_1) ? SSS.a_ipages[1] : (t_a_ipages_1 >= 1 ? t_a_ipages_1 : 1))];
+ value.a_separator = gl(a_separator);
+ }
+ //alert(xToString(value));
+ SSS.savedValue[SSS.sedValueIndex] = value;
+ //alert(xToString(SSS.savedValue));
+ saveValue('spfwset', xToString(SSS.savedValue));
+ if ((e.shiftKey ? !prefs.FW_RAS : prefs.FW_RAS)) { //按住shift键,执行反向操作.
+ setTimeout(function(){
+ location.reload();
+ }, 1);
+ }
+ }, false);
+
+ function ll(obj, value) {
+ if (obj.type == 'checkbox') {
+ obj.checked = value;
+ } else {
+ obj.value = value;
+ }
+ }
+
+
+ // 载入翻页设置.
+ if (SSS.a_enable === undefined) { //未定义翻页功能.
+ a_enable.disabled = true;
+ autopager_field.style.display = 'none';
+ } else {
+ ll(a_enable, SSS.a_enable);
+ ll(a_useiframe, SSS.a_useiframe);
+ ll(a_newIframe, SSS.a_newIframe);
+ ll(a_iloaded, SSS.a_iloaded);
+ ll(a_itimeout, SSS.a_itimeout);
+ ll(a_manualA, SSS.a_manualA);
+ ll(a_force, SSS.a_force);
+ ll(a_remain, SSS.a_remain);
+ ll(a_maxpage, SSS.a_maxpage);
+ ll(a_separator, SSS.a_separator);
+ ll(a_ipages_0, SSS.a_ipages[0]);
+ ll(a_ipages_1, SSS.a_ipages[1]);
+ }
+
+ if (!SSS.a_enable) { //当前不是翻页模式,禁用立即翻页按钮.
+ a_starti.disabled = true;
+ }
+
+ if (!SSS.hasRule) { //如果没有高级规则,那么此项不允许操作.
+ a_force.disabled = true;
+ }
+
+ //载入预读设置.
+ ll(useiframe, SSS.useiframe);
+ ll(viewcontent, SSS.viewcontent);
+
+ //总开关
+ ll(enable, SSS.enable);
+
+ var vertical = parseInt(prefs.FW_offset[0], 10);
+ var horiz = parseInt(prefs.FW_offset[1], 10);
+ var FW_position = prefs.FW_position;
+
+ // 非opera用fixed定位.
+ div.style.position = 'fixed';
+ switch (FW_position) {
+ case 1:
+ div.style.top = vertical + 'px';
+ div.style.left = horiz + 'px';
+ break;
+ case 2:
+ div.style.top = vertical + 'px';
+ div.style.right = horiz + 'px';
+ break;
+ case 3:
+ div.style.bottom = vertical + 'px';
+ div.style.right = horiz + 'px';
+ break;
+ case 4:
+ div.style.bottom = vertical + 'px';
+ div.style.left = horiz + 'px';
+ break;
+ default:
+ break;
+ }
+ },
+
+ FWKG_state: {
+ loading: '读取中状态',
+ prefetcher: '预读状态',
+ autopager: '翻页状态',
+ Apause: '翻页状态(暂停)',
+ Astop: '翻页状态(停止)(翻页完成,或者被异常停止)(无法再开启)',
+ dot: '读取完后',
+ },
+ // 相关动作
+ updateColor: function(state) {
+ this.rect.style.backgroundColor = FWKG_color[state];
+ this.rect.setAttribute("title", this.FWKG_state[state]);
+ },
+ loadedIcon: function(command) {
+ this.dot.style.display = command == 'show' ? 'block' : 'none';
+ },
+ CmodeIcon: function(command) {
+ this.cur_mode.style.display = command == 'show' ? 'block' : 'none';
+ },
+
+ // tools
+ getId: function(id) {
+ return document.getElementById(id);
+ }
+};
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/autopager.js b/Super_preloaderPlus/src/autopager.js
new file mode 100644
index 00000000..828f34cf
--- /dev/null
+++ b/Super_preloaderPlus/src/autopager.js
@@ -0,0 +1,907 @@
+
+/**
+ * AutoPager
+ */
+function AutoPager(SSS, floatWO, cplink, nextlink) {
+ var nullFn = function() {},
+ C = console;
+
+ var remove = []; // 需要移除的事件
+
+ this.init.apply(this, arguments);
+
+ this.cplink = cplink;
+ this.nextlink = nextlink;
+
+ //获取插入位置节点.
+ var insertPoint,
+ insertMode,
+ pageElement = getAllElements(SSS.a_pageElement);
+
+ if (SSS.a_HT_insert) {
+ insertPoint = getElement(SSS.a_HT_insert[0]);
+ insertMode = SSS.a_HT_insert[1];
+ } else {
+ if (pageElement.length > 0) {
+ var pELast = pageElement[pageElement.length - 1];
+ insertPoint = pELast.nextSibling ? pELast.nextSibling : pELast.parentNode.appendChild(document.createTextNode(' '));
+ }
+ }
+
+ if (insertPoint) {
+ debug('验证是否能找到插入位置节点:成功,', insertPoint);
+ } else {
+ C.error('验证是否能找到插入位置节点:失败', (SSS.a_HT_insert ? SSS.a_HT_insert[0] : ''), 'JS执行终止');
+ floatWO.updateColor('Astop');
+ return;
+ }
+
+ if (pageElement.length > 0) {
+ debug('验证是否能找到主要元素:成功,', pageElement);
+ } else {
+ C.error('验证是否能找到主要元素:失败,', SSS.a_pageElement, 'JS执行终止');
+ floatWO.updateColor('Astop');
+ return;
+ }
+
+ if (SSS.a_stylish) { // 插入自定义样式
+ GM_addStyle(SSS.a_stylish, 'Super_preloader-custom-style');
+ }
+
+ var insertPointP;
+ if (insertMode != 2) {
+ insertPointP = insertPoint.parentNode;
+ }
+
+ var addIntoDoc;
+ if (insertMode == 2) {
+ addIntoDoc = function(obj) {
+ return insertPoint.appendChild(obj);
+ };
+ } else {
+ addIntoDoc = function(obj) {
+ return insertPointP.insertBefore(obj, insertPoint);
+ };
+ }
+
+ var doc, win;
+
+ function XHRLoaded(req) {
+ var str = req.responseText;
+ doc = win = createDocumentByString(str);
+
+ if (!doc) {
+ C.error('文档对象创建失败');
+ removeL();
+ return;
+ }
+ floatWO.updateColor('autopager');
+ floatWO.CmodeIcon('hide');
+ floatWO.loadedIcon('show');
+ working = false;
+ scroll();
+ }
+
+ function removeL(isRemoveAddPage) {
+ debug('移除各种事件监听');
+ floatWO.updateColor('Astop');
+ var _remove = remove;
+ for (var i = 0, ii = _remove.length; i < ii; i++) {
+ _remove[i]();
+ }
+
+ if (isRemoveAddPage) {
+ var separator = document.querySelector('.sp-separator');
+ if (separator) {
+ var insertBefore = insertPoint;
+ if (insertMode == 2) {
+ var l = insertPoint.children.length;
+ if (l > 0) {
+ insertBefore = insertPoint.children[l - 1];
+ }
+ }
+
+ var range = document.createRange();
+ range.setStartBefore(separator);
+ range.setEndBefore(insertBefore);
+ range.deleteContents();
+ range.detach();
+
+ if (insertMode == 2) { // 还需要额外移除?
+ insertPoint.removeChild(insertBefore);
+ }
+ }
+ var style = document.getElementById("Super_preloader-style");
+ if (style)
+ style.parentNode.removeChild(style);
+ }
+ }
+ if (isHashchangeSite && !hashchangeAdded) {
+ window.addEventListener("hashchange", onhashChange, false);
+ hashchangeAdded = true;
+ debug('成功添加 hashchange 事件');
+ }
+
+ function onhashChange(event) {
+ debug("触发 Hashchang 事件");
+ removeL(true);
+
+ setTimeout(function(){
+ nextlink = getElement(SSS.nextLink || 'auto;');
+ nextlink = getFullHref(nextlink);
+ // preLink = getElement(SSS.preLink || 'auto;');
+ autopager(SSS, floatWO);
+ }, hashchangeTimer);
+ }
+
+ var iframe;
+ var messageR;
+
+ function iframeLoaded() {
+ var iframe = this;
+ //alert(this.contentDocument.body)
+ var body = iframe.contentDocument.body;
+ if (body && body.firstChild) {
+ setTimeout(function() {
+ doc = iframe.contentDocument;
+ removeScripts(doc);
+ win = iframe.contentWindow || doc;
+ floatWO.updateColor('autopager');
+ floatWO.CmodeIcon('hide');
+ floatWO.loadedIcon('show');
+ working = false;
+
+ scroll();
+ }, SSS.a_itimeout);
+ }
+ }
+
+ function iframeRquest(link) {
+ messageR = false;
+ if (SSS.a_newIframe || !iframe) {
+ var i = document.createElement('iframe');
+ iframe = i;
+ i.name = 'superpreloader-iframe';
+ i.width = '100%';
+ i.height = '0';
+ i.frameBorder = "0";
+ i.style.cssText = '\
+ margin:0!important;\
+ padding:0!important;\
+ visibility:hidden!important;\
+ ';
+ i.src = link;
+ if (SSS.a_iloaded) {
+ i.addEventListener('load', iframeLoaded, false);
+ remove.push(function() {
+ i.removeEventListener('load', iframeLoaded, false);
+ });
+ } else {
+ var messagehandler = function (e) {
+ if (!messageR && e.data == 'superpreloader-iframe:DOMLoaded') {
+ messageR = true;
+ iframeLoaded.call(i);
+ if (SSS.a_newIframe) {
+ window.removeEventListener('message', messagehandler, false);
+ }
+ }
+ };
+ window.addEventListener('message', messagehandler, false);
+ remove.push(function() {
+ window.removeEventListener('message', messagehandler, false);
+ });
+ }
+ document.body.appendChild(i);
+ } else {
+ iframe.src = link;
+ iframe.contentDocument.location.replace(link);
+ }
+ }
+
+ var working;
+
+ function doRequest() {
+ working = true;
+ floatWO.updateColor('loading');
+ floatWO.CmodeIcon('show');
+
+ debug('获取下一页' + (SSS.a_useiframe ? '(iframe方式)': ''), nextlink);
+ if (SSS.a_useiframe) {
+ iframeRquest(nextlink);
+ } else {
+ GM_xmlhttpRequest({
+ method: "GET",
+ url: nextlink,
+ overrideMimeType: 'text/html; charset=' + document.characterSet,
+ onload: XHRLoaded
+ });
+ }
+ }
+
+ var ipagesmode = SSS.a_ipages[0];
+ var ipagesnumber = SSS.a_ipages[1];
+ var scrollDo = nullFn;
+ var afterInsertDo = nullFn;
+ if (prefs.Aplus) {
+ afterInsertDo = doRequest;
+ doRequest();
+ } else {
+ scrollDo = doRequest;
+ if (ipagesmode) doRequest();
+ }
+
+ var manualDiv;
+
+ function manualAdiv() {
+ if (!manualDiv) {
+ GM_addStyle('\
+ #sp-sp-manualdiv{\
+ line-height:1.6!important;\
+ opacity:1!important;\
+ position:relative!important;\
+ float:none!important;\
+ top:0!important;\
+ left:0!important;\
+ z-index: 1000!important;\
+ min-width:366px!important;\
+ width:auto!important;\
+ text-align:center!important;\
+ font-size:14px!important;\
+ padding:3px 0!important;\
+ margin:5px 10px 8px;\
+ clear:both!important;\
+ border-top:1px solid #ccc!important;\
+ border-bottom:1px solid #ccc!important;\
+ -moz-border-radius:30px!important;\
+ border-radius:30px!important;\
+ background-color:#F5F5F5!important;\
+ -moz-box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ -webkit-box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ }\
+ .sp-sp-md-span{\
+ font-weight:bold!important;\
+ margin:0 5px!important;\
+ }\
+ #sp-sp-md-number{\
+ width:50px!important;\
+ vertical-align:middle!important;\
+ display:inline-block!important;\
+ text-align:left!important;\
+ }\
+ #sp-sp-md-imgnext{\
+ padding:0!important;\
+ margin:0 0 0 5px!important;\
+ vertical-align:middle!important;\
+ display:inline-block!important;\
+ }\
+ #sp-sp-manualdiv:hover{\
+ cursor:pointer;\
+ }\
+ #sp-sp-md-someinfo{\
+ position:absolute!important;\
+ right:16px!important;\
+ bottom:1px!important;\
+ font-size:10px!important;\
+ text-shadow:white 0 1px 0!important;\
+ color:#5A5A5A!important;\
+ font-style:italic!important;\
+ z-index:-1!important;\
+ background:none!important;\
+ }\
+ ');
+
+ var div = $C('div', { id: 'sp-sp-manualdiv' });
+ manualDiv = div;
+ var span = $C('span', { class: 'sp-sp-md-span' }, '下');
+ div.appendChild(span);
+
+ var input = $C('input', {
+ type: 'number',
+ value: 1,
+ min: 1,
+ title: '输入你想要拼接的页数(必须>=1),然后按回车.',
+ id: 'sp-sp-md-number'
+ });
+
+ var getInputValue = function () {
+ var value = Number(input.value);
+ if (isNaN(value) || value < 1) {
+ value = 1;
+ input.value = 1;
+ }
+ return value;
+ };
+
+ var spage = function () {
+ if (doc) {
+ var value = getInputValue();
+ //alert(value);
+ ipagesmode = true;
+ ipagesnumber = value + paged;
+ insertedIntoDoc();
+ }
+ };
+ input.addEventListener('keyup', function(e) {
+ //alert(e.keyCode);
+ if (e.keyCode == 13) { //回车
+ spage();
+ }
+ }, false);
+ div.appendChild(input);
+ div.appendChild($C('span', { className: 'sp-sp-md-span' }, '页'));
+ div.appendChild($C('img', {id: 'sp-sp-md-imgnext', src: _sep_icons.next}));
+ div.appendChild($C('span', { id: 'sp-sp-md-someinfo' }, prefs.someValue));
+ document.body.appendChild(div);
+ div.addEventListener('click', function(e) {
+ if (e.target.id == 'sp-sp-md-number') return;
+ spage();
+ }, false);
+ }
+ addIntoDoc(manualDiv);
+ manualDiv.style.display = 'block';
+ }
+
+ function beforeInsertIntoDoc() {
+ working = true;
+ if (SSS.a_manualA && !ipagesmode) { //显示手动翻页触发条.
+ manualAdiv();
+ } else { //直接拼接.
+ insertedIntoDoc();
+ }
+ }
+
+
+ var sepStyle;
+ var goNextImg = [false];
+ var sNumber = prefs.sepStartN;
+ var _sep_icons = sep_icons;
+ var curNumber = sNumber;
+
+ function createSep(lastUrl, currentUrl, nextUrl) {
+ var div = document.createElement('div');
+ if (SSS.a_separator) {
+ if (!sepStyle) {
+ sepStyle = GM_addStyle('\
+ div.sp-separator{\
+ line-height:1.6!important;\
+ opacity:1!important;\
+ position:relative!important;\
+ float:none!important;\
+ top:0!important;\
+ left:0!important;\
+ min-width:366px;\
+ width:auto;\
+ text-align:center!important;\
+ font-size:14px!important;\
+ display:block!important;\
+ padding:3px 0!important;\
+ margin:5px 10px 8px;\
+ clear:both!important;\
+ border-top:1px solid #ccc!important;\
+ border-bottom:1px solid #ccc!important;\
+ -moz-border-radius:30px!important;\
+ border-radius:30px!important;\
+ background-color:#F5F5F5!important;\
+ -moz-box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ -webkit-box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
+ }\
+ div.sp-separator img{\
+ vertical-align:middle!important;\
+ cursor:pointer!important;\
+ padding:0!important;\
+ margin:0 5px!important;\
+ border:none!important;\
+ display:inline-block!important;\
+ float:none!important;\
+ width: auto;\
+ height: auto;\
+ }\
+ div.sp-separator a.sp-sp-nextlink{\
+ margin:0 20px 0 -6px!important;\
+ display:inline!important;\
+ text-shadow:#fff 0 1px 0!important;\
+ background:none!important;\
+ }\
+ div.sp-separator span.sp-span-someinfo{\
+ position:absolute!important;\
+ right:16px!important;\
+ bottom:1px!important;\
+ font-size:10px!important;\
+ text-shadow:white 0 1px 0!important;\
+ color:#5A5A5A!important;\
+ font-style:italic!important;\
+ z-index:-1!important;\
+ background:none!important;\
+ }\
+ ');
+ }
+
+ div.className = 'sp-separator';
+ div.id = 'sp-separator-' + curNumber;
+ div.addEventListener('click', sepHandler, false);
+
+ var pageStr = '第 ' + curNumber + ' 页' +
+ ( SSS.a_separatorReal ? getRalativePageStr(lastUrl, currentUrl, nextUrl) : '');
+ div.appendChild($C('a', {
+ class: 'sp-sp-nextlink',
+ href: currentUrl,
+ title: currentUrl
+ }, pageStr));
+
+ div.appendChild($C('img', {
+ src: _sep_icons.top,
+ class: 'sp-sp-gotop',
+ alt: '去到顶部',
+ title: '去到顶部'
+ }));
+
+ div.appendChild($C('img', {
+ src: curNumber == sNumber ? _sep_icons.pre_gray : _sep_icons.pre,
+ class: 'sp-sp-gopre',
+ title: '上滚一页'
+ }));
+
+ var i_next = $C('img', {
+ src: _sep_icons.next_gray,
+ class: 'sp-sp-gonext',
+ title: '下滚一页'
+ });
+
+ if (goNextImg.length == 2) {
+ goNextImg.shift();
+ }
+ goNextImg.push(i_next);
+ div.appendChild(i_next);
+
+ div.appendChild($C('img', {
+ src: _sep_icons.bottom,
+ class: 'sp-sp-gobottom',
+ alt: '去到底部',
+ title: '去到底部'
+ }));
+
+ div.appendChild($C('span', { class: 'sp-span-someinfo' }, prefs.someValue));
+ curNumber += 1;
+ } else {
+ div.style.cssText = '\
+ height:0!important;\
+ width:0!important;\
+ margin:0!important;\
+ padding:0!important;\
+ border:none!important;\
+ clear:both!important;\
+ display:block!important;\
+ visibility:hidden!important;\
+ ';
+ }
+ return div;
+ }
+
+ var paged = 0;
+
+ function insertedIntoDoc() {
+ if (!doc) return;
+
+ if(SSS.a_documentFilter){
+ try{
+ SSS.a_documentFilter(doc, nextlink);
+ }catch(e){
+ C.error("执行 documentFilter 错误", e, SSS.a_documentFilter.toString());
+ }
+ }
+
+ var docTitle = getElementByCSS("title", doc).textContent;
+
+ removeScripts(doc);
+
+ var fragment = document.createDocumentFragment();
+ var pageElements = getAllElements(SSS.a_pageElement, false, doc, win);
+ var ii = pageElements.length;
+ if (ii <= 0) {
+ debug('获取下一页的主要内容失败', SSS.a_pageElement);
+ removeL();
+ return;
+ }
+
+ // 提前查找下一页链接,后面再赋值
+ var lastUrl = cplink;
+ cplink = nextlink;
+ var nl = getElement(SSS.nextLink, false, doc, win);
+ if (nl) {
+ nl = getFullHref(nl);
+ if (nl == nextlink) {
+ nextlink = null;
+ } else {
+ nextlink = nl;
+ }
+ } else {
+ nextlink = null;
+ }
+
+ var i, pe_x, pe_x_nn;
+ for (i = 0; i < ii; i++) {
+ pe_x = pageElements[i];
+ pe_x_nn = pe_x.nodeName;
+ if (pe_x_nn == 'BODY' || pe_x_nn == 'HTML' || pe_x_nn == 'SCRIPT') continue;
+ fragment.appendChild(pe_x);
+ }
+
+ if (SSS.filter && typeof(SSS.filter) == 'string') { //功能未完善.
+ //alert(SSS.filter);
+ var nodes = [];
+ try {
+ nodes = getAllElements(SSS.filter, fragment);
+ } catch (e) {}
+ var nodes_x;
+ for (i = nodes.length - 1; i >= 0; i--) {
+ nodes_x = nodes[i];
+ nodes_x.parentNode.removeChild(nodes_x);
+ }
+ }
+
+ // lazyImgSrc
+ if (SSS.lazyImgSrc) {
+ handleLazyImgSrc(SSS.lazyImgSrc, fragment);
+ }
+
+ var imgs;
+ if (!window.opera && SSS.a_useiframe && !SSS.a_iloaded) {
+ imgs = getAllElements('css;img[src]', fragment); //收集所有图片
+ }
+
+ // 处理下一页内容部分链接是否新标签页打开
+ if (prefs.forceTargetWindow) {
+ var arr = Array.prototype.slice.call(fragment.querySelectorAll('a[href]:not([href^="mailto:"]):not([href^="javascript:"]):not([href^="#"])'));
+ arr.forEach(function (elem){
+ elem.setAttribute('target', '_blank');
+ if (elem.getAttribute('onclick') == 'atarget(this)') { // 卡饭论坛的控制是否在新标签页打开
+ elem.removeAttribute('onclick');
+ }
+ });
+ }
+
+ var sepdiv = createSep(lastUrl, cplink, nextlink);
+ if (pageElements[0] && pageElements[0].tagName == 'TR') {
+ var insertParent = insertPoint.parentNode;
+ var colNodes = getAllElements('child::tr[1]/child::*[self::td or self::th]', insertParent);
+ var colums = 0;
+ for (var x = 0, l = colNodes.length; x < l; x++) {
+ var col = colNodes[x].getAttribute('colspan');
+ colums += parseInt(col, 10) || 1;
+ }
+ var td = doc.createElement('td');
+ td.appendChild(sepdiv);
+ var tr = doc.createElement('tr');
+ td.setAttribute('colspan', colums);
+ tr.appendChild(td);
+ fragment.insertBefore(tr, fragment.firstChild);
+ } else {
+ fragment.insertBefore(sepdiv, fragment.firstChild);
+ }
+
+ addIntoDoc(fragment);
+
+ // filter
+ if (SSS.filter && typeof(SSS.filter) == 'function') {
+ try{
+ SSS.filter(pageElements);
+ debug("执行 filter(pages) 成功");
+ }catch(e){
+ C.error("执行 filter(pages) 错误", e, SSS.filter.toString());
+ }
+ }
+
+ if (imgs) { //非opera,在iframeDOM取出数据时需要重载图片.
+ setTimeout(function() {
+ var _imgs = imgs;
+ var i, ii, img;
+ for (i = 0, ii = _imgs.length; i < ii; i++) {
+ img = _imgs[i];
+ var src = img.src;
+ img.src = src;
+ }
+ }, 99);
+ }
+
+ if (SSS.a_replaceE) {
+ var oldE = getAllElements(SSS.a_replaceE);
+ var oldE_lt = oldE.length;
+ //alert(oldE_lt);
+ if (oldE_lt > 0) {
+ var newE = getAllElements(SSS.a_replaceE, false, doc, win);
+ var newE_lt = newE.length;
+ //alert(newE_lt);
+ if (newE_lt == oldE_lt) { // 替换
+ var oldE_x, newE_x;
+ for (i = 0; i < newE_lt; i++) {
+ oldE_x = oldE[i];
+ newE_x = newE[i];
+ newE_x = doc.importNode(newE_x, true);
+ oldE_x.parentNode.replaceChild(newE_x, oldE_x);
+ }
+ }
+ }
+ }
+
+ paged += 1;
+ if (ipagesmode && paged >= ipagesnumber) {
+ ipagesmode = false;
+ }
+ floatWO.loadedIcon('hide');
+ if (manualDiv) {
+ manualDiv.style.display = 'none';
+ }
+ if (goNextImg[0]) goNextImg[0].src = _sep_icons.next;
+
+
+ var ev = document.createEvent('Event');
+ ev.initEvent('Super_preloaderPageLoaded', true, false);
+ document.dispatchEvent(ev);
+
+ if(prefs.enableHistory){
+ try {
+ window.history.pushState(null, docTitle, cplink);
+ } catch(e) {}
+ }
+
+ if (paged >= SSS.a_maxpage) {
+ debug('到达所设定的最大翻页数', SSS.a_maxpage);
+ notice('状态:' + '到达所设定的最大翻页数:' + SSS.a_maxpage + '');
+ removeL();
+ return;
+ }
+ var delayiframe = function(fn) {
+ setTimeout(fn, 199);
+ };
+ if (nextlink) {
+ // debug('找到下一页链接:', nextlink);
+ doc = win = null;
+ if (ipagesmode) {
+ if (SSS.a_useiframe) { //延时点,firefox,太急会卡-_-!
+ delayiframe(doRequest);
+ } else {
+ doRequest();
+ }
+ } else {
+ working = false;
+ if (SSS.a_useiframe) {
+ delayiframe(afterInsertDo);
+ } else {
+ afterInsertDo();
+ }
+ }
+ } else {
+ debug('没有找到下一页链接', SSS.nextLink);
+ removeL();
+ return;
+ }
+ }
+
+ //返回,剩余高度是总高度的比值.
+ var relatedObj_0, relatedObj_1;
+ if (SSS.a_relatedObj) {
+ if (Array.isArray(SSS.a_relatedObj)) {
+ relatedObj_0 = SSS.a_relatedObj[0];
+ relatedObj_1 = SSS.a_relatedObj[1];
+ } else {
+ relatedObj_0 = SSS.a_pageElement;
+ relatedObj_1 = 'bottom';
+ }
+ }
+
+ function getRemain() {
+ var scrolly = window.scrollY;
+ var WI = window.innerHeight;
+ var obj = relatedObj_0 &&getLastElement(relatedObj_0);
+ var scrollH = (obj && obj.nodeType == 1) ? (obj.getBoundingClientRect()[relatedObj_1] + scrolly) : Math.max(document.documentElement.scrollHeight, document.body.scrollHeight);
+ return (scrollH - scrolly - WI) / WI; //剩余高度于页面总高度的比例.
+ }
+
+ var pause = false;
+ if (prefs.pauseA) {
+ var Sbutton = ['target', 'shiftKey', 'ctrlKey', 'altKey'];
+ var ltype = prefs.mouseA ? 'mousedown' : 'dblclick';
+ var button_1 = Sbutton[prefs.Pbutton[0]];
+ var button_2 = Sbutton[prefs.Pbutton[1]];
+ var button_3 = Sbutton[prefs.Pbutton[2]];
+
+ var pauseIt = function () {
+ pause = !pause;
+ if (prefs.stop_ipage) ipagesmode = false;
+ if (pause) {
+ floatWO.updateColor('Apause');
+ notice('状态:' + '自动翻页暂停.');
+ } else {
+ floatWO.updateColor('autopager');
+ floatWO.CmodeIcon('hide');
+ notice('状态:' + '自动翻页启用.');
+ }
+ scroll();
+ };
+ var Sctimeout;
+
+ var clearPause = function () {
+ clearTimeout(Sctimeout);
+ document.removeEventListener('mouseup', arguments.callee, false);
+ };
+
+ var pausehandler = function (e) {
+ if (!SSS.a_manualA || ipagesmode || pause) {
+ if (e[button_1] && e[button_2] && e[button_3]) {
+ if (e.type == 'mousedown') {
+ document.addEventListener('mouseup', clearPause, false);
+ Sctimeout = setTimeout(pauseIt, prefs.Atimeout);
+ } else {
+ pauseIt();
+ }
+ }
+ }
+ };
+ document.addEventListener(ltype, pausehandler, false);
+ remove.push(function() {
+ document.removeEventListener(ltype, pausehandler, false);
+ });
+ }
+
+ function scroll() {
+ if (!pause && !working && (getRemain() <= SSS.a_remain || ipagesmode)) {
+ if (doc) { //有的话,就插入到文档.
+ beforeInsertIntoDoc();
+ } else { //否则就请求文档.
+ scrollDo();
+ }
+ }
+ }
+
+ var timeout;
+ function timeoutfn(){
+ clearTimeout(timeout);
+ timeout = setTimeout(scroll, 100);
+ }
+
+ window.addEventListener('scroll', timeoutfn, false);
+ remove.push(function() {
+ window.removeEventListener('scroll', timeoutfn, false);
+ });
+
+
+ this.startipages = function(value) {
+ if (value > 0) {
+ ipagesmode = true;
+ ipagesnumber = value + paged;
+ notice('状态:' + '当前已翻页数量:' + paged + ',' + '连续翻页到第' + ipagesnumber + '页.');
+ if (SSS.a_manualA) insertedIntoDoc();
+ scroll();
+ }
+ };
+}
+
+AutoPager.prototype = {
+ init: function(SSS, floatWO) {
+ this.SSS = SSS;
+ this.floatWO = floatWO;
+
+ // 更新悬浮窗的颜色.
+ floatWO.updateColor('autopager');
+ },
+ destroy: function(isRemoveAddPage) {
+
+ },
+ addListener: function() {
+
+ },
+ removeListener: function() {
+
+ },
+ handleEvent: function(event) {
+
+ },
+ stateToggle: function() {
+
+ },
+ scroll : function() {
+
+ },
+ request : function() {
+
+ },
+ requestLoad : function(res) {
+
+ },
+ addPage : function(htmlDoc, page) {
+ },
+};
+
+function sp_transition(start, end) {
+ var TweenF = sp_transition.TweenF;
+ if (!TweenF) {
+ TweenF = Tween[TweenM[prefs.s_method]];
+ TweenF = TweenF[TweenEase[prefs.s_ease]] || TweenF;
+ sp_transition.TweenF = TweenF;
+ }
+ var frameSpeed = 1000 / prefs.s_FPS;
+ var t = 0; //次数,开始
+ var b = start; //开始
+ var c = end - start; //结束
+ var d = Math.ceil(prefs.s_duration / frameSpeed); //次数,结束
+
+ var x = window.scrollX;
+
+ function transition() {
+ var y = Math.ceil(TweenF(t, b, c, d));
+ //alert(y);
+ window.scroll(x, y);
+ if (t < d) {
+ t++;
+ setTimeout(transition, frameSpeed);
+ }
+ }
+ transition();
+}
+
+function sepHandler(e) {
+ e.stopPropagation();
+ var div = this;
+ //alert(div);
+ var target = e.target;
+ //alert(target);
+
+ function getRelativeDiv(which) {
+ var id = div.id;
+ id = id.replace(/(sp-separator-)(.+)/, function(a, b, c) {
+ return b + String((Number(c) + (which == 'pre' ? -1 : 1)));
+ });
+ //alert(id);
+ return (id ? document.getElementById(id) : null);
+ }
+
+ function scrollIt(a, b) {
+ //a=a!==undefined? a : window.scrollY;
+ if (prefs.sepT) {
+ sp_transition(a, b);
+ } else {
+ window.scroll(window.scrollX, b);
+ }
+ }
+
+ var o_scrollY, divS;
+
+ switch (target.className) {
+ case 'sp-sp-gotop':
+ scrollIt(window.scrollY, 0);
+ break;
+ case 'sp-sp-gopre':
+ var prediv = getRelativeDiv('pre');
+ if (!prediv) return;
+ o_scrollY = window.scrollY;
+ var preDS = prediv.getBoundingClientRect().top;
+ if (prefs.sepP) {
+ divS = div.getBoundingClientRect().top;
+ preDS = o_scrollY - (divS - preDS);
+ } else {
+ preDS += o_scrollY - 6;
+ }
+ scrollIt(o_scrollY, preDS);
+ break;
+ case 'sp-sp-gonext':
+ var nextdiv = getRelativeDiv('next');
+ if (!nextdiv) return;
+ o_scrollY = window.scrollY;
+ var nextDS = nextdiv.getBoundingClientRect().top;
+ if (prefs.sepP) {
+ divS = div.getBoundingClientRect().top;
+ nextDS = o_scrollY + (-divS + nextDS);
+ } else {
+ nextDS += o_scrollY - 6;
+ }
+ scrollIt(o_scrollY, nextDS);
+ break;
+ case 'sp-sp-gobottom':
+ scrollIt(window.scrollY, Math.max(document.documentElement.scrollHeight, document.body.scrollHeight));
+ break;
+ default:
+ break;
+ }
+}
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/libs.js b/Super_preloaderPlus/src/libs.js
new file mode 100644
index 00000000..542f8a46
--- /dev/null
+++ b/Super_preloaderPlus/src/libs.js
@@ -0,0 +1,1134 @@
+// ==================== libs ==============================
+
+// 自造简化版 underscroe 库,仅 ECMAScript 5
+var _ = (function(){
+
+ var nativeIsArray = Array.isArray;
+ var _ = function(obj){
+ if(obj instanceof _) return obj;
+ if(!(this instanceof _)) return new _(obj);
+ this._wrapped = obj;
+ };
+
+ // Return the first value which passes a truth test. Aliased as `detect`.
+ _.find = function(obj, iterator, context){
+ var result;
+ obj.some(function(value, index, array){
+ if(iterator.call(context, value, index, array)){
+ result = value;
+ return true;
+ }
+ });
+ return result;
+ };
+
+ return _;
+})();
+
+
+function gmCompatible() {
+
+ GM_addStyle = function(css, id){
+ var s = document.createElement('style');
+ if (id) {
+ s.setAttribute(id, id);
+ }
+ s.setAttribute('type', 'text/css');
+ s.setAttribute('style', 'display: none !important;');
+ s.appendChild(document.createTextNode(css));
+ return (document.getElementsByTagName('head')[0] || document.documentElement).appendChild(s);
+ };
+
+ if (typeof unsafeWindow == "undefined") {
+ unsafeWindow = window;
+ }
+
+ if (typeof GM_getValue != "undefined" && GM_getValue("a", "b") !== undefined) {
+ return;
+ }
+
+ GM_getValue = function(key, defaultValue) {
+ var value = window.localStorage.getItem(key);
+ if (value === null) value = defaultValue;
+ else if (value == 'true') value = true;
+ else if (value == 'false') value = false;
+ return value;
+ };
+ GM_setValue = function(key, value) {
+ window.localStorage.setItem(key, value);
+ };
+ GM_registerMenuCommand = function() {};
+
+ if (typeof GM_xmlhttpRequest == 'undefined') {
+ GM_xmlhttpRequest = function(opt) {
+ var req = new XMLHttpRequest();
+ req.open('GET', opt.url, true);
+ req.overrideMimeType(opt.overrideMimeType);
+ req.onreadystatechange = function (aEvt) {
+ if (req.readyState == 4) {
+ if (req.status == 200) {
+ opt.onload(req);
+ }
+ else {
+ opt.onerror();
+ }
+ }
+ };
+ req.send(null);
+ };
+ }
+}
+
+// By lastDream2013 略加修改,原版只能用于 Firefox
+function getRalativePageStr(lastUrl, currentUrl, nextUrl) {
+ function getDigital(str) {
+ var num = str.replace(/^p/i, '');
+ return parseInt(num, 10);
+ }
+
+ var getRalativePageNumArray = function (lasturl, url) {
+ if (!lasturl || !url) {
+ return [0, 0];
+ }
+
+ var lasturlarray = lasturl.split(/-|\.|\&|\/|=|#|\?/),
+ urlarray = url.split(/-|\.|\&|\/|=|#|\?/),
+ url_info,
+ lasturl_info;
+ // 一些 url_info 为 p1,p2,p3 之类的
+ var handleInfo = function(s) {
+ if (s) {
+ return s.replace(/^p/, '');
+ }
+ return s;
+ };
+ while (urlarray.length !== 0) {
+ url_info = handleInfo(urlarray.pop());
+ lasturl_info = handleInfo(lasturlarray.pop());
+ if (url_info != lasturl_info) {
+ if (/[0-9]+/.test(url_info) && (url_info == "2" || /[0-9]+/.test(lasturl_info))) {
+ return [(parseInt(lasturl_info) || 1), parseInt(url_info)];
+ }
+ }
+ }
+ return [0, 0];
+ };
+
+ var ralativeOff;
+
+ //论坛和搜索引擎网页显示实际页面信息
+ var ralativePageNumarray = [];
+ if (nextUrl) {
+ ralativePageNumarray = getRalativePageNumArray(currentUrl, nextUrl);
+ } else {
+ ralativePageNumarray = getRalativePageNumArray(lastUrl, currentUrl);
+ ralativeOff = ralativePageNumarray[1] - ralativePageNumarray[0]; //用的上一页的相对信息比较的,要补充差值……
+ ralativePageNumarray[1] = ralativePageNumarray[1] + ralativeOff;
+ ralativePageNumarray[0] = ralativePageNumarray[0] + ralativeOff;
+ }
+
+ // console.log('[获取实际页数] ', '要比较的3个页数:',arguments, ',得到的差值:', ralativePageNumarray);
+ if (isNaN(ralativePageNumarray[0]) || isNaN(ralativePageNumarray[1])) {
+ return '';
+ }
+
+ var realPageSiteMatch = false;
+ ralativeOff = ralativePageNumarray[1] - ralativePageNumarray[0];
+ //上一页与下一页差值为1,并最大数值不超过10000(一般论坛也不会超过这么多页……)
+ if (ralativeOff === 1 && ralativePageNumarray[1] < 10000) {
+ realPageSiteMatch = true;
+ }
+
+ //上一页与下一页差值不为1,但上一页与下一页差值能被上一页与下一面所整除的,有规律的页面
+ if (!realPageSiteMatch && ralativeOff !== 1) {
+ if ((ralativePageNumarray[1] % ralativeOff) === 0 && (ralativePageNumarray[0] % ralativeOff) === 0) {
+ realPageSiteMatch = true;
+ }
+ }
+
+ if (!realPageSiteMatch) { //不满足以上条件,再根据地址特征来匹配
+ var sitePattern;
+ for (var i = 0, length = REALPAGE_SITE_PATTERN.length; i < length; i++) {
+ sitePattern = REALPAGE_SITE_PATTERN[i];
+ if (currentUrl.toLocaleLowerCase().indexOf(sitePattern) >= 0) {
+ realPageSiteMatch = true;
+ break;
+ }
+ }
+ }
+
+ var ralativePageStr;
+ if (realPageSiteMatch) { //如果匹配就显示实际网页信息
+ if (ralativePageNumarray[1] - ralativePageNumarray[0] > 1) { //一般是搜索引擎的第xx - xx项……
+ ralativePageStr = ' [ 实际:第 ' + ralativePageNumarray[0] + ' - ' + ralativePageNumarray[1] + ' 项 ]';
+ } else if ((ralativePageNumarray[1] - ralativePageNumarray[0]) === 1) { //一般的翻页数,差值应该是1
+ ralativePageStr = ' [ 实际:第 ' + ralativePageNumarray[0] + ' 页 ]';
+ } else if ((ralativePageNumarray[0] === 0 && ralativePageNumarray[1]) === 0) { //找不到的话……
+ ralativePageStr = ' [ 实际网页结束 ]';
+ }
+ } else {
+ ralativePageStr = '';
+ }
+ return ralativePageStr || '';
+}
+
+function handleLazyImgSrc(rule, doc) {
+ var imgAttrs = rule.split('|');
+
+ [].forEach.call(doc.querySelectorAll('img'), function(img) {
+ var oldSrc = img.src;
+
+ imgAttrs.some(function(attr) {
+ var newSrc = img.getAttribute(attr);
+ if (newSrc && newSrc != oldSrc) {
+ img.setAttribute("src", newSrc);
+ // img.removeAttribute(attr);
+ return true;
+ }
+ });
+ });
+}
+
+function removeScripts(node) { // 移除元素的 script
+ var scripts = getAllElements('css;script', node);
+ var scripts_x;
+ for (var i = scripts.length - 1; i >= 0; i--) {
+ scripts_x = scripts[i];
+ scripts_x.parentNode.removeChild(scripts_x);
+ }
+}
+
+var noticeDiv;
+var noticeDivto;
+var noticeDivto2;
+function notice(html_txt) {
+ if (!noticeDiv) {
+ var div = document.createElement('div');
+ noticeDiv = div;
+ div.style.cssText = '\
+ position:fixed!important;\
+ z-index:2147483647!important;\
+ float:none!important;\
+ width:auto!important;\
+ height:auto!important;\
+ font-size:13px!important;\
+ padding:3px 20px 2px 5px!important;\
+ background-color:#7f8f9c!important;\
+ border:none!important;\
+ color:#000!important;\
+ text-align:left!important;\
+ left:0!important;\
+ bottom:0!important;\
+ opacity:0;\
+ -moz-border-radius:0 6px 0 0!important;\
+ border-radius:0 6px 0 0!important;\
+ -o-transition:opacity 0.3s ease-in-out;\
+ -webkit-transition:opacity 0.3s ease-in-out;\
+ -moz-transition:opacity 0.3s ease-in-out;\
+ ';
+ document.body.appendChild(div);
+ }
+ clearTimeout(noticeDivto);
+ clearTimeout(noticeDivto2);
+ noticeDiv.innerHTML = html_txt;
+ noticeDiv.style.display = 'block';
+ noticeDiv.style.opacity = '0.96';
+ noticeDivto2 = setTimeout(function() {
+ noticeDiv.style.opacity = '0';
+ }, 1666);
+ noticeDivto = setTimeout(function() {
+ noticeDiv.style.display = 'none';
+ }, 2000);
+}
+
+
+function $C(type, atArr, inner, action, listen) {
+ var e = document.createElement(type);
+ for (var at in atArr) {
+ if (atArr.hasOwnProperty(at)) {
+ e.setAttribute(at, atArr[at]);
+ }
+ }
+ if (action && listen) {
+ e.addEventListener(action, listen, false);
+ }
+ if (inner) {
+ e.innerHTML = inner;
+ }
+ return e;
+}
+
+var docChecked;
+function autoGetLink(doc, win) {
+ if (!autoMatch.keyMatch) return;
+ if (!parseKWRE.done) {
+ parseKWRE();
+ parseKWRE.done = true;
+ }
+
+ var startTime = new Date();
+ doc = doc || document;
+ win = win || window;
+
+ // if (doc == document) { //当前文档,只检查一次.
+ // //alert(nextlink);
+ // if (docChecked) return nextlink;
+ // docChecked = true;
+ // }
+
+ var _prePageKey = prePageKey;
+ var _nextPageKey = nextPageKey;
+ var _nPKL = nextPageKey.length;
+ var _pPKL = prePageKey.length;
+ var _getFullHref = getFullHref;
+ var _getAllElementsByXpath = getAllElementsByXpath;
+ var _Number = Number;
+
+ var _cplink = doc.URL || doc.location.href;
+ var m = _cplink.match(/https?:\/\/([^\/]+)/);
+ if (!m) return;
+ var _domain_port = m[1]; //端口和域名,用来验证是否跨域.
+
+ var alllinks = doc.links;
+ var alllinksl = alllinks.length;
+
+ var curLHref = doc.URL;
+ var _nextlink;
+ var _prelink;
+ // if (!autoGetLink.checked) { //第一次检查
+ // _nextlink = nextlink;
+ // _prelink = prelink;
+ // } else {
+ // _prelink = true;
+ // }
+
+ var DCEnable = autoMatch.digitalCheck;
+ var DCRE = /^\s*\D{0,1}(\d+)\D{0,1}\s*$/;
+
+ var i, a, ahref, atext, numtext;
+ var aP, initSD, searchD = 1,
+ preS1, preS2, searchedD, pSNText, preSS, nodeType;
+ var nextS1, nextS2, nSNText, nextSS;
+ var aimgs, j, jj, aimg_x, xbreak, k, keytext;
+
+ function finalCheck(a, type) {
+ var ahref = a.getAttribute('href'); //在chrome上当是非当前页面文档对象的时候直接用a.href访问,不返回href
+ if (ahref == '#') {
+ return null;
+ }
+ ahref = _getFullHref(ahref); //从相对路径获取完全的href;
+
+ //3个条件:http协议链接,非跳到当前页面的链接,非跨域
+ if (/^https?:/i.test(ahref) && ahref.replace(/#.*$/, '') != curLHref && ahref.match(/https?:\/\/([^\/]+)/)[1] == _domain_port) {
+ if (xbug) {
+ debug((type == 'pre' ? '上一页' : '下一页') + '匹配到的关键字为:', atext);
+ }
+ return a; //返回对象A
+ //return ahref;
+ }
+ }
+
+ if (xbug) {
+ debug('全文档链接数量:', alllinksl);
+ }
+
+ for (i = 0; i < alllinksl; i++) {
+ if (_nextlink && _prelink) break;
+ a = alllinks[i];
+ if (!a) continue; //undefined跳过
+ //links集合返回的本来就是包含href的a元素..所以不用检测
+ //if(!a.hasAttribute("href"))continue;
+ atext = a.textContent;
+ if (atext) {
+ if (DCEnable) {
+ numtext = atext.match(DCRE);
+ if (numtext) { //是不是纯数字
+ //debug(numtext);
+ numtext = numtext[1];
+ //alert(numtext);
+ aP = a;
+ initSD = 0;
+
+ if (!_nextlink) {
+ preS1 = a.previousSibling;
+ preS2 = a.previousElementSibling;
+
+
+ while (!(preS1 || preS2) && initSD < searchD) {
+ aP = aP.parentNode;
+ if (aP) {
+ preS1 = aP.previousSibling;
+ preS2 = aP.previousElementSibling;
+ }
+ initSD++;
+ //alert('initSD: '+initSD);
+ }
+ searchedD = initSD > 0 ? true : false;
+
+ if (preS1 || preS2) {
+ pSNText = preS1 ? preS1.textContent.match(DCRE) : '';
+ if (pSNText) {
+ preSS = preS1;
+ } else {
+ pSNText = preS2 ? preS2.textContent.match(DCRE) : '';
+ preSS = preS2;
+ }
+ //alert(previousS);
+ if (pSNText) {
+ pSNText = pSNText[1];
+ //debug(pSNText)
+ //alert(pSNText)
+ if (_Number(pSNText) == _Number(numtext) - 1) {
+ //alert(searchedD);
+ nodeType = preSS.nodeType;
+ //alert(nodeType);
+ if (nodeType == 3 || (nodeType == 1 && (searchedD ? _getAllElementsByXpath('./descendant-or-self::a[@href]', preSS, doc).snapshotLength === 0 : (!preSS.hasAttribute('href') || _getFullHref(preSS.getAttribute('href')) == curLHref)))) {
+ _nextlink = finalCheck(a, 'next');
+ //alert(_nextlink);
+ }
+ continue;
+ }
+ }
+ }
+ }
+
+ if (!_prelink) {
+ nextS1 = a.nextSibling;
+ nextS2 = a.nextElementSibling;
+
+ while (!(nextS1 || nextS2) && initSD < searchD) {
+ aP = aP.parentNode;
+ if (aP) {
+ nextS1 = a.nextSibling;
+ nextS2 = a.nextElementSibling;
+ }
+ initSD++;
+ //alert('initSD: '+initSD);
+ }
+ searchedD = initSD > 0 ? true : false;
+
+ if (nextS1 || nextS2) {
+ nSNText = nextS1 ? nextS1.textContent.match(DCRE) : '';
+ if (nSNText) {
+ nextSS = nextS1;
+ } else {
+ nSNText = nextS2 ? nextS2.textContent.match(DCRE) : '';
+ nextSS = nextS2;
+ }
+ //alert(nextS);
+ if (nSNText) {
+ nSNText = nSNText[1];
+ //alert(pSNText)
+ if (_Number(nSNText) == _Number(numtext) + 1) {
+ //alert(searchedD);
+ nodeType = nextSS.nodeType;
+ //alert(nodeType);
+ if (nodeType == 3 || (nodeType == 1 && (searchedD ? _getAllElementsByXpath('./descendant-or-self::a[@href]', nextSS, doc).snapshotLength === 0 : (!nextSS.hasAttribute("href") || _getFullHref(nextSS.getAttribute('href')) == curLHref)))) {
+ _prelink = finalCheck(a, 'pre');
+ //alert(_prelink);
+ }
+ }
+ }
+ }
+ }
+ continue;
+ }
+ }
+ } else {
+ atext = a.title;
+ }
+ if (!atext) {
+ aimgs = a.getElementsByTagName('img');
+ for (j = 0, jj = aimgs.length; j < jj; j++) {
+ aimg_x = aimgs[j];
+ atext = aimg_x.alt || aimg_x.title;
+ if (atext) break;
+ }
+ }
+ if (!atext) continue;
+ if (!_nextlink) {
+ xbreak = false;
+ for (k = 0; k < _nPKL; k++) {
+ keytext = _nextPageKey[k];
+ if (!(keytext.test(atext))) continue;
+ _nextlink = finalCheck(a, 'next');
+ xbreak = true;
+ break;
+ }
+ if (xbreak || _nextlink) continue;
+ }
+ if (!_prelink) {
+ for (k = 0; k < _pPKL; k++) {
+ keytext = _prePageKey[k];
+ if (!(keytext.test(atext))) continue;
+ _prelink = finalCheck(a, 'pre');
+ break;
+ }
+ }
+ }
+
+ debug('搜索链接数量:', i, '耗时:', new Date() - startTime, '毫秒');
+
+ if (!autoGetLink.checked) { //只在第一次检测的时候,抛出上一页链接.
+ prelink = _prelink;
+ autoGetLink.checked = true;
+ }
+
+ //alert(_nextlink);
+ return _nextlink;
+}
+
+function parseKWRE() {
+ function modifyPageKey(name, pageKey, pageKeyLength) {
+ function strMTE(str) {
+ return (str.replace(/\\/g, '\\\\')
+ .replace(/\+/g, '\\+')
+ .replace(/\./g, '\\.')
+ .replace(/\?/g, '\\?')
+ .replace(/\{/g, '\\{')
+ .replace(/\}/g, '\\}')
+ .replace(/\[/g, '\\[')
+ .replace(/\]/g, '\\]')
+ .replace(/\^/g, '\\^')
+ .replace(/\$/g, '\\$')
+ .replace(/\*/g, '\\*')
+ .replace(/\(/g, '\\(')
+ .replace(/\)/g, '\\)')
+ .replace(/\|/g, '\\|')
+ .replace(/\//g, '\\/'));
+ }
+
+ var pfwordl = autoMatch.pfwordl,
+ sfwordl = autoMatch.sfwordl;
+
+ var RE_enable_a = pfwordl[name].enable,
+ RE_maxPrefix = pfwordl[name].maxPrefix,
+ RE_character_a = pfwordl[name].character,
+ RE_enable_b = sfwordl[name].enable,
+ RE_maxSubfix = sfwordl[name].maxSubfix,
+ RE_character_b = sfwordl[name].character;
+ var plwords,
+ slwords,
+ rep;
+
+ plwords = RE_maxPrefix > 0 ? ('[' + (RE_enable_a ? strMTE(RE_character_a.join('')) : '.') + ']{0,' + RE_maxPrefix + '}') : '';
+ plwords = '^\\s*' + plwords;
+ //alert(plwords);
+ slwords = RE_maxSubfix > 0 ? ('[' + (RE_enable_b ? strMTE(RE_character_b.join('')) : '.') + ']{0,' + RE_maxSubfix + '}') : '';
+ slwords = slwords + '\\s*$';
+ //alert(slwords);
+ rep = prefs.cases ? '' : 'i';
+
+ for (var i = 0; i < pageKeyLength; i++) {
+ pageKey[i] = new RegExp(plwords + strMTE(pageKey[i]) + slwords, rep);
+ //alert(pageKey[i]);
+ }
+ return pageKey;
+ }
+
+ //转成正则.
+ prePageKey = modifyPageKey('previous', prePageKey, prePageKey.length);
+ nextPageKey = modifyPageKey('next', nextPageKey, nextPageKey.length);
+}
+
+// 地址栏递增处理函数.
+function hrefInc(obj, doc, win) {
+ var _cplink = doc.URL;
+
+ function getHref(href) {
+ var mFails = obj.mFails;
+ if (!mFails) return href;
+ var str;
+ if (typeof mFails == 'string') {
+ str = mFails;
+ } else {
+ var fx;
+ var array = [];
+ var i, ii;
+ var mValue;
+ for (i = 0, ii = mFails.length; i < ii; i++) {
+ fx = mFails[i];
+ if (!fx) continue;
+ if (typeof fx == 'string') {
+ array.push(fx);
+ } else {
+ mValue = href.match(fx);
+ if (!mValue) return href;
+ array.push(mValue);
+ }
+ }
+ str = array.join('');
+ }
+ return str;
+ }
+ // alert(getHref(_cplink))
+
+ var sa = obj.startAfter;
+ var saType = typeof sa;
+ var index;
+
+ if (saType == 'string') {
+ index = _cplink.indexOf(sa);
+ if (index == -1) {
+ _cplink = getHref(_cplink);
+ index = _cplink.indexOf(sa);
+ if (index == -1) return;
+ //alert(index);
+ }
+ } else {
+ var tsa = _cplink.match(sa);
+ //alert(sa);
+ if (!tsa) {
+ _cplink = getHref(_cplink);
+ sa = (_cplink.match(sa) || [])[0];
+ if (!sa) return;
+ index = _cplink.indexOf(sa);
+ if (index == -1) return;
+ } else {
+ sa = tsa[0];
+ index = _cplink.indexOf(sa);
+ //alert(index)
+ //alert(tsa.index)
+ }
+ }
+
+ index += sa.length;
+ var max = obj.max === undefined ? 9999 : obj.max;
+ var min = obj.min === undefined ? 1 : obj.min;
+ var aStr = _cplink.slice(0, index);
+ var bStr = _cplink.slice(index);
+ var nbStr = bStr.replace(/^(\d+)(.*)$/, function(a, b, c) {
+ b = Number(b) + obj.inc;
+ if (b >= max || b < min) return a;
+ return b + c;
+ });
+ // alert(aStr+nbStr);
+ if (nbStr !== bStr) {
+ var ilresult;
+ try {
+ ilresult = obj.isLast(doc, unsafeWindow, _cplink);
+ } catch (e) {}
+ if (ilresult) return;
+ return aStr + nbStr;
+ }
+}
+
+// 获取单个元素,混合
+function getElement(selector, contextNode, doc, win) {
+ var ret;
+ if (!selector) return ret;
+ doc = doc || document;
+ win = win || window;
+ contextNode = contextNode || doc;
+ var type = typeof selector;
+ if (type == 'string') {
+ if (selector.search(/^css;/i) === 0) {
+ ret = getElementByCSS(selector.slice(4), contextNode);
+ } else if (selector.toLowerCase() == 'auto;') {
+ ret = autoGetLink(doc, win);
+ } else {
+ ret = getElementByXpath(selector, contextNode, doc);
+ }
+ } else if (type == 'function') {
+ var _cplink = doc.URL;
+ ret = selector(doc, win, _cplink);
+ } else if (selector instanceof Array) {
+ for (var i = 0, l = selector.length; i < l; i++) {
+ ret = getElement(selector[i], contextNode, doc, win);
+ if (ret) {
+ break;
+ }
+ }
+ } else {
+ ret = hrefInc(selector, doc, win);
+ }
+ return ret;
+}
+
+// css 获取单个元素
+function getElementByCSS(css, contextNode) {
+ return (contextNode || document).querySelector(css);
+}
+
+// css 获取所有元素
+function getAllElementsByCSS(css, contextNode) {
+ return (contextNode || document).querySelectorAll(css);
+}
+
+// xpath 获取单个元素
+function getElementByXpath(xpath, contextNode, doc) {
+ doc = doc || document;
+ contextNode = contextNode || doc;
+ return doc.evaluate(xpath, contextNode, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
+}
+
+// xpath 获取多个元素.
+function getAllElementsByXpath(xpath, contextNode, doc) {
+ doc = doc || document;
+ contextNode = contextNode || doc;
+ return doc.evaluate(xpath, contextNode, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
+}
+
+// 获取多个元素
+function getAllElements(selector, contextNode, doc, win) {
+ var ret = [];
+ if (!selector) return ret;
+ var Eles;
+ doc = doc || document;
+ win = win || window;
+ contextNode = contextNode || doc;
+ if (typeof selector == 'string') {
+ if (selector.search(/^css;/i) === 0) {
+ Eles = getAllElementsByCSS(selector.slice(4), contextNode);
+ } else {
+ Eles = getAllElementsByXpath(selector, contextNode, doc);
+ }
+ } else {
+ Eles = selector(doc, win);
+ if (!Eles) return ret;
+ if (Eles.nodeType) { //单个元素.
+ ret[0] = Eles;
+ return ret;
+ }
+ }
+
+ function unique(array) { //数组去重并且保持数组顺序.
+ var i, ca, ca2, j;
+ for (i = 0; i < array.length; i++) {
+ ca = array[i];
+ for (j = i + 1; j < array.length; j++) {
+ ca2 = array[j];
+ if (ca2 == ca) {
+ array.splice(j, 1);
+ j--;
+ }
+ }
+ }
+ return array;
+ }
+
+ function makeArray(x) {
+ var ret = [];
+ var i, ii;
+ var x_x;
+ if (x.pop) { //普通的 array
+ for (i = 0, ii = x.length; i < ii; i++) {
+ x_x = x[i];
+ if (x_x) {
+ if (x_x.nodeType) { //普通类型,直接放进去.
+ ret.push(x_x);
+ } else {
+ ret = ret.concat(makeArray(x_x)); //嵌套的.
+ }
+ }
+ }
+ //alert(ret)
+ return unique(ret);
+ } else if (x.item) { //nodelist or HTMLcollection
+ i = x.length;
+ while (i) {
+ ret[--i] = x[i];
+ }
+ /*
+ for(i=0,ii=x.length;i 0) {
+ return eles[l - 1];
+ }
+}
+
+function saveValue(key, value) {
+ localStorage.setItem(key, encodeURIComponent(value));
+}
+
+function getValue(key) {
+ var value = localStorage.getItem(key);
+ return value ? decodeURIComponent(value) : undefined;
+}
+
+function createDocumentByString(str) { // string转为DOM
+ if (!str) {
+ C.error('没有找到要转成DOM的字符串');
+ return;
+ }
+ if (document.documentElement.nodeName != 'HTML') {
+ return new DOMParser().parseFromString(str, 'application/xhtml+xml');
+ }
+
+ var doc;
+ try {
+ // firefox and chrome 30+,Opera 12 会报错
+ doc = new DOMParser().parseFromString(str, 'text/html');
+ } catch (ex) {}
+
+ if (doc) {
+ return doc;
+ }
+
+ if (document.implementation.createHTMLDocument) {
+ doc = document.implementation.createHTMLDocument('superPreloader');
+ } else {
+ try {
+ doc = document.cloneNode(false);
+ doc.appendChild(doc.importNode(document.documentElement, false));
+ doc.documentElement.appendChild(doc.createElement('head'));
+ doc.documentElement.appendChild(doc.createElement('body'));
+ } catch (e) {}
+ }
+ if (!doc) return;
+ var range = document.createRange();
+ range.selectNodeContents(document.body);
+ var fragment = range.createContextualFragment(str);
+ doc.body.appendChild(fragment);
+ var headChildNames = {
+ TITLE: true,
+ META: true,
+ LINK: true,
+ STYLE: true,
+ BASE: true
+ };
+ var child;
+ var body = doc.body;
+ var bchilds = body.childNodes;
+ for (var i = bchilds.length - 1; i >= 0; i--) { //移除head的子元素
+ child = bchilds[i];
+ if (headChildNames[child.nodeName]) body.removeChild(child);
+ }
+ //alert(doc.documentElement.innerHTML);
+ //debug(doc);
+ //debug(doc.documentElement.innerHTML);
+ return doc;
+}
+
+// 从相对路径的a.href获取完全的href值.
+function getFullHref(href) {
+ if (typeof href != 'string') href = href.getAttribute('href');
+ //alert(href);
+ //if(href.search(/^https?:/)==0)return href;//http打头,不一定就是完整的href;
+ var a = getFullHref.a;
+ if (!a) {
+ getFullHref.a = a = document.createElement('a');
+ }
+ a.href = href;
+ //alert(a.href);
+ return a.href;
+}
+
+
+function toRE(obj) {
+ if (obj instanceof RegExp) {
+ return obj;
+ } else if (obj instanceof Array) {
+ return new RegExp(obj[0], obj[1]);
+ } else {
+ if (obj.search(/^wildc;/i) === 0) {
+ obj = wildcardToRegExpStr(obj.slice(6));
+ }
+ return new RegExp(obj);
+ }
+}
+
+function wildcardToRegExpStr(urlstr) {
+ if (urlstr.source) return urlstr.source;
+ var reg = urlstr.replace(/[()\[\]{}|+.,^$?\\]/g, "\\$&").replace(/\*+/g, function(str){
+ return str === "*" ? ".*" : "[^/]*";
+ });
+ return "^" + reg + "$";
+}
+
+
+/* jshint ignore:start */
+
+//动画库
+var Tween = {
+ Linear: function(t, b, c, d) {
+ return c * t / d + b;
+ },
+ Quad: {
+ easeIn: function(t, b, c, d) {
+ return c * (t /= d) * t + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return -c * (t /= d) * (t - 2) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if ((t /= d / 2) < 1) return c / 2 * t * t + b;
+ return -c / 2 * ((--t) * (t - 2) - 1) + b;
+ }
+ },
+ Cubic: {
+ easeIn: function(t, b, c, d) {
+ return c * (t /= d) * t * t + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return c * ((t = t / d - 1) * t * t + 1) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if ((t /= d / 2) < 1) return c / 2 * t * t * t + b;
+ return c / 2 * ((t -= 2) * t * t + 2) + b;
+ }
+ },
+ Quart: {
+ easeIn: function(t, b, c, d) {
+ return c * (t /= d) * t * t * t + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return -c * ((t = t / d - 1) * t * t * t - 1) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if ((t /= d / 2) < 1) return c / 2 * t * t * t * t + b;
+ return -c / 2 * ((t -= 2) * t * t * t - 2) + b;
+ }
+ },
+ Quint: {
+ easeIn: function(t, b, c, d) {
+ return c * (t /= d) * t * t * t * t + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return c * ((t = t / d - 1) * t * t * t * t + 1) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if ((t /= d / 2) < 1) return c / 2 * t * t * t * t * t + b;
+ return c / 2 * ((t -= 2) * t * t * t * t + 2) + b;
+ }
+ },
+ Sine: {
+ easeIn: function(t, b, c, d) {
+ return -c * Math.cos(t / d * (Math.PI / 2)) + c + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return c * Math.sin(t / d * (Math.PI / 2)) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ return -c / 2 * (Math.cos(Math.PI * t / d) - 1) + b;
+ }
+ },
+ Expo: {
+ easeIn: function(t, b, c, d) {
+ return (t == 0) ? b : c * Math.pow(2, 10 * (t / d - 1)) + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return (t == d) ? b + c : c * (-Math.pow(2, -10 * t / d) + 1) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if (t == 0) return b;
+ if (t == d) return b + c;
+ if ((t /= d / 2) < 1) return c / 2 * Math.pow(2, 10 * (t - 1)) + b;
+ return c / 2 * (-Math.pow(2, -10 * --t) + 2) + b;
+ }
+ },
+ Circ: {
+ easeIn: function(t, b, c, d) {
+ return -c * (Math.sqrt(1 - (t /= d) * t) - 1) + b;
+ },
+ easeOut: function(t, b, c, d) {
+ return c * Math.sqrt(1 - (t = t / d - 1) * t) + b;
+ },
+ easeInOut: function(t, b, c, d) {
+ if ((t /= d / 2) < 1) return -c / 2 * (Math.sqrt(1 - t * t) - 1) + b;
+ return c / 2 * (Math.sqrt(1 - (t -= 2) * t) + 1) + b;
+ }
+ },
+ Elastic: {
+ easeIn: function(t, b, c, d, a, p) {
+ if (t == 0) return b;
+ if ((t /= d) == 1) return b + c;
+ if (!p) p = d * .3;
+ if (!a || a < Math.abs(c)) {
+ a = c;
+ var s = p / 4;
+ } else var s = p / (2 * Math.PI) * Math.asin(c / a);
+ return -(a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
+ },
+ easeOut: function(t, b, c, d, a, p) {
+ if (t == 0) return b;
+ if ((t /= d) == 1) return b + c;
+ if (!p) p = d * .3;
+ if (!a || a < Math.abs(c)) {
+ a = c;
+ var s = p / 4;
+ } else var s = p / (2 * Math.PI) * Math.asin(c / a);
+ return (a * Math.pow(2, -10 * t) * Math.sin((t * d - s) * (2 * Math.PI) / p) + c + b);
+ },
+ easeInOut: function(t, b, c, d, a, p) {
+ if (t == 0) return b;
+ if ((t /= d / 2) == 2) return b + c;
+ if (!p) p = d * (.3 * 1.5);
+ if (!a || a < Math.abs(c)) {
+ a = c;
+ var s = p / 4;
+ } else var s = p / (2 * Math.PI) * Math.asin(c / a);
+ if (t < 1) return -.5 * (a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
+ return a * Math.pow(2, -10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p) * .5 + c + b;
+ }
+ },
+ Back: {
+ easeIn: function(t, b, c, d, s) {
+ if (s == undefined) s = 1.70158;
+ return c * (t /= d) * t * ((s + 1) * t - s) + b;
+ },
+ easeOut: function(t, b, c, d, s) {
+ if (s == undefined) s = 1.70158;
+ return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b;
+ },
+ easeInOut: function(t, b, c, d, s) {
+ if (s == undefined) s = 1.70158;
+ if ((t /= d / 2) < 1) return c / 2 * (t * t * (((s *= (1.525)) + 1) * t - s)) + b;
+ return c / 2 * ((t -= 2) * t * (((s *= (1.525)) + 1) * t + s) + 2) + b;
+ }
+ },
+ Bounce: {
+ easeIn: function(t, b, c, d) {
+ return c - Tween.Bounce.easeOut(d - t, 0, c, d) + b;
+ },
+ easeOut: function(t, b, c, d) {
+ if ((t /= d) < (1 / 2.75)) {
+ return c * (7.5625 * t * t) + b;
+ } else if (t < (2 / 2.75)) {
+ return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;
+ } else if (t < (2.5 / 2.75)) {
+ return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;
+ } else {
+ return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;
+ }
+ },
+ easeInOut: function(t, b, c, d) {
+ if (t < d / 2) return Tween.Bounce.easeIn(t * 2, 0, c, d) * .5 + b;
+ else return Tween.Bounce.easeOut(t * 2 - d, 0, c, d) * .5 + c * .5 + b;
+ }
+ }
+};
+
+var TweenM = [
+ 'Linear',
+ 'Quad',
+ 'Cubic',
+ 'Quart',
+ 'Quint',
+ 'Sine',
+ 'Expo',
+ 'Circ',
+ 'Elastic',
+ 'Back',
+ 'Bounce',
+];
+
+var TweenEase = [
+ 'easeIn',
+ 'easeOut',
+ 'easeInOut',
+];
+
+
+// 任何转成字符串,存储,修改过
+function xToString(x) {
+ function toStr(x) {
+ switch (typeof x) {
+ case 'undefined':
+ return Str(x);
+ case 'boolean':
+ return Str(x);
+ case 'number':
+ return Str(x);
+ case 'string':
+ return ('"' +
+ (x.replace(/(?:\r\n|\n|\r|\t|\\|")/g, function(a) {
+ var ret;
+ switch (a) { //转成字面量
+ case '\r\n':
+ ret = '\\r\\n';
+ break;
+ case '\n':
+ ret = '\\n';
+ break;
+ case '\r':
+ ret = '\\r';
+ break;
+ case '\t':
+ ret = '\\t';
+ break;
+ case '\\':
+ ret = '\\\\';
+ break;
+ case '"':
+ ret = '\\"';
+ break;
+ default:
+ break;
+ }
+ return ret;
+ })) + '"');
+ case 'function':
+ var fnStr = Str(x);
+ return fnStr.indexOf('native code') == -1 ? fnStr : 'function(){}';
+ case 'object':
+ //注,object的除了单纯{},其他的对象的属性会造成丢失..
+ if (x === null) {
+ return Str(x);
+ }
+ switch (x.constructor.name) {
+ case "Object":
+ var i;
+ var rStr = '';
+ for (i in x) {
+ if (!x.hasOwnProperty(i)) { //去掉原型链上的属性.
+ continue;
+ }
+ rStr += toStr(i) + ':' + toStr(x[i]) + ',';
+ }
+ return ('{' + rStr.replace(/,$/i, '') + '}');
+ case "Array":
+ var i;
+ var rStr = '';
+ for (i in x) {
+ if (!x.hasOwnProperty(i)) { //去掉原型链上的属性.
+ continue;
+ }
+ rStr += toStr(x[i]) + ',';
+ }
+ return '[' + rStr.replace(/,$/i, '') + ']';
+ case "String":
+ return toStr(Str(x));
+ case "RegExp":
+ return Str(x);
+ case "Number":
+ return Str(x);
+ case "Boolean":
+ return Str(x);
+ default:
+ //alert(x.constructor);//漏了什么类型么?
+ break;
+ }
+ default:
+ break;
+ }
+ }
+ var Str = String;
+ return toStr(x);
+}
+
+/* jshint ignore:end */
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/main.js b/Super_preloaderPlus/src/main.js
index 855849d9..fe4f950f 100644
--- a/Super_preloaderPlus/src/main.js
+++ b/Super_preloaderPlus/src/main.js
@@ -1,7 +1,4 @@
-// main.js
-
-//------------------------下面的不要管他-----------------
-///////////////////////////////////////////////////////////////////
+//------------------------ 运行部分 -----------------
var xbug = prefs.debug || GM_getValue("debug") || false;
var C = console;
@@ -65,7 +62,7 @@ var SP = {
// alert('自定义站点规则错误');
}
- if (_.isArray(infos)) {
+ if (Array.isArray(infos)) {
SITEINFO = infos.concat(SITEINFO);
}
};
@@ -76,3019 +73,317 @@ var SP = {
},
};
-var setup = function(){
- var d = document;
- var on = function(node, e, f) {
- node.addEventListener(e, f, false);
- };
-
- var $ = function(s) { return d.getElementById('sp-prefs-'+s); };
- if($('setup')) return;
-
- var styleNode = GM_addStyle('\
- #sp-prefs-setup { position:fixed;z-index:2147483647;top:30px;right:60px;padding:20px 30px;background:#eee;width:500px;border:1px solid black; }\
- #sp-prefs-setup * { color:black;text-align:left;line-height:normal;font-size:12px; }\
- #sp-prefs-setup a { color:black;text-decoration:underline; }\
- #sp-prefs-setup div { text-align:center;font-weight:bold;font-size:14px; }\
- #sp-prefs-setup ul { margin:15px 0 15px 0;padding:0;list-style:none;background:#eee;border:0; }\
- #sp-prefs-setup input, #sp-prefs-setup select { border:1px solid gray;padding:2px;background:white; }\
- #sp-prefs-setup li { margin:0;padding:6px 0;vertical-align:middle;background:#eee;border:0 }\
- #sp-prefs-setup button { width:150px;margin:0 10px;text-align:center; }\
- #sp-prefs-setup textarea { width:98%; height:60px; margin:3px 0; }\
- #sp-prefs-setup b { font-weight: bold; font-family: "微软雅黑", sans-serif; }\
- ');
-
- var div = d.createElement('div');
- div.id = 'sp-prefs-setup';
- d.body.appendChild(div);
- div.innerHTML = '\
- Super_preloaderPlus_one 设置
\
- \
- ';
- div = null;
-
- var close = function() {
- if (styleNode) {
- styleNode.parentNode.removeChild(styleNode);
- }
- var div = $('setup');
- div.parentNode.removeChild(div);
- };
-
- on($('ok'), 'click', function(){
- GM_setValue('enableHistory', prefs.enableHistory = !!$('enableHistory').checked);
- GM_setValue('SITEINFO_D.useiframe', SITEINFO_D.useiframe = !!$('SITEINFO_D-useiframe').checked);
- GM_setValue('SITEINFO_D.autopager.enable', SITEINFO_D.autopager.enable = !!$('SITEINFO_D-a_enable').checked);
- GM_setValue('SITEINFO_D.autopager.force_enable', SITEINFO_D.autopager.force_enable = !!$('SITEINFO_D-a_force_enable').checked);
-
- GM_setValue('debug', xbug = !!$('debug').checked);
- debug = xbug ? console.log.bind(console) : function() {};
-
- GM_setValue('dblclick_pause', $('dblclick_pause').checked);
- GM_setValue('excludes', prefs.excludes = $('excludes').value);
- GM_setValue('custom_siteinfo', prefs.custom_siteinfo = $('custom_siteinfo').value);
-
- SP.loadSetting();
-
- close();
- });
-
- on($('cancel'), 'click', close);
-
- $('checkUpdate').onclick = checkUpdate;
- $('debug').checked = xbug;
- $('enableHistory').checked = prefs.enableHistory;
- $('dblclick_pause').checked = GM_getValue('dblclick_pause') || false;
- $('SITEINFO_D-useiframe').checked = SITEINFO_D.useiframe;
- $('SITEINFO_D-a_enable').checked = SITEINFO_D.autopager.enable;
- $('SITEINFO_D-a_force_enable').checked = SITEINFO_D.autopager.force_enable;
- $('excludes').value = prefs.excludes;
- $('custom_siteinfo').value = prefs.custom_siteinfo;
-
- // 打开设置自动检查更新
- checkUpdate();
-};
-
-var isUpdating = true;
-function checkUpdate() {
- if (isUpdating) {
- return;
- }
-
- GM_xmlhttpRequest({
- method: "GET",
- url: scriptInfo.metaUrl,
- onload: function(response) {
- var txt = response.responseText;
- var curVersion = scriptInfo.version;
- var latestVersion = txt.match(/@\s*version\s*([\d\.]+)\s*/i);
- if (latestVersion) {
- latestVersion = latestVersion[1];
- } else {
- alert('解析版本号错误');
- return;
- }
-
- //对比版本号
- var needUpdate;
- var latestVersion = latestVersion.split('.');
- var lVLength = latestVersion.length;
- var currentVersion = curVersion.split('.');
- var cVLength = currentVersion.length;
- var lV_x;
- var cV_x;
- for (var i = 0; i < lVLength; i++) {
- lV_x = Number(latestVersion[i]);
- cV_x = (i >= cVLength) ? 0 : Number(currentVersion[i]);
- if (lV_x > cV_x) {
- needUpdate = true;
- break;
- } else if (lV_x < cV_x) {
- break;
- }
- }
-
- if (needUpdate) {
- alert('本脚本从版本 ' + scriptInfo.version + ' 更新到了版本 ' + latestVersion + '.\n请点击脚本主页进行安装');
- document.getElementById("sp-prefs-homepageURL").boxShadow = '0 0 2px 2px #FF5555';
- }
-
- isUpdating = false;
- }
- });
-}
-
function init(window, document) {
var startTime = new Date();
- var nullFn = function() {}; //空函数.
+ var nullFn = function() {}; // 空函数.
var url = document.location.href.replace(/#.*$/, ''); //url 去掉hash
- var cplink = url; // 翻上来的最近的页面的url;
- var domain = document.domain; //取得域名.
- var domain_port = url.match(/https?:\/\/([^\/]+)/)[1]; //端口和域名,用来验证是否跨域.
- // 新加的,以示区别
- var remove = []; // 需要移除的事件
debug('----------------------------------------------------');
- //悬浮窗
- var floatWO = {
- updateColor: nullFn,
- loadedIcon: nullFn,
- CmodeIcon: nullFn,
- };
+ var hashchangeAdded = false;
- function floatWindow() {
- GM_addStyle('\
- #sp-fw-container {\
- z-index:999999!important;\
- text-align:left!important;\
- }\
- #sp-fw-container * {\
- font-size:13px!important;\
- color:black!important;\
- float:none!important;\
- }\
- #sp-fw-main-head{\
- position:relative!important;\
- top:0!important;\
- left:0!important;\
- }\
- #sp-fw-span-info{\
- position:absolute!important;\
- right:1px!important;\
- top:0!important;\
- font-size:10px!important;\
- line-height:10px!important;\
- background:none!important;\
- font-style:italic!important;\
- color:#5a5a5a!important;\
- text-shadow:white 0px 1px 1px!important;\
- }\
- #sp-fw-container input {\
- vertical-align:middle!important;\
- display:inline-block!important;\
- outline:none!important;\
- height: auto !important;\
- padding: 0px !important;\
- margin-bottom: 0px !important;\
- }\
- #sp-fw-container input[type="number"] {\
- width:50px!important;\
- text-align:left!important;\
- }\
- #sp-fw-container input[type="checkbox"] {\
- border:1px solid #B4B4B4!important;\
- padding:1px!important;\
- margin:3px!important;\
- width:13px!important;\
- height:13px!important;\
- background:none!important;\
- cursor:pointer!important;\
- }\
- #sp-fw-container input[type="button"] {\
- border:1px solid #ccc!important;\
- cursor:pointer!important;\
- background:none!important;\
- width:auto!important;\
- height:auto!important;\
- }\
- #sp-fw-container li {\
- list-style:none!important;\
- margin:3px 0!important;\
- border:none!important;\
- float:none!important;\
- }\
- #sp-fw-container fieldset {\
- border:2px groove #ccc!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- padding:4px 9px 6px 9px!important;\
- margin:2px!important;\
- display:block!important;\
- width:auto!important;\
- height:auto!important;\
- }\
- #sp-fw-container legend {\
- line-height: 20px !important;\
- margin-bottom: 0px !important;\
- }\
- #sp-fw-container fieldset>ul {\
- padding:0!important;\
- margin:0!important;\
- }\
- #sp-fw-container ul#sp-fw-a_useiframe-extend{\
- padding-left:40px!important;\
- }\
- #sp-fw-rect {\
- position:relative!important;\
- top:0!important;\
- left:0!important;\
- float:right!important;\
- height:10px!important;\
- width:10px!important;\
- padding:0!important;\
- margin:0!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- border:1px solid white!important;\
- -webkit-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
- -moz-box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
- box-shadow:inset 0 5px 0 rgba(255,255,255,0.3), 0 0 3px rgba(0,0,0,0.8)!important;\
- opacity:0.8!important;\
- }\
- #sp-fw-dot,\
- #sp-fw-cur-mode {\
- position:absolute!important;\
- z-index:9999!important;\
- width:5px!important;\
- height:5px!important;\
- padding:0!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- border:1px solid white!important;\
- opacity:1!important;\
- -webkit-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
- -moz-box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
- box-shadow:inset 0 -2px 1px rgba(0,0,0,0.3),inset 0 2px 1px rgba(255,255,255,0.3), 0px 1px 2px rgba(0,0,0,0.9)!important;\
- }\
- #sp-fw-dot{\
- right:-3px!important;\
- top:-3px!important;\
- }\
- #sp-fw-cur-mode{\
- left:-3px!important;\
- top:-3px!important;\
- width:6px!important;\
- height:6px!important;\
- }\
- #sp-fw-content{\
- padding:0!important;\
- margin:5px 5px 0 0!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- border:1px solid #A0A0A0!important;\
- -webkit-box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
- -moz-box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
- box-shadow:-2px 2px 5px rgba(0,0,0,0.3)!important;\
- }\
- #sp-fw-main {\
- padding:5px!important;\
- border:1px solid white!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- background-color:#F2F2F7!important;\
- background: -moz-linear-gradient(top, #FCFCFC, #F2F2F7 100%)!important;\
- background: -webkit-gradient(linear, 0 0, 0 100%, from(#FCFCFC), to(#F2F2F7))!important;\
- }\
- #sp-fw-foot{\
- position:relative!important;\
- left:0!important;\
- right:0!important;\
- min-height:20px!important;\
- }\
- #sp-fw-savebutton{\
- position:absolute!important;\
- top:0!important;\
- right:2px!important;\
- }\
- #sp-fw-container .sp-fw-spanbutton{\
- border:1px solid #ccc!important;\
- -moz-border-radius:3px!important;\
- border-radius:3px!important;\
- padding:2px 3px!important;\
- cursor:pointer!important;\
- background-color:#F9F9F9!important;\
- -webkit-box-shadow:inset 0 10px 5px white!important;\
- -moz-box-shadow:inset 0 10px 5px white!important;\
- box-shadow:inset 0 10px 5px white!important;\
- }\
- ');
- var div = document.createElement('div');
- div.id = 'sp-fw-container';
- div.innerHTML = '\
- \
- \
-
\
-
\
- 使用翻页模式\
- Super_preloader\
-
\
-
\
- \
- \
-
\
-
\
- ';
- document.body.appendChild(div);
+ //执行开始..///////////////////
- function $(id) {
- return document.getElementById(id);
- }
+ // 分析黑名单
+ var blackList_all = blackList.concat(prefs.excludes.split(/[\n\r]+/).map(function(line) {
+ return line.trim();
+ }));
- var rect = $('sp-fw-rect'); //悬浮窗的小正方形,用颜色描述当前的状态.
- var spanel = $('sp-fw-content'); //设置面板.
+ var blackList_re = new RegExp(blackList_all.map(wildcardToRegExpStr).join("|"));
+ if(blackList_re.test(url)){
+ debug('匹配黑名单,js执行终止');
+ return;
+ }
- var spanelc = {
- show: function() {
- spanel.style.display = 'block';
- },
- hide: function() {
- spanel.style.display = 'none';
- },
- };
- var rectt1, rectt2;
- //设置面板显隐
- rect.addEventListener('mouseover', function(e) {
- rectt1 = setTimeout(spanelc.show, 100);
- }, false);
- rect.addEventListener('mouseout', function(e) {
- clearTimeout(rectt1);
- }, false);
+ //是否在frame上加载..
+ if (prefs.DisableI && window.self != window.parent) {
+ var isReturn = !_.find(DIExclude, function(x){ return x[1] && x[2].test(url); });
+ if (isReturn) {
+ debug('url为:', url, '的页面为非顶层窗口,JS执行终止.');
+ return;
+ }
+ }
+ debug('url为:', url, 'JS加载成功');
- div.addEventListener('mouseover', function(e) {
- clearTimeout(rectt2);
- }, false);
+ //第一阶段..分析高级模式..
+ SITEINFO = SITEINFO.concat(SITEINFO_TP, SITEINFO_comp);
- div.addEventListener('mouseout', function(e) {
- if (e.relatedTarget && e.relatedTarget.disabled) return; //for firefox and chrome
- rectt2 = setTimeout(spanelc.hide, 288);
- }, false);
+ //重要的变量两枚.
+ var nextlink;
+ var prelink;
+ //===============
+
+ var SSS = {};
- var dot = $('sp-fw-dot'); //载入完成后,显示的小点
- dot.style.backgroundColor = FWKG_color.dot;
+ var findCurSiteInfo = function() {
+ var SII;
+ var SIIA;
+ var SIIAD = SITEINFO_D.autopager;
+ var Rurl;
+ var ii = SITEINFO.length;
- var cur_mode = $('sp-fw-cur-mode'); //当载入状态时,用来描述当前是翻页模式,还是预读模式.
- cur_mode.style.backgroundColor = SSS.a_enable ? FWKG_color.autopager : FWKG_color.prefetcher;
+ debug('高级规则数量:', ii);
- var a_enable = $('sp-fw-a_enable'); //启用翻页模式
- var autopager_field = $('sp-fw-autopager-field'); //翻页设置区域
+ for (i = 0; i < ii; i++) {
+ SII = SITEINFO[i];
+ Rurl = toRE(SII.url);
+ if (Rurl.test(url)) {
+ debug('找到匹配当前站点的规则:', SII, '是第', i + 1, '规则');
- //预读设置
- var useiframe = $('sp-fw-useiframe');
- var viewcontent = $('sp-fw-viewcontent');
+ // 运行规则的 startFilter
+ if (SII.autopager && SII.autopager.startFilter) {
+ SII.autopager.startFilter(window, document);
+ debug('成功运行 startFilter');
+ }
- //翻页设置
- var a_useiframe = $('sp-fw-a_useiframe');
- var a_iloaded = $('sp-fw-a_iloaded');
- var a_itimeout = $('sp-fw-a_itimeout');
- var a_manualA = $('sp-fw-a_manualA');
- var a_remain = $('sp-fw-a_remain');
- var a_maxpage = $('sp-fw-a_maxpage');
- var a_separator = $('sp-fw-a_separator');
- var a_ipages_0 = $('sp-fw-a_ipages_0');
- var a_ipages_1 = $('sp-fw-a_ipages_1');
- var a_force = $('sp-fw-a_force');
+ nextlink = getElement(SII.nextLink || 'auto;');
+ if (!nextlink) {
+ debug('无法找到下一页链接,跳过规则:', SII, '继续查找其他规则');
+ continue;
+ }
- // newIframe 输入框的点击
- var a_newIframe = $('sp-fw-a_newIframe');
- a_newIframe.addEventListener('click', function(){
- a_useiframe.checked = a_newIframe.checked;
- }, false);
+ if (SII.preLink && SII.preLink != 'auto;') { //如果设定了具体的preLink
+ prelink = getElement(SII.preLink);
+ } else {
+ if(prefs.autoGetPreLink){
+ getElement('auto;');
+ }
+ }
- var a_starti = $('sp-fw-a_starti'); //开始立即翻页
- a_starti.addEventListener('click', function() {
- if (this.disabled) return;
- var value = Number(a_ipages_1.value);
- if (isNaN(value) || value <= 0) {
- value = SSS.a_ipages[1];
- a_ipages_1.value = value;
- }
- autoPO.startipages(value);
- }, false);
+ // alert(prelink);
+ SSS.hasRule = true;
+ SSS.Rurl = String(Rurl);
+ // alert(SSS.Rurl);
+ SSS.nextLink = SII.nextLink || 'auto;';
+ SSS.viewcontent = SII.viewcontent;
+ SSS.enable = (SII.enable === undefined) ? SITEINFO_D.enable : SII.enable;
+ SSS.useiframe = (SII.useiframe === undefined) ? SITEINFO_D.useiframe : SII.useiframe;
+ if (SII.pageElement) { //如果是Oautopager的规则..
+ if (!(SII.autopager instanceof Object)) SII.autopager = {};
+ SII.autopager.pageElement = SII.pageElement;
+ if (SII.insertBefore) SII.autopager.HT_insert = [SII.insertBefore, 1];
+ }
+
+ //自动翻页设置.
+ SIIA = SII.autopager;
+ if (SIIA) {
+ SSS.a_pageElement = SIIA.pageElement;
+ if (!SSS.a_pageElement) break;
+ SSS.a_manualA = (SIIA.manualA === undefined) ? SIIAD.manualA : SIIA.manualA;
+ SSS.a_enable = (SIIA.enable === undefined) ? SIIAD.enable : SIIA.enable;
+ SSS.a_useiframe = (SIIA.useiframe === undefined) ? SIIAD.useiframe : SIIA.useiframe;
+ SSS.a_newIframe = (SIIA.newIframe === undefined) ? SIIAD.newIframe : SIIA.newIframe;
+ SSS.a_iloaded = (SIIA.iloaded === undefined) ? SIIAD.iloaded : SIIA.iloaded;
+ SSS.a_itimeout = (SIIA.itimeout === undefined) ? SIIAD.itimeout : SIIA.itimeout;
+ //alert(SSS.a_itimeout);
+ SSS.a_remain = (SIIA.remain === undefined) ? SIIAD.remain : SIIA.remain;
+ SSS.a_maxpage = (SIIA.maxpage === undefined) ? SIIAD.maxpage : SIIA.maxpage;
+ SSS.a_separator = (SIIA.separator === undefined) ? SIIAD.separator : SIIA.separator;
+ SSS.a_separatorReal = (SIIA.separatorReal === undefined) ? SIIAD.separatorReal : SIIA.separatorReal;
+ SSS.a_replaceE = SIIA.replaceE;
+ SSS.a_HT_insert = SIIA.HT_insert;
+ SSS.a_relatedObj = SIIA.relatedObj;
+ SSS.a_ipages = (SIIA.ipages === undefined) ? SIIAD.ipages : SIIA.ipages;
- //总开关
- var enable = $('sp-fw-enable');
- $('sp-fw-setup').addEventListener('click', setup, false);
+ // new
+ SSS.filter = SII.filter || SIIA.filter; // 新增了函数的形式,原来的功能是移除 pageElement
+ SSS.a_documentFilter = SII.documentFilter || SIIA.documentFilter;
+ SSS.a_stylish = SII.stylish || SIIA.stylish;
+ SSS.lazyImgSrc = SIIA.lazyImgSrc;
+ }
- // 保存设置按钮.
- var savebutton = $('sp-fw-savebutton');
- savebutton.addEventListener('click', function(e) {
- var value = {
- Rurl: SSS.Rurl,
- useiframe: gl(useiframe),
- viewcontent: gl(viewcontent),
- enable: gl(enable),
- };
+ // 检验是否存在内容
+ var pageElement = getElement(SSS.a_pageElement);
+ if (!pageElement) {
+ debug('无法找到内容,跳过规则:', SII, '继续查找其他规则');
+ continue;
+ }
- function gl(obj) {
- return (obj.type == 'checkbox' ? obj.checked : obj.value);
- }
- if (SSS.a_enable !== undefined) {
- value.a_enable = gl(a_enable);
- value.a_useiframe = gl(a_useiframe);
- value.a_newIframe = gl(a_newIframe);
- value.a_iloaded = gl(a_iloaded);
- value.a_manualA = gl(a_manualA);
- value.a_force = gl(a_force);
- var t_a_itimeout = Number(gl(a_itimeout));
- value.a_itimeout = isNaN(t_a_itimeout) ? SSS.a_itimeout : (t_a_itimeout >= 0 ? t_a_itimeout : 0);
- var t_a_remain = Number(gl(a_remain));
- value.a_remain = isNaN(t_a_remain) ? SSS.a_remain : Number(t_a_remain.toFixed(2));
- var t_a_maxpage = Number(gl(a_maxpage));
- value.a_maxpage = isNaN(t_a_maxpage) ? SSS.a_maxpage : (t_a_maxpage >= 1 ? t_a_maxpage : 1);
- var t_a_ipages_1 = Number(gl(a_ipages_1));
- value.a_ipages = [gl(a_ipages_0), (isNaN(t_a_ipages_1) ? SSS.a_ipages[1] : (t_a_ipages_1 >= 1 ? t_a_ipages_1 : 1))];
- value.a_separator = gl(a_separator);
- }
- //alert(xToString(value));
- SSS.savedValue[SSS.sedValueIndex] = value;
- //alert(xToString(SSS.savedValue));
- saveValue('spfwset', xToString(SSS.savedValue));
- if ((e.shiftKey ? !prefs.FW_RAS : prefs.FW_RAS)) { //按住shift键,执行反向操作.
- setTimeout(function(){
- location.reload();
- }, 1);
+ break;
}
- }, false);
+ }
- function ll(obj, value) {
- if (obj.type == 'checkbox') {
- obj.checked = value;
+ if (!SSS.hasRule) {
+ debug('未找到合适的高级规则,开始自动匹配.');
+ //自动搜索.
+ if (!autoMatch.keyMatch) {
+ debug('自动匹配功能被禁用了.');
} else {
- obj.value = value;
+ nextlink = autoGetLink();
+ //alert(nextlink);
+ if (nextlink) { //强制模式.
+ var FA = autoMatch.FA;
+ SSS.Rurl = window.localStorage ? ('am:' + (url.match(/^https?:\/\/[^:]*\//i) || [])[0]) : 'am:automatch';
+ //alert(SSS.Rurl);
+ SSS.enable = true;
+ SSS.nextLink = 'auto;';
+ SSS.viewcontent = autoMatch.viewcontent;
+ SSS.useiframe = autoMatch.useiframe;
+ SSS.a_force = true;
+ SSS.a_manualA = FA.manualA;
+ // SSS.a_enable = FA.enable || false; //不能使a_enable的值==undefined...
+ SSS.a_enable = FA.enable || SITEINFO_D.autopager.force_enable; //不能使a_enable的值==undefined...
+ SSS.a_useiframe = FA.useiframe;
+ SSS.a_iloaded = FA.iloaded;
+ SSS.a_itimeout = FA.itimeout;
+ SSS.a_remain = FA.remain;
+ SSS.a_maxpage = FA.maxpage;
+ SSS.a_separator = FA.separator;
+ SSS.a_ipages = FA.ipages;
+ }
}
}
- //载入翻页设置.
- if (SSS.a_enable === undefined) { //未定义翻页功能.
- a_enable.disabled = true;
- autopager_field.style.display = 'none';
- } else {
- ll(a_enable, SSS.a_enable);
- ll(a_useiframe, SSS.a_useiframe);
- ll(a_newIframe, SSS.a_newIframe);
- ll(a_iloaded, SSS.a_iloaded);
- ll(a_itimeout, SSS.a_itimeout);
- ll(a_manualA, SSS.a_manualA);
- ll(a_force, SSS.a_force);
- ll(a_remain, SSS.a_remain);
- ll(a_maxpage, SSS.a_maxpage);
- ll(a_separator, SSS.a_separator);
- ll(a_ipages_0, SSS.a_ipages[0]);
- ll(a_ipages_1, SSS.a_ipages[1]);
- }
-
- if (!SSS.a_enable) { //当前不是翻页模式,禁用立即翻页按钮.
- a_starti.disabled = true;
- }
-
- if (!SSS.hasRule) { //如果没有高级规则,那么此项不允许操作.
- a_force.disabled = true;
+ // 如果规则没 lazyImgSrc,设置默认值
+ if (!SSS.lazyImgSrc) {
+ SSS.lazyImgSrc = prefs.lazyImgSrc;
}
- //载入预读设置.
- ll(useiframe, SSS.useiframe);
- ll(viewcontent, SSS.viewcontent);
-
- //总开关
- ll(enable, SSS.enable);
-
- var FWKG_state = {
- loading: '读取中状态',
- prefetcher: '预读状态',
- autopager: '翻页状态',
- Apause: '翻页状态(暂停)',
- Astop: '翻页状态(停止)(翻页完成,或者被异常停止)(无法再开启)',
- dot: '读取完后',
- };
-
- floatWO = {
- updateColor: function(state) {
- rect.style.backgroundColor = FWKG_color[state];
- rect.setAttribute("title", FWKG_state[state]);
- },
- loadedIcon: function(command) {
- dot.style.display = command == 'show' ? 'block' : 'none';
- },
- CmodeIcon: function(command) {
- cur_mode.style.display = command == 'show' ? 'block' : 'none';
- },
- };
-
-
- var vertical = parseInt(prefs.FW_offset[0], 10);
- var horiz = parseInt(prefs.FW_offset[1], 10);
- var FW_position = prefs.FW_position;
+ debug('搜索高级规则和自动匹配过程总耗时:', new Date() - startTime, '毫秒');
+ };
- // 非opera用fixed定位.
- div.style.position = 'fixed';
- switch (FW_position) {
- case 1:
- div.style.top = vertical + 'px';
- div.style.left = horiz + 'px';
- break;
- case 2:
- div.style.top = vertical + 'px';
- div.style.right = horiz + 'px';
- break;
- case 3:
- div.style.bottom = vertical + 'px';
- div.style.right = horiz + 'px';
- break;
- case 4:
- div.style.bottom = vertical + 'px';
- div.style.left = horiz + 'px';
- break;
- default:
- break;
- }
+ findCurSiteInfo();
+
+ //上下页都没有找到啊
+ if (!nextlink && !prelink) {
+ debug('未找到相关链接, JS执行停止. 共耗时' + (new Date() - startTime) + '毫秒');
+ return;
+ } else {
+ debug('上一页链接:', prelink);
+ debug('下一页链接:', nextlink);
+ nextlink = nextlink ? (nextlink.href || nextlink) : undefined;
+ prelink = prelink ? (prelink.href || prelink) : undefined;
}
- function sp_transition(start, end) {
- var TweenF = sp_transition.TweenF;
- if (!TweenF) {
- TweenF = Tween[TweenM[prefs.s_method]];
- TweenF = TweenF[TweenEase[prefs.s_ease]] || TweenF;
- sp_transition.TweenF = TweenF;
- }
- var frameSpeed = 1000 / prefs.s_FPS;
- var t = 0; //次数,开始
- var b = start; //开始
- var c = end - start; //结束
- var d = Math.ceil(prefs.s_duration / frameSpeed); //次数,结束
-
- var x = window.scrollX;
+ var superPreloader = {
+ go: function() {
+ nextlink = autoPO && autoPO.nextlink || nextlink;
+ if (nextlink) window.location.href = nextlink;
+ },
+ back: function() {
+ prelink = autoPO && autoPO.prelink || prelink;
+ if(!prelink) getElement('auto;');
+ if (prelink) window.location.href = prelink;
+ },
+ };
- function transition() {
- var y = Math.ceil(TweenF(t, b, c, d));
- //alert(y);
- window.scroll(x, y);
- if (t < d) {
- t++;
- setTimeout(transition, frameSpeed);
+ if (prefs.arrowKeyPage) {
+ debug('添加键盘左右方向键翻页监听.');
+ document.addEventListener('keyup', function(e) {
+ var tarNN = e.target.nodeName;
+ if (tarNN != 'BODY' && tarNN != 'HTML') return;
+ switch (e.keyCode) {
+ case 37:
+ superPreloader.back();
+ break;
+ case 39:
+ superPreloader.go();
+ break;
+ default:
+ break;
}
- }
- transition();
+ }, false);
}
- function sepHandler(e) {
- e.stopPropagation();
- var div = this;
- //alert(div);
- var target = e.target;
- //alert(target);
-
- function getRelativeDiv(which) {
- var id = div.id;
- id = id.replace(/(sp-separator-)(.+)/, function(a, b, c) {
- return b + String((Number(c) + (which == 'pre' ? -1 : 1)));
- });
- //alert(id);
- return (id ? document.getElementById(id) : null);
- }
-
- function scrollIt(a, b) {
- //a=a!==undefined? a : window.scrollY;
- if (prefs.sepT) {
- sp_transition(a, b);
- } else {
- window.scroll(window.scrollX, b);
- }
- }
+ // 监听下一页事件.
+ debug('添加鼠标手势翻页监听.');
+ document.addEventListener('superPreloader.go', function() {
+ superPreloader.go();
+ }, false);
- var o_scrollY, divS;
-
- switch (target.className) {
- case 'sp-sp-gotop':
- scrollIt(window.scrollY, 0);
- break;
- case 'sp-sp-gopre':
- var prediv = getRelativeDiv('pre');
- if (!prediv) return;
- o_scrollY = window.scrollY;
- var preDS = prediv.getBoundingClientRect().top;
- if (prefs.sepP) {
- divS = div.getBoundingClientRect().top;
- preDS = o_scrollY - (divS - preDS);
- } else {
- preDS += o_scrollY - 6;
- }
- scrollIt(o_scrollY, preDS);
- break;
- case 'sp-sp-gonext':
- var nextdiv = getRelativeDiv('next');
- if (!nextdiv) return;
- o_scrollY = window.scrollY;
- var nextDS = nextdiv.getBoundingClientRect().top;
- if (prefs.sepP) {
- divS = div.getBoundingClientRect().top;
- nextDS = o_scrollY + (-divS + nextDS);
- } else {
- nextDS += o_scrollY - 6;
- }
- scrollIt(o_scrollY, nextDS);
- break;
- case 'sp-sp-gobottom':
- scrollIt(window.scrollY, Math.max(document.documentElement.scrollHeight, document.body.scrollHeight));
- break;
- default:
- break;
- }
- }
-
- //autopager
- var autoPO = {
- startipages: nullFn,
- };
- var hashchangeAdded = false;
-
- function autopager(SSS, floatWO) {
- //return;
- //更新悬浮窗的颜色.
- floatWO.updateColor('autopager');
-
- //获取插入位置节点.
- var insertPoint;
- var pageElement;
- var insertMode;
- if (SSS.a_HT_insert) {
- insertPoint = getElement(SSS.a_HT_insert[0]);
- insertMode = SSS.a_HT_insert[1];
- } else {
- pageElement = getAllElements(SSS.a_pageElement);
- if (pageElement.length > 0) {
- var pELast = pageElement[pageElement.length - 1];
- insertPoint = pELast.nextSibling ? pELast.nextSibling : pELast.parentNode.appendChild(document.createTextNode(' '));
- }
- }
-
- if (insertPoint) {
- debug('验证是否能找到插入位置节点:成功,', insertPoint);
- } else {
- C.error('验证是否能找到插入位置节点:失败', (SSS.a_HT_insert ? SSS.a_HT_insert[0] : ''), 'JS执行终止');
- floatWO.updateColor('Astop');
- return;
- }
-
- if (pageElement === undefined) {
- pageElement = getAllElements(SSS.a_pageElement);
- }
- if (pageElement.length > 0) {
- debug('验证是否能找到主要元素:成功,', pageElement);
- } else {
- C.error('验证是否能找到主要元素:失败,', SSS.a_pageElement, 'JS执行终止');
- floatWO.updateColor('Astop');
- return;
- }
-
- if (SSS.a_stylish) { // 插入自定义样式
- GM_addStyle(SSS.a_stylish, 'Super_preloader-style');
- }
-
- var insertPointP;
- if (insertMode != 2) {
- insertPointP = insertPoint.parentNode;
- }
-
- var addIntoDoc;
- if (insertMode == 2) {
- addIntoDoc = function(obj) {
- return insertPoint.appendChild(obj);
- };
- } else {
- addIntoDoc = function(obj) {
- return insertPointP.insertBefore(obj, insertPoint);
- };
- }
-
- var doc, win;
-
- function XHRLoaded(req) {
- var str = req.responseText;
- doc = win = createDocumentByString(str);
-
- if (!doc) {
- C.error('文档对象创建失败');
- removeL();
- return;
- }
- floatWO.updateColor('autopager');
- floatWO.CmodeIcon('hide');
- floatWO.loadedIcon('show');
- working = false;
- scroll();
- }
-
- function removeL(isRemoveAddPage) {
- debug('移除各种事件监听');
- floatWO.updateColor('Astop');
- var _remove = remove;
- for (var i = 0, ii = _remove.length; i < ii; i++) {
- _remove[i]();
- }
-
- if (isRemoveAddPage) {
- var separator = document.querySelector('.sp-separator');
- if (separator) {
- var insertBefore = insertPoint;
- if (insertMode == 2) {
- var l = insertPoint.children.length;
- if (l > 0) {
- insertBefore = insertPoint.children[l - 1];
- }
- }
-
- var range = document.createRange();
- range.setStartBefore(separator);
- range.setEndBefore(insertBefore);
- range.deleteContents();
- range.detach();
-
- if (insertMode == 2) { // 还需要额外移除?
- insertPoint.removeChild(insertBefore);
- }
- }
- var style = document.getElementById("Super_preloader-style");
- if (style)
- style.parentNode.removeChild(style);
- }
- }
- if (isHashchangeSite && !hashchangeAdded) {
- window.addEventListener("hashchange", onhashChange, false);
- hashchangeAdded = true;
- debug('成功添加 hashchange 事件');
- }
-
- function onhashChange(event) {
- debug("触发 Hashchang 事件");
- removeL(true);
-
- setTimeout(function(){
- nextlink = getElement(SSS.nextLink || 'auto;');
- nextlink = getFullHref(nextlink);
- // preLink = getElement(SSS.preLink || 'auto;');
- autopager(SSS, floatWO);
- }, hashchangeTimer);
- }
-
- var iframe;
- var messageR;
-
- function iframeLoaded() {
- var iframe = this;
- //alert(this.contentDocument.body)
- var body = iframe.contentDocument.body;
- if (body && body.firstChild) {
- setTimeout(function() {
- doc = iframe.contentDocument;
- removeScripts(doc);
- win = iframe.contentWindow || doc;
- floatWO.updateColor('autopager');
- floatWO.CmodeIcon('hide');
- floatWO.loadedIcon('show');
- working = false;
-
- scroll();
- }, SSS.a_itimeout);
- }
- }
-
- function iframeRquest(link) {
- messageR = false;
- if (SSS.a_newIframe || !iframe) {
- var i = document.createElement('iframe');
- iframe = i;
- i.name = 'superpreloader-iframe';
- i.width = '100%';
- i.height = '0';
- i.frameBorder = "0";
- i.style.cssText = '\
- margin:0!important;\
- padding:0!important;\
- visibility:hidden!important;\
- ';
- i.src = link;
- if (SSS.a_iloaded) {
- i.addEventListener('load', iframeLoaded, false);
- remove.push(function() {
- i.removeEventListener('load', iframeLoaded, false);
- });
- } else {
- var messagehandler = function (e) {
- if (!messageR && e.data == 'superpreloader-iframe:DOMLoaded') {
- messageR = true;
- iframeLoaded.call(i);
- if (SSS.a_newIframe) {
- window.removeEventListener('message', messagehandler, false);
- }
- }
- };
- window.addEventListener('message', messagehandler, false);
- remove.push(function() {
- window.removeEventListener('message', messagehandler, false);
- });
- }
- document.body.appendChild(i);
- } else {
- iframe.src = link;
- iframe.contentDocument.location.replace(link);
- }
- }
-
- var working;
-
- function doRequest() {
- working = true;
- floatWO.updateColor('loading');
- floatWO.CmodeIcon('show');
-
- debug('获取下一页' + (SSS.a_useiframe ? '(iframe方式)': ''), nextlink);
- if (SSS.a_useiframe) {
- iframeRquest(nextlink);
- } else {
- GM_xmlhttpRequest({
- method: "GET",
- url: nextlink,
- overrideMimeType: 'text/html; charset=' + document.characterSet,
- onload: XHRLoaded
- });
- }
- }
-
- var ipagesmode = SSS.a_ipages[0];
- var ipagesnumber = SSS.a_ipages[1];
- var scrollDo = nullFn;
- var afterInsertDo = nullFn;
- if (prefs.Aplus) {
- afterInsertDo = doRequest;
- doRequest();
- } else {
- scrollDo = doRequest;
- if (ipagesmode) doRequest();
- }
-
- var manualDiv;
-
- function manualAdiv() {
- if (!manualDiv) {
- GM_addStyle('\
- #sp-sp-manualdiv{\
- line-height:1.6!important;\
- opacity:1!important;\
- position:relative!important;\
- float:none!important;\
- top:0!important;\
- left:0!important;\
- z-index: 1000!important;\
- min-width:366px!important;\
- width:auto!important;\
- text-align:center!important;\
- font-size:14px!important;\
- padding:3px 0!important;\
- margin:5px 10px 8px;\
- clear:both!important;\
- border-top:1px solid #ccc!important;\
- border-bottom:1px solid #ccc!important;\
- -moz-border-radius:30px!important;\
- border-radius:30px!important;\
- background-color:#F5F5F5!important;\
- -moz-box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
- -webkit-box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
- box-shadow:inset 0 10px 16px #fff,0 2px 3px rgba(0,0,0,0.1);\
- }\
- .sp-sp-md-span{\
- font-weight:bold!important;\
- margin:0 5px!important;\
- }\
- #sp-sp-md-number{\
- width:50px!important;\
- vertical-align:middle!important;\
- display:inline-block!important;\
- text-align:left!important;\
- }\
- #sp-sp-md-imgnext{\
- padding:0!important;\
- margin:0 0 0 5px!important;\
- vertical-align:middle!important;\
- display:inline-block!important;\
- }\
- #sp-sp-manualdiv:hover{\
- cursor:pointer;\
- }\
- #sp-sp-md-someinfo{\
- position:absolute!important;\
- right:16px!important;\
- bottom:1px!important;\
- font-size:10px!important;\
- text-shadow:white 0 1px 0!important;\
- color:#5A5A5A!important;\
- font-style:italic!important;\
- z-index:-1!important;\
- background:none!important;\
- }\
- ');
-
- var div = $C('div', { id: 'sp-sp-manualdiv' });
- manualDiv = div;
- var span = $C('span', { class: 'sp-sp-md-span' }, '下');
- div.appendChild(span);
-
- var input = $C('input', {
- type: 'number',
- value: 1,
- min: 1,
- title: '输入你想要拼接的页数(必须>=1),然后按回车.',
- id: 'sp-sp-md-number'
- });
-
- var getInputValue = function () {
- var value = Number(input.value);
- if (isNaN(value) || value < 1) {
- value = 1;
- input.value = 1;
- }
- return value;
- };
-
- var spage = function () {
- if (doc) {
- var value = getInputValue();
- //alert(value);
- ipagesmode = true;
- ipagesnumber = value + paged;
- insertedIntoDoc();
- }
- };
- input.addEventListener('keyup', function(e) {
- //alert(e.keyCode);
- if (e.keyCode == 13) { //回车
- spage();
- }
- }, false);
- div.appendChild(input);
- div.appendChild($C('span', { className: 'sp-sp-md-span' }, '页'));
- div.appendChild($C('img', {id: 'sp-sp-md-imgnext', src: _sep_icons.next}));
- div.appendChild($C('span', { id: 'sp-sp-md-someinfo' }, prefs.someValue));
- document.body.appendChild(div);
- div.addEventListener('click', function(e) {
- if (e.target.id == 'sp-sp-md-number') return;
- spage();
- }, false);
- }
- addIntoDoc(manualDiv);
- manualDiv.style.display = 'block';
- }
-
- function beforeInsertIntoDoc() {
- working = true;
- if (SSS.a_manualA && !ipagesmode) { //显示手动翻页触发条.
- manualAdiv();
- } else { //直接拼接.
- insertedIntoDoc();
- }
- }
-
-
- var sepStyle;
- var goNextImg = [false];
- var sNumber = prefs.sepStartN;
- var _sep_icons = sep_icons;
- var curNumber = sNumber;
-
- function createSep(lastUrl, currentUrl, nextUrl) {
- var div = document.createElement('div');
- if (SSS.a_separator) {
- if (!sepStyle) {
- sepStyle = GM_addStyle('\
- div.sp-separator{\
- line-height:1.6!important;\
- opacity:1!important;\
- position:relative!important;\
- float:none!important;\
- top:0!important;\
- left:0!important;\
- min-width:366px;\
- width:auto;\
- text-align:center!important;\
- font-size:14px!important;\
- display:block!important;\
- padding:3px 0!important;\
- margin:5px 10px 8px;\
- clear:both!important;\
- border-top:1px solid #ccc!important;\
- border-bottom:1px solid #ccc!important;\
- -moz-border-radius:30px!important;\
- border-radius:30px!important;\
- background-color:#F5F5F5!important;\
- -moz-box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
- -webkit-box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
- box-shadow:inset 0 16px 20px #fff,0 2px 3px rgba(0,0,0,0.1);\
- }\
- div.sp-separator img{\
- vertical-align:middle!important;\
- cursor:pointer!important;\
- padding:0!important;\
- margin:0 5px!important;\
- border:none!important;\
- display:inline-block!important;\
- float:none!important;\
- width: auto;\
- height: auto;\
- }\
- div.sp-separator a.sp-sp-nextlink{\
- margin:0 20px 0 -6px!important;\
- display:inline!important;\
- text-shadow:#fff 0 1px 0!important;\
- background:none!important;\
- }\
- div.sp-separator span.sp-span-someinfo{\
- position:absolute!important;\
- right:16px!important;\
- bottom:1px!important;\
- font-size:10px!important;\
- text-shadow:white 0 1px 0!important;\
- color:#5A5A5A!important;\
- font-style:italic!important;\
- z-index:-1!important;\
- background:none!important;\
- }\
- ');
- }
-
- div.className = 'sp-separator';
- div.id = 'sp-separator-' + curNumber;
- div.addEventListener('click', sepHandler, false);
-
- var pageStr = '第 ' + curNumber + ' 页' +
- ( SSS.a_separatorReal ? getRalativePageStr(lastUrl, currentUrl, nextUrl) : '');
- div.appendChild($C('a', {
- class: 'sp-sp-nextlink',
- href: currentUrl,
- title: currentUrl
- }, pageStr));
-
- div.appendChild($C('img', {
- src: _sep_icons.top,
- class: 'sp-sp-gotop',
- alt: '去到顶部',
- title: '去到顶部'
- }));
-
- div.appendChild($C('img', {
- src: curNumber == sNumber ? _sep_icons.pre_gray : _sep_icons.pre,
- class: 'sp-sp-gopre',
- title: '上滚一页'
- }));
-
- var i_next = $C('img', {
- src: _sep_icons.next_gray,
- class: 'sp-sp-gonext',
- title: '下滚一页'
- });
-
- if (goNextImg.length == 2) {
- goNextImg.shift();
- }
- goNextImg.push(i_next);
- div.appendChild(i_next);
-
- div.appendChild($C('img', {
- src: _sep_icons.bottom,
- class: 'sp-sp-gobottom',
- alt: '去到底部',
- title: '去到底部'
- }));
-
- div.appendChild($C('span', { class: 'sp-span-someinfo' }, prefs.someValue));
- curNumber += 1;
- } else {
- div.style.cssText = '\
- height:0!important;\
- width:0!important;\
- margin:0!important;\
- padding:0!important;\
- border:none!important;\
- clear:both!important;\
- display:block!important;\
- visibility:hidden!important;\
- ';
- }
- return div;
- }
-
- var paged = 0;
-
- function insertedIntoDoc() {
- if (!doc) return;
-
- if(SSS.a_documentFilter){
- try{
- SSS.a_documentFilter(doc, nextlink);
- }catch(e){
- C.error("执行 documentFilter 错误", e, SSS.a_documentFilter.toString());
- }
- }
-
- var docTitle = getElementByCSS("title", doc).textContent;
-
- removeScripts(doc);
-
- var fragment = document.createDocumentFragment();
- var pageElements = getAllElements(SSS.a_pageElement, false, doc, win);
- var ii = pageElements.length;
- if (ii <= 0) {
- debug('获取下一页的主要内容失败', SSS.a_pageElement);
- removeL();
- return;
- }
-
- // 提前查找下一页链接,后面再赋值
- var lastUrl = cplink;
- cplink = nextlink;
- var nl = getElement(SSS.nextLink, false, doc, win);
- if (nl) {
- nl = getFullHref(nl);
- if (nl == nextlink) {
- nextlink = null;
- } else {
- nextlink = nl;
- }
- } else {
- nextlink = null;
- }
-
- var i, pe_x, pe_x_nn;
- for (i = 0; i < ii; i++) {
- pe_x = pageElements[i];
- pe_x_nn = pe_x.nodeName;
- if (pe_x_nn == 'BODY' || pe_x_nn == 'HTML' || pe_x_nn == 'SCRIPT') continue;
- fragment.appendChild(pe_x);
- }
-
- if (SSS.filter && typeof(SSS.filter) == 'string') { //功能未完善.
- //alert(SSS.filter);
- var nodes = [];
- try {
- nodes = getAllElements(SSS.filter, fragment);
- } catch (e) {}
- var nodes_x;
- for (i = nodes.length - 1; i >= 0; i--) {
- nodes_x = nodes[i];
- nodes_x.parentNode.removeChild(nodes_x);
- }
- }
-
- // lazyImgSrc
- if (SSS.lazyImgSrc) {
- handleLazyImgSrc(SSS.lazyImgSrc, fragment);
- }
-
- var imgs;
- if (!window.opera && SSS.a_useiframe && !SSS.a_iloaded) {
- imgs = getAllElements('css;img[src]', fragment); //收集所有图片
- }
-
- var sepdiv = createSep(lastUrl, cplink, nextlink);
- if (pageElements[0] && pageElements[0].tagName == 'TR') {
- var insertParent = insertPoint.parentNode;
- var colNodes = getAllElements('child::tr[1]/child::*[self::td or self::th]', insertParent);
- var colums = 0;
- for (var x = 0, l = colNodes.length; x < l; x++) {
- var col = colNodes[x].getAttribute('colspan');
- colums += parseInt(col, 10) || 1;
- }
- var td = doc.createElement('td');
- td.appendChild(sepdiv);
- var tr = doc.createElement('tr');
- td.setAttribute('colspan', colums);
- tr.appendChild(td);
- fragment.insertBefore(tr, fragment.firstChild);
- } else {
- fragment.insertBefore(sepdiv, fragment.firstChild);
- }
-
- addIntoDoc(fragment);
-
- // filter
- if (SSS.filter && typeof(SSS.filter) == 'function') {
- try{
- SSS.filter(pageElements);
- debug("执行 filter(pages) 成功");
- }catch(e){
- C.error("执行 filter(pages) 错误", e, SSS.filter.toString());
- }
- }
-
- if (imgs) { //非opera,在iframeDOM取出数据时需要重载图片.
- setTimeout(function() {
- var _imgs = imgs;
- var i, ii, img;
- for (i = 0, ii = _imgs.length; i < ii; i++) {
- img = _imgs[i];
- var src = img.src;
- img.src = src;
- }
- }, 99);
- }
-
- if (SSS.a_replaceE) {
- var oldE = getAllElements(SSS.a_replaceE);
- var oldE_lt = oldE.length;
- //alert(oldE_lt);
- if (oldE_lt > 0) {
- var newE = getAllElements(SSS.a_replaceE, false, doc, win);
- var newE_lt = newE.length;
- //alert(newE_lt);
- if (newE_lt == oldE_lt) { // 替换
- var oldE_x, newE_x;
- for (i = 0; i < newE_lt; i++) {
- oldE_x = oldE[i];
- newE_x = newE[i];
- newE_x = doc.importNode(newE_x, true);
- oldE_x.parentNode.replaceChild(newE_x, oldE_x);
- }
- }
- }
- }
-
- paged += 1;
- if (ipagesmode && paged >= ipagesnumber) {
- ipagesmode = false;
- }
- floatWO.loadedIcon('hide');
- if (manualDiv) {
- manualDiv.style.display = 'none';
- }
- if (goNextImg[0]) goNextImg[0].src = _sep_icons.next;
-
-
- var ev = document.createEvent('Event');
- ev.initEvent('Super_preloaderPageLoaded', true, false);
- document.dispatchEvent(ev);
-
- if(prefs.enableHistory){
- try {
- window.history.pushState(null, docTitle, cplink);
- } catch(e) {}
- }
-
- if (paged >= SSS.a_maxpage) {
- debug('到达所设定的最大翻页数', SSS.a_maxpage);
- notice('状态:' + '到达所设定的最大翻页数:' + SSS.a_maxpage + '');
- removeL();
- return;
- }
- var delayiframe = function(fn) {
- setTimeout(fn, 199);
- };
- if (nextlink) {
- // debug('找到下一页链接:', nextlink);
- doc = win = null;
- if (ipagesmode) {
- if (SSS.a_useiframe) { //延时点,firefox,太急会卡-_-!
- delayiframe(doRequest);
- } else {
- doRequest();
- }
- } else {
- working = false;
- if (SSS.a_useiframe) {
- delayiframe(afterInsertDo);
- } else {
- afterInsertDo();
- }
- }
- } else {
- debug('没有找到下一页链接', SSS.nextLink);
- removeL();
- return;
- }
- }
-
- //返回,剩余高度是总高度的比值.
- var relatedObj_0, relatedObj_1;
- if (SSS.a_relatedObj) {
- if (_.isArray(SSS.a_relatedObj)) {
- relatedObj_0 = SSS.a_relatedObj[0];
- relatedObj_1 = SSS.a_relatedObj[1];
- } else {
- relatedObj_0 = SSS.a_pageElement;
- relatedObj_1 = 'bottom';
- }
- }
-
- function getRemain() {
- var scrolly = window.scrollY;
- var WI = window.innerHeight;
- var obj = getLastElement(relatedObj_0);
- var scrollH = (obj && obj.nodeType == 1) ? (obj.getBoundingClientRect()[relatedObj_1] + scrolly) : Math.max(document.documentElement.scrollHeight, document.body.scrollHeight);
- return (scrollH - scrolly - WI) / WI; //剩余高度于页面总高度的比例.
- }
-
- var pause = false;
- if (prefs.pauseA) {
- var Sbutton = ['target', 'shiftKey', 'ctrlKey', 'altKey'];
- var ltype = prefs.mouseA ? 'mousedown' : 'dblclick';
- var button_1 = Sbutton[prefs.Pbutton[0]];
- var button_2 = Sbutton[prefs.Pbutton[1]];
- var button_3 = Sbutton[prefs.Pbutton[2]];
-
- var pauseIt = function () {
- pause = !pause;
- if (prefs.stop_ipage) ipagesmode = false;
- if (pause) {
- floatWO.updateColor('Apause');
- notice('状态:' + '自动翻页暂停.');
- } else {
- floatWO.updateColor('autopager');
- floatWO.CmodeIcon('hide');
- notice('状态:' + '自动翻页启用.');
- }
- scroll();
- };
- var Sctimeout;
-
- var clearPause = function () {
- clearTimeout(Sctimeout);
- document.removeEventListener('mouseup', arguments.callee, false);
- };
-
- var pausehandler = function (e) {
- if (!SSS.a_manualA || ipagesmode || pause) {
- if (e[button_1] && e[button_2] && e[button_3]) {
- if (e.type == 'mousedown') {
- document.addEventListener('mouseup', clearPause, false);
- Sctimeout = setTimeout(pauseIt, prefs.Atimeout);
- } else {
- pauseIt();
- }
- }
- }
- };
- document.addEventListener(ltype, pausehandler, false);
- remove.push(function() {
- document.removeEventListener(ltype, pausehandler, false);
- });
- }
-
- function scroll() {
- if (!pause && !working && (getRemain() <= SSS.a_remain || ipagesmode)) {
- if (doc) { //有的话,就插入到文档.
- beforeInsertIntoDoc();
- } else { //否则就请求文档.
- scrollDo();
- }
- }
- }
-
- var timeout;
- function timeoutfn(){
- clearTimeout(timeout);
- timeout = setTimeout(scroll, 100);
- }
- window.addEventListener('scroll', timeoutfn, false);
- remove.push(function() {
- window.removeEventListener('scroll', timeoutfn, false);
- });
-
- autoPO = {
- startipages: function(value) {
- if (value > 0) {
- ipagesmode = true;
- ipagesnumber = value + paged;
- notice('状态:' + '当前已翻页数量:' + paged + ',' + '连续翻页到第' + ipagesnumber + '页.');
- if (SSS.a_manualA) insertedIntoDoc();
- scroll();
- }
- },
- };
- }
-
- //prefetcher
- function prefetcher(SSS, floatWO) {
- function cContainer() {
- var div = document.createElement('div');
- var div2 = div.cloneNode(false);
- var hr = document.createElement('hr');
- div.style.cssText = '\
- margin:3px!important;\
- padding:5px!important;\
- border-radius:8px!important;\
- -moz-border-radius:8px!important;\
- border-bottom:1px solid #E30005!important;\
- border-top:1px solid #E30005!important;\
- background-color:#F5F5F5!important;\
- float:none!important;\
- ';
- div.title = '预读的内容';
- div2.style.cssText = '\
- text-align:left!important;\
- color:red!important;\
- font-size:13px!important;\
- display:block!important;\
- float:none!important;\
- position:static!important;\
- ';
- hr.style.cssText = '\
- display:block!important;\
- border:1px inset #000!important;\
- ';
- div.appendChild(div2);
- div.appendChild(hr);
- document.body.appendChild(div);
- return {
- div: div,
- div2: div2
- };
- }
-
- floatWO.updateColor('prefetcher');
-
- floatWO.updateColor('loading');
- floatWO.CmodeIcon('show');
-
- if (SSS.useiframe) {
- var iframe = document.createElement('iframe');
- iframe.name = 'superpreloader-iframe';
- iframe.src = nextlink;
- iframe.width = '100%';
- iframe.height = '0';
- iframe.frameBorder = "0";
- iframe.style.cssText = '\
- margin:0!important;\
- padding:0!important;\
- ';
- iframe.addEventListener('load', function() {
- var body = this.contentDocument.body;
- if (body && body.firstChild) {
- floatWO.updateColor('prefetcher');
- floatWO.CmodeIcon('hide');
- floatWO.loadedIcon('show');
- this.removeEventListener('load', arguments.callee, false);
-
- if (SSS.lazyImgSrc) {
- handleLazyImgSrc(SSS.lazyImgSrc, body);
- }
- }
- }, false);
- if (SSS.viewcontent) {
- var container = cContainer();
- container.div2.innerHTML = 'iframe全预读: ' + '
' + '预读网址: ' + '' + nextlink + '';
- iframe.height = '300px';
- container.div.appendChild(iframe);
- } else {
- document.body.appendChild(iframe);
- }
- } else {
- GM_xmlhttpRequest({
- method: "GET",
- url: nextlink,
- overrideMimeType: 'text/html; charset=' + document.characterSet,
- onload: function(req) {
- var str = req.responseText;
- var doc = createDocumentByString(str);
- if (!doc) {
- C.error('文档对象创建失败!');
- return;
- }
-
- if (SSS.lazyImgSrc) {
- handleLazyImgSrc(SSS.lazyImgSrc, doc);
- }
-
- var images = doc.images;
- var isl = images.length;
- var img;
- var iarray = [];
- var i;
- var existSRC = {};
- var isrc;
- for (i = isl - 1; i >= 0; i--) {
- isrc = images[i].getAttribute('src');
- if (!isrc || existSRC[isrc]) {
- continue;
- } else {
- existSRC[isrc] = true;
- }
- img = document.createElement('img');
- img.src = isrc;
- iarray.push(img);
- }
- if (SSS.viewcontent) {
- var containter = cContainer();
- var div = containter.div;
- i = iarray.length;
- containter.div2.innerHTML = '预读取图片张数: ' + '' + i + '' + '
' + '预读网址: ' + '' + nextlink + '';
- for (i -= 1; i >= 0; i--) {
- div.appendChild(iarray[i]);
- }
- }
- floatWO.updateColor('prefetcher');
- floatWO.loadedIcon('show');
- floatWO.CmodeIcon('hide');
- }
- });
- }
- }
-
-
- //执行开始..///////////////////
-
- // 分析黑名单
- var blackList_re = new RegExp(blackList.map(wildcardToRegExpStr).join("|"));
- if(blackList_re.test(url)){
- debug('匹配黑名单,js执行终止');
- return;
- }
-
- //是否在frame上加载..
- if (prefs.DisableI && window.self != window.parent) {
- var isReturn = !_.find(DIExclude, function(x){ return x[1] && x[2].test(url); });
- if (isReturn) {
- debug('url为:', url, '的页面为非顶层窗口,JS执行终止.');
- return;
- }
- }
- debug('url为:', url, 'JS加载成功');
-
- //第一阶段..分析高级模式..
- SITEINFO = SITEINFO.concat(SITEINFO_TP, SITEINFO_comp);
-
- //重要的变量两枚.
- var nextlink;
- var prelink;
- //===============
-
- var SSS = {};
-
- var findCurSiteInfo = function() {
- var SII;
- var SIIA;
- var SIIAD = SITEINFO_D.autopager;
- var Rurl;
- var ii = SITEINFO.length;
-
- debug('高级规则数量:', ii);
-
- for (i = 0; i < ii; i++) {
- SII = SITEINFO[i];
- Rurl = toRE(SII.url);
- if (Rurl.test(url)) {
- debug('找到匹配当前站点的规则:', SII, '是第', i + 1, '规则');
-
- // 运行规则的 startFilter
- if (SII.autopager && SII.autopager.startFilter) {
- SII.autopager.startFilter(window, document);
- debug('成功运行 startFilter');
- }
-
- nextlink = getElement(SII.nextLink || 'auto;');
- if (!nextlink) {
- debug('无法找到下一页链接,跳过规则:', SII, '继续查找其他规则');
- continue;
- }
-
- if (SII.preLink && SII.preLink != 'auto;') { //如果设定了具体的preLink
- prelink = getElement(SII.preLink);
- } else {
- if(prefs.autoGetPreLink){
- getElement('auto;');
- }
- }
-
- // alert(prelink);
- SSS.hasRule = true;
- SSS.Rurl = String(Rurl);
- // alert(SSS.Rurl);
- SSS.nextLink = SII.nextLink || 'auto;';
- SSS.viewcontent = SII.viewcontent;
- SSS.enable = (SII.enable === undefined) ? SITEINFO_D.enable : SII.enable;
- SSS.useiframe = (SII.useiframe === undefined) ? SITEINFO_D.useiframe : SII.useiframe;
- if (SII.pageElement) { //如果是Oautopager的规则..
- if (!(SII.autopager instanceof Object)) SII.autopager = {};
- SII.autopager.pageElement = SII.pageElement;
- if (SII.insertBefore) SII.autopager.HT_insert = [SII.insertBefore, 1];
- }
-
- //自动翻页设置.
- SIIA = SII.autopager;
- if (SIIA) {
- SSS.a_pageElement = SIIA.pageElement;
- if (!SSS.a_pageElement) break;
- SSS.a_manualA = (SIIA.manualA === undefined) ? SIIAD.manualA : SIIA.manualA;
- SSS.a_enable = (SIIA.enable === undefined) ? SIIAD.enable : SIIA.enable;
- SSS.a_useiframe = (SIIA.useiframe === undefined) ? SIIAD.useiframe : SIIA.useiframe;
- SSS.a_newIframe = (SIIA.newIframe === undefined) ? SIIAD.newIframe : SIIA.newIframe;
- SSS.a_iloaded = (SIIA.iloaded === undefined) ? SIIAD.iloaded : SIIA.iloaded;
- SSS.a_itimeout = (SIIA.itimeout === undefined) ? SIIAD.itimeout : SIIA.itimeout;
- //alert(SSS.a_itimeout);
- SSS.a_remain = (SIIA.remain === undefined) ? SIIAD.remain : SIIA.remain;
- SSS.a_maxpage = (SIIA.maxpage === undefined) ? SIIAD.maxpage : SIIA.maxpage;
- SSS.a_separator = (SIIA.separator === undefined) ? SIIAD.separator : SIIA.separator;
- SSS.a_separatorReal = (SIIA.separatorReal === undefined) ? SIIAD.separatorReal : SIIA.separatorReal;
- SSS.a_replaceE = SIIA.replaceE;
- SSS.a_HT_insert = SIIA.HT_insert;
- SSS.a_relatedObj = SIIA.relatedObj;
- SSS.a_ipages = (SIIA.ipages === undefined) ? SIIAD.ipages : SIIA.ipages;
-
- // new
- SSS.filter = SII.filter || SIIA.filter; // 新增了函数的形式,原来的功能是移除 pageElement
- SSS.a_documentFilter = SII.documentFilter || SIIA.documentFilter;
- SSS.a_stylish = SII.stylish || SIIA.stylish;
- SSS.lazyImgSrc = SIIA.lazyImgSrc;
- }
-
- // 检验是否存在内容
- var pageElement = getElement(SSS.a_pageElement);
- if (!pageElement) {
- debug('无法找到内容,跳过规则:', SII, '继续查找其他规则');
- continue;
- }
-
- break;
- }
- }
-
- if (!SSS.hasRule) {
- debug('未找到合适的高级规则,开始自动匹配.');
- //自动搜索.
- if (!autoMatch.keyMatch) {
- debug('自动匹配功能被禁用了.');
- } else {
- nextlink = autoGetLink();
- //alert(nextlink);
- if (nextlink) { //强制模式.
- var FA = autoMatch.FA;
- SSS.Rurl = window.localStorage ? ('am:' + (url.match(/^https?:\/\/[^:]*\//i) || [])[0]) : 'am:automatch';
- //alert(SSS.Rurl);
- SSS.enable = true;
- SSS.nextLink = 'auto;';
- SSS.viewcontent = autoMatch.viewcontent;
- SSS.useiframe = autoMatch.useiframe;
- SSS.a_force = true;
- SSS.a_manualA = FA.manualA;
- // SSS.a_enable = FA.enable || false; //不能使a_enable的值==undefined...
- SSS.a_enable = FA.enable || SITEINFO_D.autopager.force_enable; //不能使a_enable的值==undefined...
- SSS.a_useiframe = FA.useiframe;
- SSS.a_iloaded = FA.iloaded;
- SSS.a_itimeout = FA.itimeout;
- SSS.a_remain = FA.remain;
- SSS.a_maxpage = FA.maxpage;
- SSS.a_separator = FA.separator;
- SSS.a_ipages = FA.ipages;
- }
- }
- }
-
- // 如果规则没 lazyImgSrc,设置默认值
- if (!SSS.lazyImgSrc) {
- SSS.lazyImgSrc = prefs.lazyImgSrc;
- }
-
- debug('搜索高级规则和自动匹配过程总耗时:', new Date() - startTime, '毫秒');
- };
-
- findCurSiteInfo();
-
- //上下页都没有找到啊
- if (!nextlink && !prelink) {
- debug('未找到相关链接, JS执行停止. 共耗时' + (new Date() - startTime) + '毫秒');
- return;
- } else {
- debug('上一页链接:', prelink);
- debug('下一页链接:', nextlink);
- nextlink = nextlink ? (nextlink.href || nextlink) : undefined;
- prelink = prelink ? (prelink.href || prelink) : undefined;
- }
-
- var superPreloader = {
- go: function() {
- if (nextlink) window.location.href = nextlink;
- },
- back: function() {
- if(!prelink) getElement('auto;');
- if (prelink) window.location.href = prelink;
- },
- };
-
- if (prefs.arrowKeyPage) {
- debug('添加键盘左右方向键翻页监听.');
- document.addEventListener('keyup', function(e) {
- var tarNN = e.target.nodeName;
- if (tarNN != 'BODY' && tarNN != 'HTML') return;
- switch (e.keyCode) {
- case 37:
- superPreloader.back();
- break;
- case 39:
- superPreloader.go();
- break;
- default:
- break;
- }
- }, false);
- }
-
- // 监听下一页事件.
- debug('添加鼠标手势翻页监听.');
- document.addEventListener('superPreloader.go', function() {
- superPreloader.go();
- }, false);
-
- // 监听下一页事件.
- document.addEventListener('superPreloader.back', function() {
- superPreloader.back();
- }, false);
+ // 监听下一页事件.
+ document.addEventListener('superPreloader.back', function() {
+ superPreloader.back();
+ }, false);
// 没找到下一页的链接
if (!nextlink) {
- debug('下一页链接不存在,JS无法继续.');
- debug('全部过程耗时:', new Date() - startTime, '毫秒');
- return;
- }
-
- // 载入设置..
- var loadLocalSetting = function() {
- debug('加载设置');
- var savedValue = getValue('spfwset');
- if (savedValue) {
- try {
- savedValue = eval(savedValue);
- } catch (e) {
- saveValue('spfwset', ''); //有问题的设置,被手动修改过?,清除掉,不然下次还是要出错.
- }
- }
- if (savedValue) {
- SSS.savedValue = savedValue;
- for (i = 0, ii = savedValue.length; i < ii; i++) {
- savedValue_x = savedValue[i];
- if (savedValue_x.Rurl == SSS.Rurl) {
- for (var ix in savedValue_x) {
- if (savedValue_x.hasOwnProperty(ix)) {
- SSS[ix] = savedValue_x[ix]; //加载键值.
- }
- }
- break;
- }
- }
- //alert(i);
- SSS.sedValueIndex = i;
- } else {
- SSS.savedValue = [];
- SSS.sedValueIndex = 0;
- }
- };
-
- loadLocalSetting();
-
- if (!SSS.hasRule) {
- SSS.a_force = true;
- }
-
- if (SSS.a_force) {
- SSS.a_pageElement = '//body/*';
- SSS.a_HT_insert = undefined;
- SSS.a_relatedObj = undefined;
- }
-
- if (prefs.floatWindow) {
- debug('创建悬浮窗');
- floatWindow(SSS);
- }
-
- if (!SSS.enable) {
- debug('本规则被关闭,脚本执行停止');
- debug('全部过程耗时:', new Date() - startTime, '毫秒');
- return;
- }
- debug('全部过程耗时:', new Date() - startTime, '毫秒');
-
- // 预读或者翻页.
- if (SSS.a_enable) {
- debug('初始化,翻页模式.');
- autopager(SSS, floatWO);
- } else {
- debug('初始化,预读模式.');
- prefetcher(SSS, floatWO);
- }
-
- var docChecked;
- function autoGetLink(doc, win) {
- if (!autoMatch.keyMatch) return;
- if (!parseKWRE.done) {
- parseKWRE();
- parseKWRE.done = true;
- }
-
- var startTime = new Date();
- doc = doc || document;
- win = win || window;
-
- if (doc == document) { //当前文档,只检查一次.
- //alert(nextlink);
- if (docChecked) return nextlink;
- docChecked = true;
- }
-
- var _prePageKey = prePageKey;
- var _nextPageKey = nextPageKey;
- var _nPKL = nextPageKey.length;
- var _pPKL = prePageKey.length;
- var _getFullHref = getFullHref;
- var _getAllElementsByXpath = getAllElementsByXpath;
- var _Number = Number;
- var _domain_port = domain_port;
- var alllinks = doc.links;
- var alllinksl = alllinks.length;
-
- var curLHref = cplink;
- var _nextlink;
- var _prelink;
- if (!autoGetLink.checked) { //第一次检查
- _nextlink = nextlink;
- _prelink = prelink;
- } else {
- _prelink = true;
- }
-
- var DCEnable = autoMatch.digitalCheck;
- var DCRE = /^\s*\D{0,1}(\d+)\D{0,1}\s*$/;
-
- var i, a, ahref, atext, numtext;
- var aP, initSD, searchD = 1,
- preS1, preS2, searchedD, pSNText, preSS, nodeType;
- var nextS1, nextS2, nSNText, nextSS;
- var aimgs, j, jj, aimg_x, xbreak, k, keytext;
-
- function finalCheck(a, type) {
- var ahref = a.getAttribute('href'); //在chrome上当是非当前页面文档对象的时候直接用a.href访问,不返回href
- if (ahref == '#') {
- return null;
- }
- ahref = _getFullHref(ahref); //从相对路径获取完全的href;
-
- //3个条件:http协议链接,非跳到当前页面的链接,非跨域
- if (/^https?:/i.test(ahref) && ahref.replace(/#.*$/, '') != curLHref && ahref.match(/https?:\/\/([^\/]+)/)[1] == _domain_port) {
- if (xbug) {
- debug((type == 'pre' ? '上一页' : '下一页') + '匹配到的关键字为:', atext);
- }
- return a; //返回对象A
- //return ahref;
- }
- }
-
- if (xbug) {
- debug('全文档链接数量:', alllinksl);
- }
-
- for (i = 0; i < alllinksl; i++) {
- if (_nextlink && _prelink) break;
- a = alllinks[i];
- if (!a) continue; //undefined跳过
- //links集合返回的本来就是包含href的a元素..所以不用检测
- //if(!a.hasAttribute("href"))continue;
- atext = a.textContent;
- if (atext) {
- if (DCEnable) {
- numtext = atext.match(DCRE);
- if (numtext) { //是不是纯数字
- //debug(numtext);
- numtext = numtext[1];
- //alert(numtext);
- aP = a;
- initSD = 0;
-
- if (!_nextlink) {
- preS1 = a.previousSibling;
- preS2 = a.previousElementSibling;
-
-
- while (!(preS1 || preS2) && initSD < searchD) {
- aP = aP.parentNode;
- if (aP) {
- preS1 = aP.previousSibling;
- preS2 = aP.previousElementSibling;
- }
- initSD++;
- //alert('initSD: '+initSD);
- }
- searchedD = initSD > 0 ? true : false;
-
- if (preS1 || preS2) {
- pSNText = preS1 ? preS1.textContent.match(DCRE) : '';
- if (pSNText) {
- preSS = preS1;
- } else {
- pSNText = preS2 ? preS2.textContent.match(DCRE) : '';
- preSS = preS2;
- }
- //alert(previousS);
- if (pSNText) {
- pSNText = pSNText[1];
- //debug(pSNText)
- //alert(pSNText)
- if (_Number(pSNText) == _Number(numtext) - 1) {
- //alert(searchedD);
- nodeType = preSS.nodeType;
- //alert(nodeType);
- if (nodeType == 3 || (nodeType == 1 && (searchedD ? _getAllElementsByXpath('./descendant-or-self::a[@href]', preSS, doc).snapshotLength === 0 : (!preSS.hasAttribute('href') || _getFullHref(preSS.getAttribute('href')) == curLHref)))) {
- _nextlink = finalCheck(a, 'next');
- //alert(_nextlink);
- }
- continue;
- }
- }
- }
- }
-
- if (!_prelink) {
- nextS1 = a.nextSibling;
- nextS2 = a.nextElementSibling;
-
- while (!(nextS1 || nextS2) && initSD < searchD) {
- aP = aP.parentNode;
- if (aP) {
- nextS1 = a.nextSibling;
- nextS2 = a.nextElementSibling;
- }
- initSD++;
- //alert('initSD: '+initSD);
- }
- searchedD = initSD > 0 ? true : false;
-
- if (nextS1 || nextS2) {
- nSNText = nextS1 ? nextS1.textContent.match(DCRE) : '';
- if (nSNText) {
- nextSS = nextS1;
- } else {
- nSNText = nextS2 ? nextS2.textContent.match(DCRE) : '';
- nextSS = nextS2;
- }
- //alert(nextS);
- if (nSNText) {
- nSNText = nSNText[1];
- //alert(pSNText)
- if (_Number(nSNText) == _Number(numtext) + 1) {
- //alert(searchedD);
- nodeType = nextSS.nodeType;
- //alert(nodeType);
- if (nodeType == 3 || (nodeType == 1 && (searchedD ? _getAllElementsByXpath('./descendant-or-self::a[@href]', nextSS, doc).snapshotLength === 0 : (!nextSS.hasAttribute("href") || _getFullHref(nextSS.getAttribute('href')) == curLHref)))) {
- _prelink = finalCheck(a, 'pre');
- //alert(_prelink);
- }
- }
- }
- }
- }
- continue;
- }
- }
- } else {
- atext = a.title;
- }
- if (!atext) {
- aimgs = a.getElementsByTagName('img');
- for (j = 0, jj = aimgs.length; j < jj; j++) {
- aimg_x = aimgs[j];
- atext = aimg_x.alt || aimg_x.title;
- if (atext) break;
- }
- }
- if (!atext) continue;
- if (!_nextlink) {
- xbreak = false;
- for (k = 0; k < _nPKL; k++) {
- keytext = _nextPageKey[k];
- if (!(keytext.test(atext))) continue;
- _nextlink = finalCheck(a, 'next');
- xbreak = true;
- break;
- }
- if (xbreak || _nextlink) continue;
- }
- if (!_prelink) {
- for (k = 0; k < _pPKL; k++) {
- keytext = _prePageKey[k];
- if (!(keytext.test(atext))) continue;
- _prelink = finalCheck(a, 'pre');
- break;
- }
- }
- }
-
- debug('搜索链接数量:', i, '耗时:', new Date() - startTime, '毫秒');
-
- if (!autoGetLink.checked) { //只在第一次检测的时候,抛出上一页链接.
- prelink = _prelink;
- autoGetLink.checked = true;
- }
-
- //alert(_nextlink);
- return _nextlink;
+ debug('下一页链接不存在,JS无法继续.');
+ debug('全部过程耗时:', new Date() - startTime, '毫秒');
+ return;
}
- function parseKWRE() {
- function modifyPageKey(name, pageKey, pageKeyLength) {
- function strMTE(str) {
- return (str.replace(/\\/g, '\\\\')
- .replace(/\+/g, '\\+')
- .replace(/\./g, '\\.')
- .replace(/\?/g, '\\?')
- .replace(/\{/g, '\\{')
- .replace(/\}/g, '\\}')
- .replace(/\[/g, '\\[')
- .replace(/\]/g, '\\]')
- .replace(/\^/g, '\\^')
- .replace(/\$/g, '\\$')
- .replace(/\*/g, '\\*')
- .replace(/\(/g, '\\(')
- .replace(/\)/g, '\\)')
- .replace(/\|/g, '\\|')
- .replace(/\//g, '\\/'));
- }
-
- var pfwordl = autoMatch.pfwordl,
- sfwordl = autoMatch.sfwordl;
-
- var RE_enable_a = pfwordl[name].enable,
- RE_maxPrefix = pfwordl[name].maxPrefix,
- RE_character_a = pfwordl[name].character,
- RE_enable_b = sfwordl[name].enable,
- RE_maxSubfix = sfwordl[name].maxSubfix,
- RE_character_b = sfwordl[name].character;
- var plwords,
- slwords,
- rep;
-
- plwords = RE_maxPrefix > 0 ? ('[' + (RE_enable_a ? strMTE(RE_character_a.join('')) : '.') + ']{0,' + RE_maxPrefix + '}') : '';
- plwords = '^\\s*' + plwords;
- //alert(plwords);
- slwords = RE_maxSubfix > 0 ? ('[' + (RE_enable_b ? strMTE(RE_character_b.join('')) : '.') + ']{0,' + RE_maxSubfix + '}') : '';
- slwords = slwords + '\\s*$';
- //alert(slwords);
- rep = prefs.cases ? '' : 'i';
-
- for (var i = 0; i < pageKeyLength; i++) {
- pageKey[i] = new RegExp(plwords + strMTE(pageKey[i]) + slwords, rep);
- //alert(pageKey[i]);
+ // 载入设置..
+ var loadLocalSetting = function() {
+ debug('加载设置');
+ var savedValue = getValue('spfwset');
+ if (savedValue) {
+ try {
+ savedValue = eval(savedValue);
+ } catch (e) {
+ saveValue('spfwset', ''); //有问题的设置,被手动修改过?,清除掉,不然下次还是要出错.
}
- return pageKey;
}
-
- //转成正则.
- prePageKey = modifyPageKey('previous', prePageKey, prePageKey.length);
- nextPageKey = modifyPageKey('next', nextPageKey, nextPageKey.length);
- }
-
- // 地址栏递增处理函数.
- function hrefInc(obj, doc, win) {
- var _cplink = cplink;
-
- function getHref(href) {
- var mFails = obj.mFails;
- if (!mFails) return href;
- var str;
- if (typeof mFails == 'string') {
- str = mFails;
- } else {
- var fx;
- var array = [];
- var i, ii;
- var mValue;
- for (i = 0, ii = mFails.length; i < ii; i++) {
- fx = mFails[i];
- if (!fx) continue;
- if (typeof fx == 'string') {
- array.push(fx);
- } else {
- mValue = href.match(fx);
- if (!mValue) return href;
- array.push(mValue);
+ if (savedValue) {
+ SSS.savedValue = savedValue;
+ for (i = 0, ii = savedValue.length; i < ii; i++) {
+ savedValue_x = savedValue[i];
+ if (savedValue_x.Rurl == SSS.Rurl) {
+ for (var ix in savedValue_x) {
+ if (savedValue_x.hasOwnProperty(ix)) {
+ SSS[ix] = savedValue_x[ix]; //加载键值.
+ }
}
- }
- str = array.join('');
- }
- return str;
- }
- // alert(getHref(_cplink))
-
- var sa = obj.startAfter;
- var saType = typeof sa;
- var index;
-
- if (saType == 'string') {
- index = _cplink.indexOf(sa);
- if (index == -1) {
- _cplink = getHref(_cplink);
- index = _cplink.indexOf(sa);
- if (index == -1) return;
- //alert(index);
- }
- } else {
- var tsa = _cplink.match(sa);
- //alert(sa);
- if (!tsa) {
- _cplink = getHref(_cplink);
- sa = (_cplink.match(sa) || [])[0];
- if (!sa) return;
- index = _cplink.indexOf(sa);
- if (index == -1) return;
- } else {
- sa = tsa[0];
- index = _cplink.indexOf(sa);
- //alert(index)
- //alert(tsa.index)
- }
- }
-
- index += sa.length;
- var max = obj.max === undefined ? 9999 : obj.max;
- var min = obj.min === undefined ? 1 : obj.min;
- var aStr = _cplink.slice(0, index);
- var bStr = _cplink.slice(index);
- var nbStr = bStr.replace(/^(\d+)(.*)$/, function(a, b, c) {
- b = Number(b) + obj.inc;
- if (b >= max || b < min) return a;
- return b + c;
- });
- // alert(aStr+nbStr);
- if (nbStr !== bStr) {
- var ilresult;
- try {
- ilresult = obj.isLast(doc, unsafeWindow, _cplink);
- } catch (e) {}
- if (ilresult) return;
- return aStr + nbStr;
- }
- }
-
- // 获取单个元素,混合
- function getElement(selector, contextNode, doc, win) {
- var ret;
- if (!selector) return ret;
- doc = doc || document;
- win = win || window;
- contextNode = contextNode || doc;
- var type = typeof selector;
- if (type == 'string') {
- if (selector.search(/^css;/i) === 0) {
- ret = getElementByCSS(selector.slice(4), contextNode);
- } else if (selector.toLowerCase() == 'auto;') {
- ret = autoGetLink(doc, win);
- } else {
- ret = getElementByXpath(selector, contextNode, doc);
- }
- } else if (type == 'function') {
- ret = selector(doc, win, cplink);
- } else if (selector instanceof Array) {
- for (var i = 0, l = selector.length; i < l; i++) {
- ret = getElement(selector[i], contextNode, doc, win);
- if (ret) {
break;
}
}
+ //alert(i);
+ SSS.sedValueIndex = i;
} else {
- ret = hrefInc(selector, doc, win);
+ SSS.savedValue = [];
+ SSS.sedValueIndex = 0;
}
- return ret;
- }
-}
-
-
-// ==================== libs ==============================
-
-// 自造简化版 underscroe 库,仅 ECMAScript 5
-var _ = (function(){
-
- var nativeIsArray = Array.isArray;
- var _ = function(obj){
- if(obj instanceof _) return obj;
- if(!(this instanceof _)) return new _(obj);
- this._wrapped = obj;
- };
-
- var toString = Object.prototype.toString;
-
- _.isArray = nativeIsArray || function(obj) {
- return toString.call(obj) == '[object Array]';
- };
-
- ['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp'].forEach(function(name){
- _['is' + name] = function(obj) {
- return toString.call(obj) == '[object ' + name + ']';
- };
- });
-
- // Return the first value which passes a truth test. Aliased as `detect`.
- _.find = function(obj, iterator, context){
- var result;
- obj.some(function(value, index, array){
- if(iterator.call(context, value, index, array)){
- result = value;
- return true;
- }
- });
- return result;
};
- return _;
-})();
-
-/* jshint ignore:start */
-//动画库
-var Tween = {
- Linear: function(t, b, c, d) {
- return c * t / d + b;
- },
- Quad: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t + b;
- },
- easeOut: function(t, b, c, d) {
- return -c * (t /= d) * (t - 2) + b;
- },
- easeInOut: function(t, b, c, d) {
- if ((t /= d / 2) < 1) return c / 2 * t * t + b;
- return -c / 2 * ((--t) * (t - 2) - 1) + b;
- }
- },
- Cubic: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return c * ((t = t / d - 1) * t * t + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if ((t /= d / 2) < 1) return c / 2 * t * t * t + b;
- return c / 2 * ((t -= 2) * t * t + 2) + b;
- }
- },
- Quart: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return -c * ((t = t / d - 1) * t * t * t - 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if ((t /= d / 2) < 1) return c / 2 * t * t * t * t + b;
- return -c / 2 * ((t -= 2) * t * t * t - 2) + b;
- }
- },
- Quint: {
- easeIn: function(t, b, c, d) {
- return c * (t /= d) * t * t * t * t + b;
- },
- easeOut: function(t, b, c, d) {
- return c * ((t = t / d - 1) * t * t * t * t + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if ((t /= d / 2) < 1) return c / 2 * t * t * t * t * t + b;
- return c / 2 * ((t -= 2) * t * t * t * t + 2) + b;
- }
- },
- Sine: {
- easeIn: function(t, b, c, d) {
- return -c * Math.cos(t / d * (Math.PI / 2)) + c + b;
- },
- easeOut: function(t, b, c, d) {
- return c * Math.sin(t / d * (Math.PI / 2)) + b;
- },
- easeInOut: function(t, b, c, d) {
- return -c / 2 * (Math.cos(Math.PI * t / d) - 1) + b;
- }
- },
- Expo: {
- easeIn: function(t, b, c, d) {
- return (t == 0) ? b : c * Math.pow(2, 10 * (t / d - 1)) + b;
- },
- easeOut: function(t, b, c, d) {
- return (t == d) ? b + c : c * (-Math.pow(2, -10 * t / d) + 1) + b;
- },
- easeInOut: function(t, b, c, d) {
- if (t == 0) return b;
- if (t == d) return b + c;
- if ((t /= d / 2) < 1) return c / 2 * Math.pow(2, 10 * (t - 1)) + b;
- return c / 2 * (-Math.pow(2, -10 * --t) + 2) + b;
- }
- },
- Circ: {
- easeIn: function(t, b, c, d) {
- return -c * (Math.sqrt(1 - (t /= d) * t) - 1) + b;
- },
- easeOut: function(t, b, c, d) {
- return c * Math.sqrt(1 - (t = t / d - 1) * t) + b;
- },
- easeInOut: function(t, b, c, d) {
- if ((t /= d / 2) < 1) return -c / 2 * (Math.sqrt(1 - t * t) - 1) + b;
- return c / 2 * (Math.sqrt(1 - (t -= 2) * t) + 1) + b;
- }
- },
- Elastic: {
- easeIn: function(t, b, c, d, a, p) {
- if (t == 0) return b;
- if ((t /= d) == 1) return b + c;
- if (!p) p = d * .3;
- if (!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- return -(a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
- },
- easeOut: function(t, b, c, d, a, p) {
- if (t == 0) return b;
- if ((t /= d) == 1) return b + c;
- if (!p) p = d * .3;
- if (!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- return (a * Math.pow(2, -10 * t) * Math.sin((t * d - s) * (2 * Math.PI) / p) + c + b);
- },
- easeInOut: function(t, b, c, d, a, p) {
- if (t == 0) return b;
- if ((t /= d / 2) == 2) return b + c;
- if (!p) p = d * (.3 * 1.5);
- if (!a || a < Math.abs(c)) {
- a = c;
- var s = p / 4;
- } else var s = p / (2 * Math.PI) * Math.asin(c / a);
- if (t < 1) return -.5 * (a * Math.pow(2, 10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p)) + b;
- return a * Math.pow(2, -10 * (t -= 1)) * Math.sin((t * d - s) * (2 * Math.PI) / p) * .5 + c + b;
- }
- },
- Back: {
- easeIn: function(t, b, c, d, s) {
- if (s == undefined) s = 1.70158;
- return c * (t /= d) * t * ((s + 1) * t - s) + b;
- },
- easeOut: function(t, b, c, d, s) {
- if (s == undefined) s = 1.70158;
- return c * ((t = t / d - 1) * t * ((s + 1) * t + s) + 1) + b;
- },
- easeInOut: function(t, b, c, d, s) {
- if (s == undefined) s = 1.70158;
- if ((t /= d / 2) < 1) return c / 2 * (t * t * (((s *= (1.525)) + 1) * t - s)) + b;
- return c / 2 * ((t -= 2) * t * (((s *= (1.525)) + 1) * t + s) + 2) + b;
- }
- },
- Bounce: {
- easeIn: function(t, b, c, d) {
- return c - Tween.Bounce.easeOut(d - t, 0, c, d) + b;
- },
- easeOut: function(t, b, c, d) {
- if ((t /= d) < (1 / 2.75)) {
- return c * (7.5625 * t * t) + b;
- } else if (t < (2 / 2.75)) {
- return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;
- } else if (t < (2.5 / 2.75)) {
- return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;
- } else {
- return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;
- }
- },
- easeInOut: function(t, b, c, d) {
- if (t < d / 2) return Tween.Bounce.easeIn(t * 2, 0, c, d) * .5 + b;
- else return Tween.Bounce.easeOut(t * 2 - d, 0, c, d) * .5 + c * .5 + b;
- }
- }
-};
-
-var TweenM = [
- 'Linear',
- 'Quad',
- 'Cubic',
- 'Quart',
- 'Quint',
- 'Sine',
- 'Expo',
- 'Circ',
- 'Elastic',
- 'Back',
- 'Bounce',
-];
-
-var TweenEase = [
- 'easeIn',
- 'easeOut',
- 'easeInOut',
-];
-/* jshint ignore:end */
-
-
-// ==================== functions ==============================
-
-function gmCompatible() {
+ loadLocalSetting();
- GM_addStyle = function(css, id){
- var s = document.createElement('style');
- if (id) {
- s.setAttribute(id, id);
- }
- s.setAttribute('type', 'text/css');
- s.setAttribute('style', 'display: none !important;');
- s.appendChild(document.createTextNode(css));
- return (document.getElementsByTagName('head')[0] || document.documentElement).appendChild(s);
- };
-
- if (typeof unsafeWindow == "undefined") unsafeWindow = window;
- if (typeof GM_getValue != "undefined" && GM_getValue("a", "b") !== undefined) {
- return;
- }
-
- GM_getValue = function(key, defaultValue) {
- var value = window.localStorage.getItem(key);
- if (value === null) value = defaultValue;
- else if (value == 'true') value = true;
- else if (value == 'false') value = false;
- return value;
- };
- GM_setValue = function(key, value) {
- window.localStorage.setItem(key, value);
- };
- GM_registerMenuCommand = function() {};
-
- // chrome 原生支持
- if (typeof GM_xmlhttpRequest == 'undefined') {
- GM_xmlhttpRequest = function(opt) {
- var req = new XMLHttpRequest();
- req.open('GET', opt.url, true);
- req.overrideMimeType(opt.overrideMimeType);
- req.onreadystatechange = function (aEvt) {
- if (req.readyState == 4) {
- if (req.status == 200) {
- opt.onload(req);
- }
- else {
- opt.onerror();
- }
- }
- };
- req.send(null);
- };
+ if (!SSS.hasRule) {
+ SSS.a_force = true;
}
-}
-// By lastDream2013 略加修改,原版只能用于 Firefox
-function getRalativePageStr(lastUrl, currentUrl, nextUrl) {
- function getDigital(str) {
- var num = str.replace(/^p/i, '');
- return parseInt(num, 10);
+ if (SSS.a_force) {
+ SSS.a_pageElement = '//body/*';
+ SSS.a_HT_insert = undefined;
+ SSS.a_relatedObj = undefined;
}
- var getRalativePageNumArray = function (lasturl, url) {
- if (!lasturl || !url) {
- return [0, 0];
- }
-
- var lasturlarray = lasturl.split(/-|\.|\&|\/|=|#|\?/),
- urlarray = url.split(/-|\.|\&|\/|=|#|\?/),
- url_info,
- lasturl_info;
- // 一些 url_info 为 p1,p2,p3 之类的
- var handleInfo = function(s) {
- if (s) {
- return s.replace(/^p/, '');
- }
- return s;
- };
- while (urlarray.length !== 0) {
- url_info = handleInfo(urlarray.pop());
- lasturl_info = handleInfo(lasturlarray.pop());
- if (url_info != lasturl_info) {
- if (/[0-9]+/.test(url_info) && (url_info == "2" || /[0-9]+/.test(lasturl_info))) {
- return [(parseInt(lasturl_info) || 1), parseInt(url_info)];
- }
- }
- }
- return [0, 0];
+ // 悬浮窗
+ var floatWO = {
+ updateColor: nullFn,
+ loadedIcon: nullFn,
+ CmodeIcon: nullFn,
+ destory: nullFn
};
-
- var ralativeOff;
-
- //论坛和搜索引擎网页显示实际页面信息
- var ralativePageNumarray = [];
- if (nextUrl) {
- ralativePageNumarray = getRalativePageNumArray(currentUrl, nextUrl);
- } else {
- ralativePageNumarray = getRalativePageNumArray(lastUrl, currentUrl);
- ralativeOff = ralativePageNumarray[1] - ralativePageNumarray[0]; //用的上一页的相对信息比较的,要补充差值……
- ralativePageNumarray[1] = ralativePageNumarray[1] + ralativeOff;
- ralativePageNumarray[0] = ralativePageNumarray[0] + ralativeOff;
- }
-
- // console.log('[获取实际页数] ', '要比较的3个页数:',arguments, ',得到的差值:', ralativePageNumarray);
- if (isNaN(ralativePageNumarray[0]) || isNaN(ralativePageNumarray[1])) {
- return '';
- }
-
- var realPageSiteMatch = false;
- ralativeOff = ralativePageNumarray[1] - ralativePageNumarray[0];
- //上一页与下一页差值为1,并最大数值不超过10000(一般论坛也不会超过这么多页……)
- if (ralativeOff === 1 && ralativePageNumarray[1] < 10000) {
- realPageSiteMatch = true;
- }
-
- //上一页与下一页差值不为1,但上一页与下一页差值能被上一页与下一面所整除的,有规律的页面
- if (!realPageSiteMatch && ralativeOff !== 1) {
- if ((ralativePageNumarray[1] % ralativeOff) === 0 && (ralativePageNumarray[0] % ralativeOff) === 0) {
- realPageSiteMatch = true;
- }
- }
-
- if (!realPageSiteMatch) { //不满足以上条件,再根据地址特征来匹配
- var sitePattern;
- for (var i = 0, length = REALPAGE_SITE_PATTERN.length; i < length; i++) {
- sitePattern = REALPAGE_SITE_PATTERN[i];
- if (currentUrl.toLocaleLowerCase().indexOf(sitePattern) >= 0) {
- realPageSiteMatch = true;
- break;
- }
- }
- }
-
- var ralativePageStr;
- if (realPageSiteMatch) { //如果匹配就显示实际网页信息
- if (ralativePageNumarray[1] - ralativePageNumarray[0] > 1) { //一般是搜索引擎的第xx - xx项……
- ralativePageStr = ' [ 实际:第 ' + ralativePageNumarray[0] + ' - ' + ralativePageNumarray[1] + ' 项 ]';
- } else if ((ralativePageNumarray[1] - ralativePageNumarray[0]) === 1) { //一般的翻页数,差值应该是1
- ralativePageStr = ' [ 实际:第 ' + ralativePageNumarray[0] + ' 页 ]';
- } else if ((ralativePageNumarray[0] === 0 && ralativePageNumarray[1]) === 0) { //找不到的话……
- ralativePageStr = ' [ 实际网页结束 ]';
- }
- } else {
- ralativePageStr = '';
- }
- return ralativePageStr || '';
-}
-
-function handleLazyImgSrc(rule, doc) {
- var imgAttrs = rule.split('|');
- imgAttrs.forEach(function(attr){
- attr = attr.trim();
- [].forEach.call(doc.querySelectorAll("img[" + attr + "]"), function(img){
- var newSrc = img.getAttribute(attr);
- if (newSrc && newSrc != img.src) {
- img.setAttribute("src", newSrc);
- img.removeAttribute(attr);
- }
- });
- });
-}
-
-function removeScripts(node) { // 移除元素的 script
- var scripts = getAllElements('css;script', node);
- var scripts_x;
- for (i = scripts.length - 1; i >= 0; i--) {
- scripts_x = scripts[i];
- scripts_x.parentNode.removeChild(scripts_x);
- }
-}
-
-var noticeDiv;
-var noticeDivto;
-var noticeDivto2;
-function notice(html_txt) {
- if (!noticeDiv) {
- var div = document.createElement('div');
- noticeDiv = div;
- div.style.cssText = '\
- position:fixed!important;\
- z-index:2147483647!important;\
- float:none!important;\
- width:auto!important;\
- height:auto!important;\
- font-size:13px!important;\
- padding:3px 20px 2px 5px!important;\
- background-color:#7f8f9c!important;\
- border:none!important;\
- color:#000!important;\
- text-align:left!important;\
- left:0!important;\
- bottom:0!important;\
- opacity:0;\
- -moz-border-radius:0 6px 0 0!important;\
- border-radius:0 6px 0 0!important;\
- -o-transition:opacity 0.3s ease-in-out;\
- -webkit-transition:opacity 0.3s ease-in-out;\
- -moz-transition:opacity 0.3s ease-in-out;\
- ';
- document.body.appendChild(div);
- }
- clearTimeout(noticeDivto);
- clearTimeout(noticeDivto2);
- noticeDiv.innerHTML = html_txt;
- noticeDiv.style.display = 'block';
- noticeDiv.style.opacity = '0.96';
- noticeDivto2 = setTimeout(function() {
- noticeDiv.style.opacity = '0';
- }, 1666);
- noticeDivto = setTimeout(function() {
- noticeDiv.style.display = 'none';
- }, 2000);
-}
-
-function $C(type, atArr, inner, action, listen) {
- var e = document.createElement(type);
- for (var at in atArr) {
- if (atArr.hasOwnProperty(at)) {
- e.setAttribute(at, atArr[at]);
- }
- }
- if (action && listen) {
- e.addEventListener(action, listen, false);
- }
- if (inner) {
- e.innerHTML = inner;
- }
- return e;
-}
-
-// css 获取单个元素
-function getElementByCSS(css, contextNode) {
- return (contextNode || document).querySelector(css);
-}
-
-// css 获取所有元素
-function getAllElementsByCSS(css, contextNode) {
- return (contextNode || document).querySelectorAll(css);
-}
-
-// xpath 获取单个元素
-function getElementByXpath(xpath, contextNode, doc) {
- doc = doc || document;
- contextNode = contextNode || doc;
- return doc.evaluate(xpath, contextNode, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
-}
-
-// xpath 获取多个元素.
-function getAllElementsByXpath(xpath, contextNode, doc) {
- doc = doc || document;
- contextNode = contextNode || doc;
- return doc.evaluate(xpath, contextNode, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
-}
-
-// 获取多个元素
-function getAllElements(selector, contextNode, doc, win) {
- var ret = [];
- if (!selector) return ret;
- var Eles;
- doc = doc || document;
- win = win || window;
- contextNode = contextNode || doc;
- if (typeof selector == 'string') {
- if (selector.search(/^css;/i) === 0) {
- Eles = getAllElementsByCSS(selector.slice(4), contextNode);
- } else {
- Eles = getAllElementsByXpath(selector, contextNode, doc);
- }
- } else {
- Eles = selector(doc, win);
- if (!Eles) return ret;
- if (Eles.nodeType) { //单个元素.
- ret[0] = Eles;
- return ret;
- }
- }
-
- function unique(array) { //数组去重并且保持数组顺序.
- var i, ca, ca2, j;
- for (i = 0; i < array.length; i++) {
- ca = array[i];
- for (j = i + 1; j < array.length; j++) {
- ca2 = array[j];
- if (ca2 == ca) {
- array.splice(j, 1);
- j--;
- }
- }
- }
- return array;
- }
-
- function makeArray(x) {
- var ret = [];
- var i, ii;
- var x_x;
- if (x.pop) { //普通的 array
- for (i = 0, ii = x.length; i < ii; i++) {
- x_x = x[i];
- if (x_x) {
- if (x_x.nodeType) { //普通类型,直接放进去.
- ret.push(x_x);
- } else {
- ret = ret.concat(makeArray(x_x)); //嵌套的.
- }
- }
- }
- //alert(ret)
- return unique(ret);
- } else if (x.item) { //nodelist or HTMLcollection
- i = x.length;
- while (i) {
- ret[--i] = x[i];
- }
- /*
- for(i=0,ii=x.length;i 0) {
- return eles[l - 1];
- }
-}
-
-function saveValue(key, value) {
- localStorage.setItem(key, encodeURIComponent(value));
-}
-
-function getValue(key) {
- var value = localStorage.getItem(key);
- return value ? decodeURIComponent(value) : undefined;
-}
-
-function createDocumentByString(str) { // string转为DOM
- if (!str) {
- C.error('没有找到要转成DOM的字符串');
- return;
- }
- if (document.documentElement.nodeName != 'HTML') {
- return new DOMParser().parseFromString(str, 'application/xhtml+xml');
- }
-
- var doc;
- try {
- // firefox and chrome 30+,Opera 12 会报错
- doc = new DOMParser().parseFromString(str, 'text/html');
- } catch (ex) {}
-
- if (doc) {
- return doc;
- }
-
- if (document.implementation.createHTMLDocument) {
- doc = document.implementation.createHTMLDocument('superPreloader');
- } else {
- try {
- doc = document.cloneNode(false);
- doc.appendChild(doc.importNode(document.documentElement, false));
- doc.documentElement.appendChild(doc.createElement('head'));
- doc.documentElement.appendChild(doc.createElement('body'));
- } catch (e) {}
- }
- if (!doc) return;
- var range = document.createRange();
- range.selectNodeContents(document.body);
- var fragment = range.createContextualFragment(str);
- doc.body.appendChild(fragment);
- var headChildNames = {
- TITLE: true,
- META: true,
- LINK: true,
- STYLE: true,
- BASE: true
+ // autopager
+ var autoPO = {
+ startipages: nullFn,
};
- var child;
- var body = doc.body;
- var bchilds = body.childNodes;
- for (var i = bchilds.length - 1; i >= 0; i--) { //移除head的子元素
- child = bchilds[i];
- if (headChildNames[child.nodeName]) body.removeChild(child);
- }
- //alert(doc.documentElement.innerHTML);
- //debug(doc);
- //debug(doc.documentElement.innerHTML);
- return doc;
-}
-// 从相对路径的a.href获取完全的href值.
-function getFullHref(href) {
- if (typeof href != 'string') href = href.getAttribute('href');
- //alert(href);
- //if(href.search(/^https?:/)==0)return href;//http打头,不一定就是完整的href;
- var a = getFullHref.a;
- if (!a) {
- getFullHref.a = a = document.createElement('a');
+ if (prefs.floatWindow) {
+ debug('创建悬浮窗');
+ floatWO = new FloatWindow(SSS, autoPO);
}
- a.href = href;
- //alert(a.href);
- return a.href;
-}
-// 任何转成字符串,存储,修改过
-function xToString(x) {
- function toStr(x) {
- switch (typeof x) {
- case 'undefined':
- return Str(x);
- case 'boolean':
- return Str(x);
- case 'number':
- return Str(x);
- case 'string':
- return ('"' +
- (x.replace(/(?:\r\n|\n|\r|\t|\\|")/g, function(a) {
- var ret;
- switch (a) { //转成字面量
- case '\r\n':
- ret = '\\r\\n';
- break;
- case '\n':
- ret = '\\n';
- break;
- case '\r':
- ret = '\\r';
- break;
- case '\t':
- ret = '\\t';
- break;
- case '\\':
- ret = '\\\\';
- break;
- case '"':
- ret = '\\"';
- break;
- default:
- break;
- }
- return ret;
- })) + '"');
- case 'function':
- var fnStr = Str(x);
- return fnStr.indexOf('native code') == -1 ? fnStr : 'function(){}';
- case 'object':
- //注,object的除了单纯{},其他的对象的属性会造成丢失..
- if (x === null) {
- return Str(x);
- }
- switch (x.constructor.name) {
- case "Object":
- var i;
- var rStr = '';
- for (i in x) {
- if (!x.hasOwnProperty(i)) { //去掉原型链上的属性.
- continue;
- }
- rStr += toStr(i) + ':' + toStr(x[i]) + ',';
- }
- return ('{' + rStr.replace(/,$/i, '') + '}');
- case "Array":
- var i;
- var rStr = '';
- for (i in x) {
- if (!x.hasOwnProperty(i)) { //去掉原型链上的属性.
- continue;
- }
- rStr += toStr(x[i]) + ',';
- }
- return '[' + rStr.replace(/,$/i, '') + ']';
- case "String":
- return toStr(Str(x));
- case "RegExp":
- return Str(x);
- case "Number":
- return Str(x);
- case "Boolean":
- return Str(x);
- default:
- //alert(x.constructor);//漏了什么类型么?
- break;
- }
- default:
- break;
- }
+ if (!SSS.enable) {
+ debug('本规则被关闭,脚本执行停止');
+ debug('全部过程耗时:', new Date() - startTime, '毫秒');
+ return;
}
- var Str = String;
- return toStr(x);
-}
+ debug('全部过程耗时:', new Date() - startTime, '毫秒');
-function toRE(obj) {
- if (obj instanceof RegExp) {
- return obj;
- } else if (obj instanceof Array) {
- return new RegExp(obj[0], obj[1]);
+ // 预读或者翻页.
+ if (SSS.a_enable) {
+ debug('初始化,翻页模式.');
+ autoPO = new AutoPager(SSS, floatWO, document.URL, nextlink);
} else {
- if (obj.search(/^wildc;/i) === 0) {
- obj = wildcardToRegExpStr(obj.slice(6));
- }
- return new RegExp(obj);
+ debug('初始化,预读模式.');
+ prefetcher(SSS, floatWO, nextlink);
}
}
-function wildcardToRegExpStr(urlstr) {
- if (urlstr.source) return urlstr.source;
- var reg = urlstr.replace(/[()\[\]{}|+.,^$?\\]/g, "\\$&").replace(/\*+/g, function(str){
- return str === "*" ? ".*" : "[^/]*";
- });
- return "^" + reg + "$";
-}
-
SP.init();
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/meta.js b/Super_preloaderPlus/src/meta.js
index f0f620e9..b72c05bf 100644
--- a/Super_preloaderPlus/src/meta.js
+++ b/Super_preloaderPlus/src/meta.js
@@ -1,5 +1,5 @@
// ==UserScript==
-// @name Super_preloaderPlus_one
+// @name <%= pkg.name %>
// @namespace https://github.com/ywzhaiqi
// @description 预读+翻页..全加速你的浏览体验...
// @author ywzhaiqi && NLF(原作者)
@@ -34,14 +34,4 @@
// @exclude http://www.youku.com/
// @exclude http://v.youku.com/*
// @exclude http://www.iqiyi.com/*
-// ==/UserScript==
-
-
-// 主要用于 chrome 原生下检查更新,也可用于手动检查更新
-var scriptInfo = {
- version: '<%= pkg.version %>',
- updateTime: '<%= grunt.template.today("yyyy/m/d") %>',
- homepageURL: 'https://greasyfork.org/scripts/293-super-preloaderplus-one',
- downloadUrl: 'https://greasyfork.org/scripts/293-super-preloaderplus-one/code/Super_preloaderPlus_one.user.js',
- metaUrl: 'https://greasyfork.org/scripts/293-super-preloaderplus-one/code/Super_preloaderPlus_one.meta.js',
-};
\ No newline at end of file
+// ==/UserScript==
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/prefetcher.js b/Super_preloaderPlus/src/prefetcher.js
new file mode 100644
index 00000000..2bc7e706
--- /dev/null
+++ b/Super_preloaderPlus/src/prefetcher.js
@@ -0,0 +1,127 @@
+
+function prefetcher(SSS, floatWO, nextlink) {
+
+ function cContainer() {
+ var div = document.createElement('div');
+ var div2 = div.cloneNode(false);
+ var hr = document.createElement('hr');
+ div.style.cssText = '\
+ margin:3px!important;\
+ padding:5px!important;\
+ border-radius:8px!important;\
+ -moz-border-radius:8px!important;\
+ border-bottom:1px solid #E30005!important;\
+ border-top:1px solid #E30005!important;\
+ background-color:#F5F5F5!important;\
+ float:none!important;\
+ ';
+ div.title = '预读的内容';
+ div2.style.cssText = '\
+ text-align:left!important;\
+ color:red!important;\
+ font-size:13px!important;\
+ display:block!important;\
+ float:none!important;\
+ position:static!important;\
+ ';
+ hr.style.cssText = '\
+ display:block!important;\
+ border:1px inset #000!important;\
+ ';
+ div.appendChild(div2);
+ div.appendChild(hr);
+ document.body.appendChild(div);
+ return {
+ div: div,
+ div2: div2
+ };
+ }
+
+ floatWO.updateColor('prefetcher');
+
+ floatWO.updateColor('loading');
+ floatWO.CmodeIcon('show');
+
+ if (SSS.useiframe) {
+ var iframe = document.createElement('iframe');
+ iframe.name = 'superpreloader-iframe';
+ iframe.src = nextlink;
+ iframe.width = '100%';
+ iframe.height = '0';
+ iframe.frameBorder = "0";
+ iframe.style.cssText = '\
+ margin:0!important;\
+ padding:0!important;\
+ ';
+ iframe.addEventListener('load', function() {
+ var body = this.contentDocument.body;
+ if (body && body.firstChild) {
+ floatWO.updateColor('prefetcher');
+ floatWO.CmodeIcon('hide');
+ floatWO.loadedIcon('show');
+ this.removeEventListener('load', arguments.callee, false);
+
+ if (SSS.lazyImgSrc) {
+ handleLazyImgSrc(SSS.lazyImgSrc, body);
+ }
+ }
+ }, false);
+ if (SSS.viewcontent) {
+ var container = cContainer();
+ container.div2.innerHTML = 'iframe全预读: ' + '
' + '预读网址: ' + '' + nextlink + '';
+ iframe.height = '300px';
+ container.div.appendChild(iframe);
+ } else {
+ document.body.appendChild(iframe);
+ }
+ } else {
+ GM_xmlhttpRequest({
+ method: "GET",
+ url: nextlink,
+ overrideMimeType: 'text/html; charset=' + document.characterSet,
+ onload: function(req) {
+ var str = req.responseText;
+ var doc = createDocumentByString(str);
+ if (!doc) {
+ console.error('文档对象创建失败!');
+ return;
+ }
+
+ if (SSS.lazyImgSrc) {
+ handleLazyImgSrc(SSS.lazyImgSrc, doc);
+ }
+
+ var images = doc.images;
+ var isl = images.length;
+ var img;
+ var iarray = [];
+ var i;
+ var existSRC = {};
+ var isrc;
+ for (i = isl - 1; i >= 0; i--) {
+ isrc = images[i].getAttribute('src');
+ if (!isrc || existSRC[isrc]) {
+ continue;
+ } else {
+ existSRC[isrc] = true;
+ }
+ img = document.createElement('img');
+ img.src = isrc;
+ iarray.push(img);
+ }
+ if (SSS.viewcontent) {
+ var containter = cContainer();
+ var div = containter.div;
+ i = iarray.length;
+ containter.div2.innerHTML = '预读取图片张数: ' + '' + i + '' + '
' + '预读网址: ' + '' + nextlink + '';
+ for (i -= 1; i >= 0; i--) {
+ div.appendChild(iarray[i]);
+ }
+ }
+ floatWO.updateColor('prefetcher');
+ floatWO.loadedIcon('show');
+ floatWO.CmodeIcon('hide');
+ }
+ });
+ }
+}
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/rule.js b/Super_preloaderPlus/src/rule.js
index 071b9cdd..54f07b7a 100644
--- a/Super_preloaderPlus/src/rule.js
+++ b/Super_preloaderPlus/src/rule.js
@@ -1,5 +1,3 @@
-// rule.js
-
if (window.name === 'mynovelreader-iframe') {
return;
}
@@ -21,14 +19,11 @@ if (window.name === 'superpreloader-iframe') { // 搜狗,iframe里面怎么不
return;
}
-
// GM 兼容
-var GM_log = this.GM_log,
- GM_getValue = this.GM_getValue,
+var GM_getValue = this.GM_getValue,
GM_setValue = this.GM_setValue,
GM_registerMenuCommand = this.GM_registerMenuCommand,
GM_xmlhttpRequest = this.GM_xmlhttpRequest,
- GM_openInTab = this.GM_openInTab,
GM_addStyle = this.GM_addStyle;
gmCompatible();
@@ -58,6 +53,7 @@ var prefs={
sepStartN: 2, // 翻页导航上的,从几开始计数.(貌似有人在意这个,所以弄个开关出来,反正简单.-_-!!)
// 新增或修改的
+ forceTargetWindow: GM_getValue('forceTargetWindow', true), // 下一页的链接设置成在新标签页打开
debug: GM_getValue('debug', false),
enableHistory: GM_getValue('enableHistory', false), // 把下一页链接添加到历史记录
autoGetPreLink: false, // 一开始不自动查找上一页链接,改为调用时再查找
@@ -72,11 +68,6 @@ var blackList=[
// 'http://*.douban.com/*',
];
-blackList = blackList.concat(prefs.excludes.split(/[\n\r]+/).map(function(line) {
- return line.trim();
-}));
-
-
//在以下网站上允许在非顶层窗口上加载JS..比如猫扑之类的框架集网页.
var DIExclude = [
['猫扑帖子', true, /http:\/\/dzh\.mop\.com\/[a-z]{3,6}\/\d{8}\/.*\.shtml$/i],
@@ -178,6 +169,9 @@ var SITEINFO=[
if (elem.className != oClassName)
elem.className = oClassName;
});
+ },
+ filter: function() { // 添加内容到页面后
+
},
startFilter: function(win, doc) { // 只作用一次
// 移除 Google 重定向
@@ -2834,33 +2828,34 @@ var SITEINFO=[
}
}
},
- {name: 'SF在线漫画',
- url:/http:\/\/comic\.sfacg\.com\/HTML\/.+/i,
- siteExample:'http://comic.sfacg.com/HTML/HZDLQ/243/?p=2',
- preLink:{
- startAfter:'?p=',
- inc:-1,
- min:1,
- },
- nextLink:{
- startAfter:'?p=',
- mFails:[/http:\/\/comic\.sfacg\.com\/HTML\/.+\//i,'?p=1'],
- inc:1,
- isLast:function(doc,win,lhref){
- var pageSel=doc.getElementById('pageSel');
- if(pageSel){
- var s2os=pageSel.options;
- var s2osl=s2os.length;
- if(pageSel.selectedIndex==s2osl-1)return true;
- }
- },
- },
- autopager:{
- pageElement:'//img[@id="curPic"]',
- useiframe:true,
- replaceE: 'id("Pages")'
- }
- },
+ // 已失效
+ // {name: 'SF在线漫画',
+ // url:/http:\/\/comic\.sfacg\.com\/HTML\/.+/i,
+ // siteExample:'http://comic.sfacg.com/HTML/ZXCHZ/001/#p=2',
+ // preLink:{
+ // startAfter:'#p=',
+ // inc:-1,
+ // min:1,
+ // },
+ // nextLink:{
+ // startAfter:'#p=',
+ // mFails:[/http:\/\/comic\.sfacg\.com\/HTML\/.+\//i,'#p=1'],
+ // inc:1,
+ // isLast:function(doc,win,lhref){
+ // var pageSel=doc.getElementById('pageSel');
+ // if(pageSel){
+ // var s2os=pageSel.options;
+ // var s2osl=s2os.length;
+ // if(pageSel.selectedIndex==s2osl-1)return true;
+ // }
+ // },
+ // },
+ // autopager:{
+ // pageElement:'//img[@id="curPic"]',
+ // useiframe:true,
+ // replaceE: 'id("Pages")'
+ // }
+ // },
{name: '热血漫画',
url: /^http:\/\/www\.rexuedongman\.com\/comic\//i,
siteExample: 'http://www.rexuedongman.com/comic/2957/36463/index.html?p=2',
@@ -3498,8 +3493,11 @@ var SITEINFO=[
{name: "github 搜索",
url: "^https?://github\\.com/search",
nextLink: "//div[@class='pagination']/a[@rel='next']",
- pageElement: "id('code_search_results issue_search_results')|//div[@class='sort-bar']/following-sibling::*[following-sibling::span[@class='search-foot-note']]",
- insertBefore: "//div[@class='pagination']"
+ autopager: {
+ pageElement: "id('code_search_results issue_search_results')|//div[@class='sort-bar']/following-sibling::*[following-sibling::span[@class='search-foot-note']]",
+ insertBefore: "//div[@class='pagination']",
+ stylish: 'li.repo-list-item { text-align: left; }'
+ }
},
{
"url": "^https?://gist\\.github\\.com/",
@@ -3703,12 +3701,12 @@ var SITEINFO_comp=[
//分页导航的6个图标:
var sep_icons={
- top:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOjM3NkQ2MTFFOTUyNjExREZBNkRGOEVGQ0JDNkM0RDU3IiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOjM3NkQ2MTFGOTUyNjExREZBNkRGOEVGQ0JDNkM0RDU3Ij4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6Mzc2RDYxMUM5NTI2MTFERkE2REY4 RUZDQkM2QzRENTciIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6Mzc2RDYxMUQ5NTI2MTFERkE2 REY4RUZDQkM2QzRENTciLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz7bso/VAAACxElEQVR42rSUS0iUURTH//d+j9EppSRtCjEi w0EhjR6kIyUpWilFpbUTei1auMoellAQZFSbVrkQilplhZC9IKyNQg8CXVQKZigaOgojNdg3j++7 nTtjAzPqTI50Zu7ce+ec87vnnPtgQghIcZ3VxiGwGksRhomemwGHHKqRPwl6+ujFJXHvPLwWCUyN VT7qvZ4UtK7oQtQ8CizLUlt4fr4U6ctmExPyZ478LelcMMNIa3vL2nkrR7KnvEaR/auuZ2akeHMt f0SGsSvFSuk5rWOzs2RvXm6+zRJBDAx+8fUNfHjZfSNwMJ4fj6ekk9KU49hYuaXAZfs4/BzvhztR 6Nxmy85aXyl1SYFdjVrViuWrmqtLj9h7R18jKPwImD6CP0V5cY09fdnKZmmzKDA55Kqqrb2u4oR9 yNOHXz4PVEWDbtPhNSfR7+lGze46u6bp7dL2n8BkmMY4umrLj6XNCA8mfn4PQ3UdNgJzGzA28xnT 1giqdh4I2UqfuGAyYGTYUbH90JrMDAcbmuqFwlWCaiGoxQwomoCmc3z1vEV6RgrbUVTmkD7Sd+GI GVo25Ra7tjp3af3ud1C5Dk3VQ9FazI+gYkAlqKqzUP/J3Yn8vAI9N8dZIn2jUJG3olE7nJ214cGp /U2pMnVTmLCsIN4M3UMAXrj9g1B0AUXloAixb90Z0gtYpoBh+PD4xf2ZqemJ+p5bgSdRF4SMG0bd 31Ivt50MzxUYV463pchF3L/HaE5QjVNj4JzuocJw++5Vw/SLlFmEXTKojwbTgS+LqbfgZGmKAAzL S+Xg4ARTCc5VFhpLKEXIFn1B5E5OG+PUy4wkDCGorDHj8R+lBGAGI+iN2t3QIowlfO3ig+kjb1v4 9aI2u1lBv0Xj+GA1nlKel+q8BnANdBrCdZVNBiwXSRY8eam1PjNBxlMLZpvo2UxWOP6T/BFgAOBe 8h+hfm64AAAAAElFTkSuQmCC',
- bottom:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOjg2RjU3NUQzOTUyNjExREY4M0U4RDZGQThBMjcwMEIzIiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOjg2RjU3NUQ0OTUyNjExREY4M0U4RDZGQThBMjcwMEIzIj4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ODZGNTc1RDE5NTI2MTFERjgzRThE NkZBOEEyNzAwQjMiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6ODZGNTc1RDI5NTI2MTFERjgz RThENkZBOEEyNzAwQjMiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz6bp+ZPAAAC0UlEQVR42rRVXUhUQRT+5t67uzdZwwX/0FKS CCMiwcwi6QfpwcAgKHvzpR6EoKeQpIcIJCOCIB8SooIgKK2gssBwQ0PXsB8s8KdSIhFzXbHS2vbe ufdOM3fd1mx3zRUPezgzzDnfnP3mm7mEMYaVMAkrZEq8hZ0nHQEe0hepD3RfpJlLAhagtcfPgBBA sGWZzHbT4JEC2e4NON1UnbHkjoURiaDdf8kGpCELOncaMkF0FceKG5PnmPBVxSlBkom9iehemEN2 gYEt7/CEasLCiQKpihuLqSkhMLMAQ+ecCl5NMQ9vkqZm82glVkVZrSMy7uC5uyMT2UlCnFvV0CxY Fps7PN6t5IZMHLB4MpER4uph86jr5GFP1wUKZd7GjelpWSWH9lenqKpL8KoyDmbolt25afBoEnic uTBMand89uh1VeboYn71YcOvscmRxliquDf13V/i9T06sWtH+aqu8VuwJO2P3ITMUuUMPiagBoX3 w02oDje2rq3AE9/t0Fhg5LLAiM0xQ93w6JBv4H2/XpxZaXcrOBZRMVVIzAld1zmwDsPSUZi5Ha+G Oum74Z5uUZvo8MQ/PPiir2NiZjrENnr2gnJQkxIOqkLTdA5MYVoGCtKLEJieYO2997+Imr9kE0cV szyxvO35g9k0KQ+5KZtgaZgD1W0+s1avQwrx4K73hp0rav6VmxB9xKM2TKle1fqsJVjoKYObc6tr YdBUlwcFni1oab8WNAytSuRGb1QUJ5GO22Z+fq339rQGS/MP2LdNIU4UrdmHx13NwW8/pupFTlJv BbeGsclP294OvawoXV/pkoiC1/3d2ujEx6di7X+fzc/ccxaoREiN9A32Ijsn/Dq+GfCJmkruNAbe OPf8MHD0LPNqqurivEbiFyav5shmOd7709TckBeTCsJvQ0vf+aS+GIeLTiXmeGFC8p+mqMz8V+6c y1oWGoE/MvwtwABuklC1izbNcAAAAABJRU5ErkJggg==',
- pre:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOkUzRDUyNEQ5OTBFMjExREZCMjNFRjQzNkMwMjdFNUMwIiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOkUzRDUyNERBOTBFMjExREZCMjNFRjQzNkMwMjdFNUMwIj4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6RTNENTI0RDc5MEUyMTFERkIyM0VG NDM2QzAyN0U1QzAiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6RTNENTI0RDg5MEUyMTFERkIy M0VGNDM2QzAyN0U1QzAiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz6I8cyJAAAC20lEQVR42tRVW0hUURTd+5xz550PVMwcUksJ JY2wrMHpoxQzQrFRxF5iGn1EERGEZCBI9OFPUR9ZkNRX0a9fkeBPEhFBP1mDFj0xdVTSqXnce8/p 3Gtjvh+IH53LZu6Bc9dZe+2196AQAtZjEVinxWIv3stsqXM3ATG+16E1iVbBVwUsOC525pI7dfNp gRApDnxulvvrq5KCoFgoKhLjktsOeWud5d7qhHhX0lnPBaVqVcA6J3Njp9224ZGvtMHhD7yE/vFe UlN+PM0V52jPr6WFKwbmTJ0ZbsZYt6+k0RkIfYLByX74HvTDYLSP1FQe25KYpTzYtJel25LQ1A+T ERcFtgenw8U47anaX5+AFh0+BN6AwizAKAX/2HPQ7OPEV+HLzSyGu1YH2JOyFSICQmi6RhYEThkx g6oO1lXuqctIS0kn74deACOKGZwIQCn62/GnkJaZggdLDpdlVyo3RgdU0yU4x7nTu8EsasQdT36Z Jz9nt9L3oxcoMqASFOQvF5p0HKDOBbwaeUJ2FBTQosI9ddtPWq4Z30vGuCCwEORiXkbRiZJdR6zv JFMBXILSKXAkQlWjgmuyFrqA4K/f0PO1E0u9B5w52zaecleQRkZm9wHGWvpoe17oTFWLjVKZtkTQ JcNu/0NQ9bAIa5M4HBkAq5MKi41gdW6L5A1E6MgnJkbVjse3hz6+Dp379ox3zWuQL8P9tqv3GqbS YBhua+qUEER6maIajchUZQZRQwyZi4bYeqs59DMobPKI1UrRHZcB5+Wn84FN/WPW04RsNDSl0KSn VflwWSNNFo8LRF0Thoa2gfucLNvScxdKKkalDdbGnbLluRrhhArCNVUnBNcw3fCv7xVqMc8a40eL cIxGVHkhrn1s2hWXwdkQybAP6sYNywAvOSv3ba2VM0OTOqswGR4DlUdiXjL4rxB4NvehKx31qf+2 YmZtwXQo4siSMv53f03rBvxHgAEAqLoqsgGSMo4AAAAASUVORK5CYII=',
- next:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOkY3M0ZDRTgzOTBFMjExREZCNjlFQUY1QUIyNjQ1NzE3IiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOkY3M0ZDRTg0OTBFMjExREZCNjlFQUY1QUIyNjQ1NzE3Ij4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6RjczRkNFODE5MEUyMTFERkI2OUVB RjVBQjI2NDU3MTciIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6RjczRkNFODI5MEUyMTFERkI2 OUVBRjVBQjI2NDU3MTciLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz6Q0swTAAAC50lEQVR42tRVXUhUQRQ+M/dnd0sN/1gtAimW LXsoiAixFyGIHnqNioioh36ghyh6sCAijAgiIoLowSRMBG1b1n5s0XxRtiyRlIpQ1M1sKxV1XffH e2emM+u6qG11EXzoXM6de2fOfPeb8x3OJUIIWAmjsEKmzj+UndeWrv0kAgoJWTglT0cW0vqB96L5 144bxu/Ac5sWWeHpQxfT0xq1QbY9D1SqgUJVHHWovHfE+U/GU5Mc1uQoi1cFgYbua8mPErxK8reC Q8sGm+qACtdh6zmejnLEEGlXCC4TTAiGSeiYEVm+eGMRDhxBpes2DVQbFWQuihtsdu4gFiopY1WM T0tgEKqmCFUnVEuCCypTwgWXdwTnloH96CylIsdtcUUloNspqDpFdAoaXhKQcYZBAqhK4ql4sVT9 tHjhINzZsN3uPnngjDMnJ18jinAQEFy3KXIQzBBE023ImOEbJ5L51eM1dooVwpgB971V8YyMgy/M 5wMfYlcantaNJ8yI8H+7LXzDVRSrSlAFiKJRITVk3ERQA9r6auF10AfRRBjqW+7Ghsf6KzMCm9yU Q3Xf5+8PWtpfzVSsPyayVq8CioSRFGiaTpAruplMBc7CZmcZtL57kvgY7KzFvbcyAquKKoLeJPil zq439e97etiOwv1coURWnqAE0ZOgBkjw0qJy6O17awR6/YHiQXZq7ZCRWTyptOpUIBQQtN9nnH3Z +swfGhoVW3L3yBQTygmeykj6JmQaGh3hzYH6oBY196VE/2NV8FQj4IkoxIY64ISnyfNJjeVyd94u MBkDw5yFjQXbQMwq4G17OGlSVoHxESt1LBaMIxODxtFGX91AsV7K12W5oTjbBQWOEvC0Vs+Yprkb Y74ut212RcLRC43Nj0Ku3HLuLtgJnpaaaCw+fRDXui21zb+YdyoyXtrc/vgcdg3bRHjsMurZZLkf L7XQXgahdOrhevnoFxeWxxTKcNNKEyL/3a9pxYB/CTAALMFZuEnI1jsAAAAASUVORK5CYII=',
- next_gray:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOjg1RDA5RjFGOTUyMjExREZCMkM4QUZEOEY4Qzg2MDREIiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOjg1RDA5RjIwOTUyMjExREZCMkM4QUZEOEY4Qzg2MDREIj4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6ODVEMDlGMUQ5NTIyMTFERkIyQzhB RkQ4RjhDODYwNEQiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6ODVEMDlGMUU5NTIyMTFERkIy QzhBRkQ4RjhDODYwNEQiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz62tt8rAAACiUlEQVR42tRVS6tSURTe5/hWFAderhoIKqmI U2eCBg2a9AOaBQ4iZxE0yCCcNYkGDYWaNEh8ICQpoYg4CJQIFA0chKGpBb7A9+Oc1jp4LnK12+GC gxYs1j7stb79rcfeh2JZlpxCaHIiEfMLj8dzee836NlVwRRF/QKj57+LxeIh8BE5CwQChC+VRCIh arWaiEQiTsViMQkGg+f/ZDyfz4lcLj9wiEajF2uz2UwUCgWRyWTE5/MJr/FqteIY8gqporI7SxaL xfWbt1wuL4ClUimWgAMGYdbrNecjZJKOTgWCYzzUkYV60mh53/2MhAJ/At1iLLIDXWCTsGkATGGz aJomDMOQ7XbLAcP+YufP62HzRqPRa5PJZPf7/edarVYC6SvwAADGOrAARmHTABgwWQqBQ6GQHA/f bDYkHA4vjjJuNBofO51OKB6P96FJbDabZVOpFA2BLDBFxlhr7gBknM/nSalUIrPZjEQikXm73X56 FBhPBXnTbDbfFgqFqdfrZVUqFZc+KjIHthRfCmyow+EguVxuWavV3kHsq6PAyKher+PyWblcfl+p VLZut5tBUMwdU0ZQJIDW6XSSarW6/gwyGAwe9vv94xcEa6bRaIhSqaRhrB4B0A24aXdcLhcFKXM1 RVA8AJn2ej0mnU7/gNm/u2v6X6cCJ4Hazeu81Wo9SCaT3yATxm63c+njHFssFo4x7I3A9xboRMgc s3v2J6R3PxaLfdfr9YzRaCQGg4HodDqSSCSmwP42+LSv+2x+mUwmTwCoa7PZGFAEnU2n03uw91XQ s3mFJMfjsTOTyTyGtWw4HD4H+0Hwe3xZrFbr/ueLbrd7Exo4hvVLIY8Q9d/9mk4G/EeAAQCBEkva rHrRPgAAAABJRU5ErkJggg==',
- pre_gray:' bWFnZVJlYWR5ccllPAAAAyBpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdp bj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6 eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEz NDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJo dHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlw dGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAv IiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RS ZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpD cmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzIiB4bXBNTTpJbnN0YW5jZUlE PSJ4bXAuaWlkOjc0MTI5MDY4OTUyMjExREZCODVDREYyM0U0QjMzQkQzIiB4bXBNTTpEb2N1bWVu dElEPSJ4bXAuZGlkOjc0MTI5MDY5OTUyMjExREZCODVDREYyM0U0QjMzQkQzIj4gPHhtcE1NOkRl cml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6NzQxMjkwNjY5NTIyMTFERkI4NUNE RjIzRTRCMzNCRDMiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NzQxMjkwNjc5NTIyMTFERkI4 NUNERjIzRTRCMzNCRDMiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1l dGE+IDw/eHBhY2tldCBlbmQ9InIiPz5D2F5XAAACZklEQVR42tSVz6sSURTH7x0VJxX8CampSQtF /AESConiQkhdlKKCLdr0YxW0iDaBSBLZok3tol27/oC3TcS14EpEBV24UOO5EETLn9M5g4KoPXu9 XHTgMNc7537me7/3zEg5jiOnCIacKISbQSAQuKjuI6VULhAInhSLxdWlFKMlv8mXer3+qU6nu79c Ll/9KyvuKZXKN9FoVBqJRBRyufyZz+eLXxXslkqlXxOJhKTZbBJIBsY6mUz23uFw3P5bsEEoFH4D kHQwGJBer0e63S7p9/tMKpW6pVarv5hMphsSiYRi8eZ6EDybzTYpg5/FeDyuYBiGtNttIhKJCBwc aTQaZLFYMHDPZjQaP8P8NY1Gw0wmEw7nD4LH4zGmQCwWn4GnN7VaLVOv13kgqCfQFZhctVolcJg0 HA7ftdlsH2BHfJfg/YNglUqF+ekOhNPpFNVqNYKKEYpX6AhcTFerFSmXy4zL5RJ4PJ4Hbrf7La4H xfQgGNa8sNvtD0OhkBiVYquhWoRCcvP5nEMoJu6uVCrRYDAoNZvNj6xW62MUcPAFMRgM79LpNIsF Xq+XBxQKBYQjlIIifgzKaSwWw+0z8HCaTCbVw+HwtcViOW+1Wmd74E6nw2azWX4MgJ+5XI5F30At nU6n/IM220VgPp//AfNYI4Yag0KheA639sHoxmYAqjiEohXo7RrKHx5CcQ6CrVQqzNFvxW6su2D7 tFfrllrtttalX+kNFPt47SlBv7Hfd9vrjxVvB8uyZOu7jX5cDez3+3mPMUejEard281R8E7h90wm c/3IRs4vtPG/+2s6GfiXAAMAq3cXTADTBMIAAAAASUVORK5CYII=',
+ top:'',
+ bottom:'',
+ pre:'',
+ next:'',
+ next_gray:'',
+ pre_gray:'',
};
//悬浮窗的状态颜色.
@@ -3788,4 +3786,8 @@ var nextPageKey=[
// 出在自动翻页信息附加显示真实相对页面信息,一般能智能识别出来。如果还有站点不能识别,可以把地址的特征字符串加到下面
// 最好不要乱加,一些不规律的站点显示出来的数字也没有意义
-var REALPAGE_SITE_PATTERN = ['search?', 'search_', 'forum', 'thread'];
\ No newline at end of file
+var REALPAGE_SITE_PATTERN = ['search?', 'search_', 'forum', 'thread'];
+
+
+//------------------------下面的不要管他-----------------
+///////////////////////////////////////////////////////////////////
\ No newline at end of file
diff --git a/Super_preloaderPlus/src/setting.js b/Super_preloaderPlus/src/setting.js
new file mode 100644
index 00000000..30b2f4f0
--- /dev/null
+++ b/Super_preloaderPlus/src/setting.js
@@ -0,0 +1,158 @@
+// 主要用于 chrome 原生下检查更新,也可用于手动检查更新
+var scriptInfo = {
+ version: '<%= pkg.version %>',
+ updateTime: '<%= grunt.template.today("yyyy/m/d") %>',
+ homepageURL: 'https://greasyfork.org/scripts/293-super-preloaderplus-one',
+ downloadUrl: 'https://greasyfork.org/scripts/293-super-preloaderplus-one/code/Super_preloaderPlus_one.user.js',
+ metaUrl: 'https://greasyfork.org/scripts/293-super-preloaderplus-one/code/Super_preloaderPlus_one.meta.js',
+};
+
+var setup = function(){
+ var d = document;
+ var on = function(node, e, f) {
+ node.addEventListener(e, f, false);
+ };
+
+ var $ = function(s) { return d.getElementById('sp-prefs-'+s); };
+ if($('setup')) return;
+
+ var styleNode = GM_addStyle('\
+ #sp-prefs-setup { position:fixed;z-index:2147483647;top:30px;right:60px;padding:20px 30px;background:#eee;width:500px;border:1px solid black; }\
+ #sp-prefs-setup * { color:black;text-align:left;line-height:normal;font-size:12px; }\
+ #sp-prefs-setup a { color:black;text-decoration:underline; }\
+ #sp-prefs-setup div { text-align:center;font-weight:bold;font-size:14px; }\
+ #sp-prefs-setup ul { margin:15px 0 15px 0;padding:0;list-style:none;background:#eee;border:0; }\
+ #sp-prefs-setup input, #sp-prefs-setup select { border:1px solid gray;padding:2px;background:white; }\
+ #sp-prefs-setup li { margin:0;padding:6px 0;vertical-align:middle;background:#eee;border:0 }\
+ #sp-prefs-setup button { width:150px;margin:0 10px;text-align:center;}\
+ #sp-prefs-setup textarea { width:98%; height:60px; margin:3px 0; }\
+ #sp-prefs-setup b { font-weight: bold; font-family: "微软雅黑", sans-serif; }\
+ #sp-prefs-setup button:disabled { color: graytext; }\
+ ');
+
+ var div = d.createElement('div');
+ div.id = 'sp-prefs-setup';
+ d.body.appendChild(div);
+ div.innerHTML = '\
+ Super_preloaderPlus_one 设置
\
+ \
+ ';
+ div = null;
+
+ var close = function() {
+ if (styleNode) {
+ styleNode.parentNode.removeChild(styleNode);
+ }
+ var div = $('setup');
+ div.parentNode.removeChild(div);
+ };
+
+ on($('ok'), 'click', function(){
+ GM_setValue('enableHistory', prefs.enableHistory = !!$('enableHistory').checked);
+ GM_setValue('forceTargetWindow', prefs.forceTargetWindow = !!$('forceTargetWindow').checked);
+ GM_setValue('SITEINFO_D.useiframe', SITEINFO_D.useiframe = !!$('SITEINFO_D-useiframe').checked);
+ GM_setValue('SITEINFO_D.autopager.enable', SITEINFO_D.autopager.enable = !!$('SITEINFO_D-a_enable').checked);
+ GM_setValue('SITEINFO_D.autopager.force_enable', SITEINFO_D.autopager.force_enable = !!$('SITEINFO_D-a_force_enable').checked);
+
+ GM_setValue('debug', xbug = !!$('debug').checked);
+ debug = xbug ? console.log.bind(console) : function() {};
+
+ GM_setValue('dblclick_pause', $('dblclick_pause').checked);
+ GM_setValue('excludes', prefs.excludes = $('excludes').value);
+ GM_setValue('custom_siteinfo', prefs.custom_siteinfo = $('custom_siteinfo').value);
+
+ SP.loadSetting();
+
+ close();
+ });
+
+ on($('cancel'), 'click', close);
+
+ $('debug').checked = xbug;
+ $('enableHistory').checked = prefs.enableHistory;
+ $('forceTargetWindow').checked = prefs.forceTargetWindow;
+ $('dblclick_pause').checked = GM_getValue('dblclick_pause') || false;
+ $('SITEINFO_D-useiframe').checked = SITEINFO_D.useiframe;
+ $('SITEINFO_D-a_enable').checked = SITEINFO_D.autopager.enable;
+ $('SITEINFO_D-a_force_enable').checked = SITEINFO_D.autopager.force_enable;
+ $('excludes').value = prefs.excludes;
+ $('custom_siteinfo').value = prefs.custom_siteinfo;
+
+};
+
+var isUpdating = true;
+function checkUpdate(button) {
+ if (isUpdating) {
+ return;
+ }
+
+ button.innerHTML = '正在更新中...';
+ button.disabled = 'disabled';
+
+ var reset = function() {
+ isUpdating = false;
+ button.innerHTML = '马上更新';
+ button.disabled = '';
+ };
+
+ GM_xmlhttpRequest({
+ method: "GET",
+ url: scriptInfo.metaUrl,
+ onload: function(response) {
+ var txt = response.responseText;
+ var curVersion = scriptInfo.version;
+ var latestVersion = txt.match(/@\s*version\s*([\d\.]+)\s*/i);
+ if (latestVersion) {
+ latestVersion = latestVersion[1];
+ } else {
+ alert('解析版本号错误');
+ return;
+ }
+
+ //对比版本号
+ var needUpdate;
+ var latestVersions = latestVersion.split('.');
+ var lVLength = latestVersions.length;
+ var currentVersion = curVersion.split('.');
+ var cVLength = currentVersion.length;
+ var lV_x;
+ var cV_x;
+ for (var i = 0; i < lVLength; i++) {
+ lV_x = Number(latestVersions[i]);
+ cV_x = (i >= cVLength) ? 0 : Number(currentVersion[i]);
+ if (lV_x > cV_x) {
+ needUpdate = true;
+ break;
+ } else if (lV_x < cV_x) {
+ break;
+ }
+ }
+
+ if (needUpdate) {
+ alert('本脚本从版本 ' + scriptInfo.version + ' 更新到了版本 ' + latestVersion + '.\n请点击脚本主页进行安装');
+ document.getElementById("sp-prefs-homepageURL").boxShadow = '0 0 2px 2px #FF5555';
+ }
+
+ reset();
+ }
+ });
+
+ setTimeout(reset, 30 * 1000);
+}