您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Changes 'Continue this thread' links to insert the linked comments into the current page
当前为
// ==UserScript== // @name Reddit - Load 'Continue this thread' inline // @description Changes 'Continue this thread' links to insert the linked comments into the current page // @author James Skinner <[email protected]> (http://github.com/spiralx) // @namespace http://spiralx.org/ // @version 1.2.1 // @icon  // @icon64  // @match *://*.reddit.com/r/*/comments/* // @grant GM_addStyle // @grant GM_getResourceURL // @run-at document-end // @resource expand  // @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.js // @require https://greasyfork.org/scripts/7602-mutation-observer/code/mutation-observer.js // ==/UserScript== /* jshint asi: true, esnext: true */ /* global jQuery, MutationSummary, GM_addStyle, GM_getResourceURL */ ; (function($) { 'use strict'; // -------------------------------------------------------------------- const units = (v, s) => `${v}${s}` $.fn.spinner = function(options) { options = Object.assign({}, $.fn.spinner.defaults, options) const $spinner = $('<div class="pulsar-horizontal"></div>') .css({ padding: units(options.size * 0.25, 'px'), height: units(options.size, 'px') }) const total_duration = (options.steps + 1) * options.step_duration for (let i = 0; i < options.steps; i++) { const delay = i * options.step_duration $('<div></div>') .css({ width: units(options.size, 'px'), height: units(options.size, 'px'), backgroundColor: options.colour, animationDuration: units(total_duration, 's'), animationDelay: units(delay, 's') }) .appendTo($spinner) } if (options.replace) { this.empty() } return this.append($spinner) } $.fn.spinner.defaults = { replace: false, steps: 3, size: 16, colour: 'white', step_duration: 0.4 } // -------------------------------------------------------------------- function processSpans($spans) { $spans.children('a') .one('click', continueThisThreadClicked) $spans.parent() .css('padding', '0px') $spans.prev() .remove() } function continueThisThreadClicked(event) { /* jshint -W040 */ this.hostname = location.hostname let $a = $(this), href = this.href, $target = $a.parent() $target.spinner({ colour: '#28f', size: 24, step_duration: 0.25, replace: true }) $.get(href, function(data) { const $child = $('.nestedlisting > .comment > .child', $(data)) .css('margin-left', '0px') $target .parentsUntil('.child') .replaceWith($child) }) return false } // -------------------------------------------------------------------- const observer = new MutationSummary({ callback(summaries) { let $spans = $(summaries[0].added) // console.log(`Added ${$spans.length} spans`) processSpans($spans) }, rootNode: document.body, queries: [ { element: 'span.deepthread' } ] }) processSpans($('span.deepthread')) // To process spans in the HTML source // -------------------------------------------------------------------- GM_addStyle(` .deepthread { display: block; padding: 0; } .deepthread:after { display: none !important; } .deepthread a { display: block; background: transparent url(${GM_getResourceURL('expand')}) no-repeat center left; padding-left: 40px; height: 40px; line-height: 40px; font-size: 1.4rem; vertical-align: middle; } .deepthread a:hover { background-color: rgba(0, 105, 255, 0.05); } .pulsar-horizontal { display: inline-block; } .pulsar-horizontal > div { display: inline-block; border-radius: 100%; animation-name: pulsing; animation-timing-function: ease-in-out; animation-iteration-count: infinite; animation-fill-mode: both; } @keyframes pulsing { 0%, 100% { transform: scale(0); opacity: 0.5; } 50% { transform: scale(1); opacity: 1; } } `) })(jQuery) jQuery.noConflict()