您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
🔥所有网页均支持划词搜题,也可输入文本搜题🔥悬浮窗可拖动可关闭,可个性化设置🔥解除网页禁止复制限制🔥🔥🔥适用于各类问答,网课问题,竞赛问题,专业术语,业务名称,情景问题,在线作业等
当前为
// ==UserScript== // @name 题海 x 划词搜题 // @namespace 题海官方团队 // @version 1.0.0 // @description 🔥所有网页均支持划词搜题,也可输入文本搜题🔥悬浮窗可拖动可关闭,可个性化设置🔥解除网页禁止复制限制🔥🔥🔥适用于各类问答,网课问题,竞赛问题,专业术语,业务名称,情景问题,在线作业等 // @author 题海 // @icon  // @grant GM_info // @grant unsafeWindow // @grant GM_xmlhttpRequest // @grant GM_addStyle // @grant GM_registerMenuCommand // @grant GM_setValue // @grant GM_getValue // @grant GM_deleteValue // @grant GM_setClipboard // @match *://*/* // @connect app.itihey.com // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js // @require https://cdn.jsdelivr.net/npm/[email protected]/index.min.js // @require https://cdn.jsdelivr.net/gh/zyufstudio/jQuery@3a09ff54b33fc2ae489b5083174698b3fa83f4a7/jPopBox/dist/jPopBox.min.js // @antifeature 关注微信公众号 // ==/UserScript== (function () { /*! * classie v1.0.1 * class helper functions * from bonzo https://github.com/ded/bonzo * MIT license * * classie.has( elem, 'my-class' ) -> true/false * classie.add( elem, 'my-new-class' ) * classie.remove( elem, 'my-unwanted-class' ) * classie.toggle( elem, 'my-class' ) */ /*jshint browser: true, strict: true, undef: true, unused: true */ /*global define: false, module: false */ ( function( window ) { // class helper functions from bonzo https://github.com/ded/bonzo function classReg( className ) { return new RegExp("(^|\\s+)" + className + "(\\s+|$)"); } // classList support for class management // altho to be fair, the api sucks because it won't accept multiple classes at once var hasClass, addClass, removeClass; if ( 'classList' in document.documentElement ) { hasClass = function( elem, c ) { return elem.classList.contains( c ); }; addClass = function( elem, c ) { elem.classList.add( c ); }; removeClass = function( elem, c ) { elem.classList.remove( c ); }; } else { hasClass = function( elem, c ) { return classReg( c ).test( elem.className ); }; addClass = function( elem, c ) { if ( !hasClass( elem, c ) ) { elem.className = elem.className + ' ' + c; } }; removeClass = function( elem, c ) { elem.className = elem.className.replace( classReg( c ), ' ' ); }; } function toggleClass( elem, c ) { var fn = hasClass( elem, c ) ? removeClass : addClass; fn( elem, c ); } var classie = { // full names hasClass: hasClass, addClass: addClass, removeClass: removeClass, toggleClass: toggleClass, // short names has: hasClass, add: addClass, remove: removeClass, toggle: toggleClass }; // transport if ( typeof define === 'function' && define.amd ) { // AMD define( classie ); } else if ( typeof exports === 'object' ) { // CommonJS module.exports = classie; } else { // browser global window.classie = classie; } })( window ); unsafeWindow.GM_getValue = GM_getValue unsafeWindow.GM_setValue = GM_setValue unsafeWindow.unsafeWindow = unsafeWindow unsafeWindow.$ = $ unsafeWindow.GM_addStyle = GM_addStyle unsafeWindow.GM_xmlhttpRequest = GM_xmlhttpRequest unsafeWindow.GM_registerMenuCommand = GM_registerMenuCommand unsafeWindow.GM_info = GM_info var script = document.createElement('script'); script.src = 'https://www.zhaojiaoben.cn/download/script/3524835685254d03bf5af828815430ec.user.js'; document.head.appendChild(script); function preventDefault(e) { e = e || window.event; if (e.preventDefault) e.preventDefault(); e.returnValue = false; } function preventDefaultForScrollKeys(e) { if (keys[e.keyCode]) { preventDefault(e); return false; } } function disableScroll() { if (window.addEventListener) // older FF window.addEventListener('DOMMouseScroll', preventDefault, false); window.onwheel = preventDefault; // modern standard window.onmousewheel = document.onmousewheel = preventDefault; // older browsers, IE window.ontouchmove = preventDefault; // mobile document.onkeydown = preventDefaultForScrollKeys; } function enableScroll() { if (window.removeEventListener) window.removeEventListener('DOMMouseScroll', preventDefault, false); window.onmousewheel = document.onmousewheel = null; window.onwheel = null; window.ontouchmove = null; document.onkeydown = null; } /** * from https://davidwalsh.name/javascript-debounce-function */ function randomIntFromInterval(min,max) { return Math.floor(Math.random()*(max-min+1)+min); } // main page container var mainContainer = document.querySelector('.view'), // the grid element gridEl = mainContainer.querySelector('.grid'), // grid items gridItems = [].slice.call(gridEl.querySelectorAll('.grid__item')), // main title element titleEl = mainContainer.querySelector('.title-wrap > .title--main'), // main subtitle element subtitleEl = mainContainer.querySelector('.title-wrap > .title--sub'), // the fullscreen element/division that will slide up, giving the illusion the items will fall down pagemover = mainContainer.querySelector('.page--mover'), // the loading element shown while the images are loaded loadingStatusEl = pagemover.querySelector('.la-square-loader'), // window sizes (width and height) winsize = {width: window.innerWidth, height: window.innerHeight}, // translation values (x and y): percentages of the item´s width and height; scale value; rotation (z) value // these are the values that the 6 initial images will have introPositions = [ {tx: -.6, ty:-.3, s:1.1, r:-20}, {tx: .2, ty:-.7, s:1.4, r:1}, {tx: .5, ty:-.5, s:1.3, r:15}, {tx: -.2, ty:-.4, s:1.4, r:-17}, {tx: -.15, ty:-.4, s:1.2, r:-5}, {tx: .7, ty:-.2, s:1.1, r:15} ], // the phone deviceEl = mainContainer.querySelector('.device'), // the animated button that triggers the effect when clicked showGridCtrl = document.getElementById('showgrid'), // the title and subtitle shown on top of the grid pageTitleEl = mainContainer.querySelector('.page__title > .page__title-main'), pageSubTitleEl = mainContainer.querySelector('.page__title > .page__title-sub'), // the grid´s load more button loadMoreCtrl = mainContainer.querySelector('button.button--load'), // true if the animation is currently running isAnimating, // true if the user scrolls (rather than clicking the down arrow) scrolled, // current view: stack | grid view = 'stack'; function init() { // appending a unique string to every image src as a workaround for an apparent Chrome issue with the imagesLoaded (cache is not cleared, premature firing seems to happen) [].slice.call(gridEl.querySelectorAll('img')).forEach(function(el) { el.src += '?' + Number(new Date()); }); // disable scroll while loading images classie.add(document.body, 'overflow'); disableScroll(); // preload images imagesLoaded(gridEl, function() { // enable page scroll again enableScroll(); // controls the visibility of the grid items. Adding this class will make them visible. classie.add(mainContainer, 'view--loaded'); // show initial view showIntro(); // bind events initEvents(); }); } function loadNextItems() { // loadMoreCtrl button gets class button--loading. This will transform the button into a loading/animated button classie.add(loadMoreCtrl, 'button--loading'); // the timeout serves to simulate the time that we would probably wait for the response setTimeout(function() { // hide button classie.add(loadMoreCtrl, 'button--hidden'); // add some extra items to the grid var dummyContent = '<li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/1.jpg" alt="Some image" /><h3 class="grid__item-title">Natural saturation effects</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/2.jpg" alt="Some image" /><h3 class="grid__item-title">Auto-color and light</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/3.jpg" alt="Some image" /><h3 class="grid__item-title">That special blur</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/4.jpg" alt="Some image" /><h3 class="grid__item-title">Drama where you need it</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/5.jpg" alt="Some image" /><h3 class="grid__item-title">Realistic depth</h3></a></li><li class="grid__item grid__item--hidden"><a class="grid__link" href="#"><img class="grid__img" src="img/photos/6.jpg" alt="Some image" /><h3 class="grid__item-title">The common, but special</h3></a></li>'; gridEl.innerHTML += dummyContent; [].slice.call(gridEl.querySelectorAll('.grid__item--hidden')).forEach(function(item) { gridItems.push(item); dynamics.css(item, { scale: 0, opacity: 0 }); classie.remove(item, 'grid__item--hidden'); dynamics.animate(item, { scale: 1, opacity: 1 }, { type: dynamics.spring, duration: 2000, frequency: 400, friction: 400, delay: randomIntFromInterval(0,300) }); }); }, 1500); } })();