Greasy Fork is available in English.
【非自动关注】【自用,长期维护】【功能有】1. 阅读全文网站支持:CSDN、github.io、xz577.com、iteye.com、720ui.com、cloud.tencent.com、##、头条、网易新闻、腾讯新闻、51CTO、知乎
Устаревшая версия за
// ==UserScript==// @name 阅读全文、自动展开全文、自动移除万恶弹框// @namespace http://tampermonkey.net/// @version 2.0// @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js// @description 【非自动关注】【自用,长期维护】【功能有】1. 阅读全文网站支持:CSDN、github.io、xz577.com、iteye.com、720ui.com、cloud.tencent.com、##、头条、网易新闻、腾讯新闻、51CTO、知乎// @author zhengmingliang// @match https://*.csdn.net/*// @match *://*.github.io/*// @match *://*.xz577.com/*// @match *://*.iteye.com/*// @match *://*.720ui.com/*// @match *://cloud.tencent.com/*// @match *://*.didispace.com/*// @match *://*.sina.cn/*// @match *://*.toutiao.com/*// @match *://*.163.com/*// @match *://*.qq.com/*// @match *://*.*.qq.com/*// @match *://blog.51cto.com/*// @match *://*.zhihu.com/question/*// @grant none// ==/UserScript==(function () {'use strict';/*** 阅读全文 规则1(openwrite.cn 插件规则)* @param readMoreSelector* @param contentSelector*/function readAllRule1(readMoreSelector, contentSelector) {if ($(readMoreSelector).length > 0) {console.log("检测到有阅读全文关注限制。。。。")// 移除阅读全文$(readMoreSelector).parent().remove();// 使滚动条可见// $("#article_content").css('overflow','auto')// 优化后:直接将style置为空console.log("style:%s", $(contentSelector).prop('style'))$(contentSelector).prop('style', '')$(contentSelector).attr('style', '')console.log("已解除阅读全文关注限制。。。。")}}/*** 阅读全文 规则1(openwrite.cn 插件规则)* @param readMoreSelector* @param contentSelector*/function readAllRule1ByOrigin(readMoreSelector, contentSelector) {var dom;var parentElement, contentElement;if (readMoreSelector.startsWith("#")) {dom = document.getElementById(readMoreSelector.substring(1))parentElement = dom.parentElement;} else if (readMoreSelector.startsWith(".")) {dom = document.getElementsByClassName(readMoreSelector.substring(1))if (dom.length > 0) {parentElement = dom[0].parentElement;}} else {dom = document.getElementsByTagName(readMoreSelector)parentElement = document.getElementsByClassName(readMoreSelector)[0].parentElement;}if (contentSelector.startsWith("#")) {contentElement = document.getElementById(contentSelector.substring(1))contentElement.style = ''} else if (contentSelector.startsWith(".")) {contentElement = document.getElementsByClassName(contentSelector.substring(1))contentElement[0].style = ''} else {contentElement = document.getElementsByTagName(contentSelector)contentElement[0].style = ''}console.log(111)parentElement.parentElement.removeChild(parentElement);}/*** 规则2:移除指定标签的某个class样式* @param readMoreSelector* @param removeSelector* @param removeClass*/function readAllRule2(readMoreSelector, removeSelector, removeClass) {if ($(readMoreSelector).length > 0) {console.log("检测到有阅读全文关注限制。。。。")// 移除阅读全文$(readMoreSelector).remove();// 使滚动条可见// $("#article_content").css('overflow','auto')// 优化后:直接将style置为空$(removeSelector).removeClass(removeClass)console.log("已解除阅读全文关注限制。。。。")}}/*** 直接点击展开* @param clickSelector*/function readAllRule3(clickSelector) {var selector = $(clickSelector);if (!selector) {selector = jQuery(clickSelector);}if (selector.length > 0) {console.log("检测到有阅读全文关注限制。。。。")// 点击展开selector.trigger("click")console.log("已解除阅读全文关注限制。。。。")}}/*** 使用openwrite.cn策略的个人博客或其他使用类似的规则*/function readAllRule4(removeSelector) {console.log("检测到有阅读全文关注限制。。。。")// 移除阅读全文$(removeSelector).parent().remove();var zIndexArray = [];var parentSelector = "div[style]"if ($("article[style]").length > 0) {parentSelector = "article[style]"}var flag = false//存放只有height属性的节点let heightArray = [];findElements();if (flag) {console.log("已解除阅读全文关注限制。。。")} else {if (parentSelector == "div[style]" && heightArray.length == 1) {heightArray[0].prop("style", "")console.log("已解除阅读全文关注限制。。。。")} else {parentSelector = "div[style]"heightArray = [];findElements();if (heightArray.length == 1) {heightArray[0].prop("style", "")console.log("已解除阅读全文关注限制。。。。。")}}}function findElements() {$(parentSelector).each(function (index) {var attr = $(this).attr('style');if (attr.indexOf("overflow") != -1 && attr.indexOf("height") != -1) {var overflow = $(this).css("overflow");if ('hidden' == overflow) {$(this).prop("style", "")flag = true}} else if (attr.indexOf("height") != -1) {console.log("index:", index, $(this))heightArray.push($(this))}let text = $(this).text();if (attr.indexOf("z-index") != -1 && (text.indexOf("首次访问") != -1 || text.indexOf("人机检测") != -1)) {let zIndex = $(this).css("z-index");console.log("zIndex:", zIndex)let lastDiv = $("div[style]").filter(function () {return $(this).attr('style').indexOf("z-index") != -1 && $(this).css("z-index") == zIndex - 1})console.log("lastDiv:", lastDiv)if (lastDiv && lastDiv.length > 0) {lastDiv.remove();}}})}}/*** java学习 javazhiyin.com*/function removeFirstLayer() {if ($(".layui-layer-page").length > 0) {var text = $(".layui-layer-page").text();if (text.indexOf('首次访问') != -1 || text.indexOf('人机识别')) {}$(".layui-layer-page").remove();$(".layui-layer-shade").remove();}$("div[index]")}function removeAlertRule1() {$("div[style]").each(function (index) {let attr = $(this).attr('style');let text = $(this).text();if (attr.indexOf("z-index") != -1 && (text.indexOf("首次访问") != -1 || text.indexOf("人机检测") != -1)) {let zIndex = $(this).css("z-index");console.log("zIndex:", zIndex)let lastDiv = $("div[style]").filter(function () {return $(this).attr('style').indexOf("z-index") != -1 && $(this).css("z-index") == zIndex - 1})console.log("lastDiv:", lastDiv)if (lastDiv && lastDiv.length > 0) {lastDiv.remove();}$(this).remove();$('body').css("overflow", 'auto');}})}/*** 公共阅读全文规则1: 查找当前页面所有div接单,判断其style属性是否包含特征值*/function commonReadAllRule1() {$("div").each(function (index) {let attr = $(this).attr('style');if(attr){if (attr.indexOf("height") != -1 && attr.indexOf("overflow") != -1 && attr.indexOf("hidden") != -1) {let id = $(this).attr('id');let cls = $(this).attr('class');let founded = false;if(id){console.log("检测到隐藏了全文的id:%s",id)founded = true}if(cls){console.log("检测到隐藏了全文的class:%s",cls)founded = true}if(founded){$(this).prop('style','')$(this).attr('style','')}}}})}/*** 公共移除dom节点*/function commonRemoveRules1(selectors,isRemoveParent) {if ('string' == typeof (selectors)) {return commonRemoveRule1(selectors,isRemoveParent)}else {for (let index in selectors) {commonRemoveRule1(selectors[index],isRemoveParent)}}}/*** 公共查找节点名称*/function commonFindRules1(keys) {let split = keys.split(",");let selector = $("div").filter(function (){let text = $(this).text();let flag = false;for (let i in split) {flag = text.indexOf(split[i]) && flag ;}return flag && $(this).children().length == 0})let id = selector.attr("id");if(id){return "#"+id;}let cls = selector.attr("class");if(cls){return "."+cls;}return selector;}function commonRemoveRule1(selector,isRemoveParent) {var $selector = $(selector);if($selector.length > 0){if(isRemoveParent){$selector.parent().remove();}else {$selector.remove();}}}var $ = $ || window.$ || jQuery;var href = window.location.hreffunction intervalReadAllRule2(checkSelector, removeSelector, removeClass) {let interval = setInterval(function () {console.log("轮训检测...")if ($(checkSelector).length > 0) {readAllRule2(checkSelector, removeSelector, removeClass)clearInterval(interval)}}, 1000)}// csdnif (href.indexOf('csdn') != -1) {console.log("检测到CSDN。。。。")// 已登录readAllRule1("#btn-readmore-zk", "#article_content")// 未登录readAllRule1(".btn-readmore", "#article_content")// 移动端处理readAllRule1(".btn_mod", ".article_content")} else if (href.indexOf('github.io') != -1) { //hoxis.github.ioconsole.log("检测到github.io。。。。")readAllRule1("#read-more-btn", "#container")} else if (href.indexOf('xz577') != -1) { //www.xz577.comconsole.log("检测到xz577。。。。")readAllRule1(".m-zk", "#mewsmian")// Your code here...} else if (href.indexOf('cloud.tencent.com') != -1) { //cloud.tencent.comconsole.log("检测到tencent。。。。")readAllRule2(".com-markdown-collpase-toggle", ".com-markdown-collpase-hide", "com-markdown-collpase-hide")// Your code here...} else if (href.indexOf('iteye.com') != -1) { //iteye.comconsole.log("检测到iteye.com。。。。")readAllRule3("#btn-readmore")// Your code here...} else if (href.indexOf('720ui.com') != -1) { // 720ui.comconsole.log("检测到720ui.com。。。。")readAllRule1("#read-more-btn", "#main")} else if (href.indexOf('sina.cn') != -1) { // k.sina.cnconsole.log("检测到sina.cn。。。。")let interval = setInterval(function () {console.log("轮训检测...")if ($(".foldBtn").length > 0) {readAllRule1ByOrigin(".foldBtn", ".s_card z_c1")clearInterval(interval)}}, 1000)} else if (href.indexOf('toutiao') != -1) { // toutiao.comconsole.log("检测到toutiao。。。。")// 循环检测intervalReadAllRule2(".fold-btn", ".fold-btn-content", "fold-btn-content-fold");// document.removeEventListener('click',getEventListeners($(document).get(0)).click[0].listener)} else if (href.indexOf('163.com') != -1) { // 3g.163.comconsole.log("检测到163.com。。。。")// 循环检测let interval = setInterval(function () {console.log("轮训检测...")if ($(".expand_more").length > 0) {readAllRule1(".expand_more", "article")clearInterval(interval)}}, 1000)} else if (href.indexOf('wx.qq.com') != -1) { // wx.qq.comconsole.log("检测到wx.qq.com。。。。")// 循环检测intervalReadAllRule2("div[aria-label]", "#article_body", "jsx-2375966888");$("#article_body").prop("style","margin:0 0.18rem; position:relative")} else if (href.indexOf('inews.qq.com') != -1) { // inews.qq.comconsole.log("检测到inews.qq.com。。。。")// 循环检测let interval = setInterval(function (){console.log("轮训检测...")if($("._1mAOD6Nkgp2wM7xlGCHeNi").length > 0){commonRemoveRules1(["._1mAOD6Nkgp2wM7xlGCHeNi","._1GTaS1LTuTrKnZ-oQ6KFRG"],true)commonReadAllRule1()clearInterval(interval)}},1000)} else if (href.indexOf('51cto.com') != -1) { // blog.51cto.comconsole.log("检测到blog.51cto.com。。。。")// 循环检测/*$(document).scroll(function (){let count = 0;console.log("轮训检测")let interval = setInterval(function (){if($("#login_iframe_mask").length > 0){console.log("已清理登录弹框")$("#login_iframe_mask").remove();clearInterval(interval)}if( count ++ > 10){count = 0;clearInterval(interval)}},1000)})*/// modify by zml 2020年10月31日 23:07:07 将原来监听是否有元素方式改为页面中添加css样式的方式来更好的解决弹框不停弹出的问题$("style").get(0).append("#login_iframe_mask{display:none}");} else if (href.indexOf('zhihu.com') != -1) { // blog.51cto.comconsole.log("检测到zhihu.com。。。。")let count = 0;let interval = setInterval(function (){if(".ModalWrap-body".length > 0){$(".ModalWrap-body").prop("style","").removeClass("ModalWrap-body")}if($(".RichContent-inner").length > 0){$(".RichContent-inner").prop("style","").removeClass("RichContent-inner").removeClass("RichContent-inner--collapsed")}if ($(".expandButton").length > 0) {console.log("移除阅读全文")$(".expandButton").remove()}if(count++ > 100){clearInterval(interval);}},1000)$("style").get(0).append(".ModalWrap{display:none}");} else if ($("#read-more-btn").length > 0) {console.log("检测到可能使用了openwrite推广工具。。。。")readAllRule4("#read-more-btn");} else if ($(".mask").length > 0 && $(".info").length > 0) { // cmsblogs.comconsole.log("检测到%s。。。。", href)readAllRule4(".info");} else if (href.indexOf("iocoder") != -1) {setInterval(removeAlertRule1(), 10000);} else if (href.indexOf("javazhiyin") != -1) {// 每隔10s移除弹出的关注检测弹框setInterval(removeFirstLayer(), 10000)} else {}})();