您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Random Sexy Pictures Parser
// ==UserScript== // @name RandomSexyPicParser // @name:zh-TW 軟瑟盤 // @name:ja RandomSexyPicParser // @namespace hoothin // @version 1.3.19 // @description Random Sexy Pictures Parser // @description:zh-TW 隨機色圖 // @description:ja ランダムセクシー画像パーサー // @author hoothin // @match https://api.lolicon.app/setu/v2* // @match https://api.nyan.xyz/httpapi/sexphoto* // @match https://huanmengii.xyz/ZY/aCOS/cos* // @match https://api.uomg.com/api/rand.img3* // @match https://api.vvhan.com/api/tao* // @match https://www.hlapi.cn/api/mjx* // @match https://3650000.xyz/api/?* // @match *://*/* // @icon  // @grant GM_addStyle // @grant GM_setValue // @grant GM_getValue // @grant GM_xmlhttpRequest // @grant GM_registerMenuCommand // @run-at document-idle // @license MIT // ==/UserScript== if (window.top != window.self) { return; } (function() { 'use strict'; var setuConfig={ "api.lolicon.app":{ include: /setu\/v2/i, name:"Lolicon ACG SexyPic", url:"https://api.lolicon.app/setu/v2?r18=1&num=10", luckyUrl:["https://api.lolicon.app/setu/v2?r18=0&num=5", "https://api.lolicon.app/setu/v2?r18=1&num=5", "https://api.lolicon.app/setu/v2?r18=2&num=5"], run:()=>{ var searchNum=getSearchParam("num"); var leftNum=searchNum; if(jsonData != "Forbidden"){ let datas=jsonData.data; datas.forEach(function(data){ leftNum--; let img=createImg(data.urls?data.urls.original:data.url); img.title=data.title+" - "+data.author; }); }else{ location.href=curConfig.url; } processByTime(leftNum,loadNum=>{ GM_xmlhttpRequest({ method: 'GET', url: curConfig.url.replace("num=5","num="+loadNum), timeout:15000, onload: function(result) { let datas=JSON.parse(result.responseText).data; datas.forEach(function(data){ let img=createImg(data.urls?data.urls.original:data.url); img.title=data.title+" - "+data.author; }); } }); },5,1000); }, getSearch:(param)=>{ return `v2?r18=${param.r18}&num=${param.num}`; }, initSearch:()=>{ var searchNum=getSearchParam("num"); var searchR18=getSearchParam("r18"); numInput.value=searchNum; r18Check.checked=searchR18==1||searchR18==2; sfwCheck.checked=searchR18==0||searchR18==2; } }, "api.nyan.xyz":{ hide: true, include: /httpapi\/sexphoto/i, name:"Nyan ACG SexyPic", url:"https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=10", luckyUrl:["https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=5", "https://api.nyan.xyz/httpapi/sexphoto/?r18=false&num=5"], run:()=>{ var searchNum=getSearchParam("num"); var leftNum=searchNum; var urls=jsonData.data.url; if(!urls instanceof Array){ urls=[urls]; } urls.forEach(function(data){ leftNum--; createImg(data); }); processByTime(leftNum,loadNum=>{ GM_xmlhttpRequest({ method: 'GET', url: curConfig.url.replace("num=5","num="+loadNum), timeout:15000, onload: function(result) { urls=JSON.parse(result.responseText).data.url; urls.forEach(function(data){ createImg(data); }); } }); },5,1000); }, getSearch:(param)=>{ return `?r18=${param.r18==1?"true":"false"}&num=${param.num}`; }, initSearch:()=>{ var searchNum=getSearchParam("num"); var searchR18=getSearchParam("r18"); numInput.value=searchNum; r18Check.checked=searchR18=="true"; sfwCheck.checked=searchR18=="false"; } }, "buyersShow":{ include: /api\/(rand|tao|mjx1|taobaoBuyerShow)/i, name:"Taobao Buyers Show", urls:["https://api.uomg.com/api/rand.img3?format=json&num=15", "https://api.suxun.site/api/tao?type=json&num=15", "https://api.03c3.cn/api/taobaoBuyerShow?type=json&num=15"], run:()=>{ r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none"; var searchNum=getSearchParam("num"); processByTime(searchNum,loadNum=>{ for(let i=0;i<loadNum;i++){ createImg(location.href.replace(/1?\?.*/,"?")+"r="+Math.random()); } },5,1000); }, getSearch:(param)=>{ return location.href.replace(/\d+$/,"")+param.num; }, initSearch:()=>{ var searchNum=getSearchParam("num"); numInput.value=searchNum; } }, "huanmengii.xyz":{ hide: true, include: /ZY\/aCOS\/cos/i, name:"Cosplay Show", url:"https://huanmengii.xyz/ZY/aCOS/cos/?type=json&num=15", run:()=>{ r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none"; var searchNum=getSearchParam("num"); processByTime(searchNum,loadNum=>{ for(let i=0;i<loadNum;i++){ GM_xmlhttpRequest({ method: 'GET', url: curConfig.url+"&"+Math.random(), timeout:15000, onload: function(result) { var curUrl=JSON.parse(result.responseText).pic; createImg(curUrl); } }); } },5,1000); }, getSearch:(param)=>{ return "?type=json&num="+param.num; }, initSearch:()=>{ var searchNum=getSearchParam("num"); numInput.value=searchNum; } }, "3650000.xyz":{ include: /\/api\/\?type=json/i, name:"3650000", url:"https://3650000.xyz/api/?type=json&mode=7&num=6", luckyUrl:["https://3650000.xyz/api/?type=json&num=6", "https://3650000.xyz/api/?type=json&mode=1&num=6", "https://3650000.xyz/api/?type=json&mode=2&num=6", "https://3650000.xyz/api/?type=json&mode=3&num=6", "https://3650000.xyz/api/?type=json&mode=5&num=6", "https://3650000.xyz/api/?type=json&mode=6&num=6", "https://3650000.xyz/api/?type=json&mode=7&num=6", "https://3650000.xyz/api/?type=json&mode=8&num=6", "https://3650000.xyz/api/?type=json&mode=9&num=6"], run:()=>{ r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none"; var searchNum=getSearchParam("num"); var searchMode=getSearchParam("mode"); processByTime(searchNum,loadNum=>{ for(let i=0;i<loadNum;i++){ GM_xmlhttpRequest({ method: 'GET', url: `${curConfig.url}&mode=${searchMode}&${Math.random()}`, timeout:15000, onload: function(result) { var curUrl=JSON.parse(result.responseText).url; createImg(curUrl); } }); } },5,1000); }, getSearch:(param)=>{ return location.pathname+`?type=json&mode=${param.mode}&num=${param.num}`; }, initSearch:()=>{ var searchNum=getSearchParam("num"); var searchMode=getSearchParam("mode"); var modeObj=[ ["Public",""], ["Weibo","1"], ["Instagram","2"], ["Cosplay","3"], ["Mtcos","5"], ["Mtcos2","6"], ["Legs","7"], ["MoreCoser","8"], ["Tuwan","9"] ]; modeObj.forEach(item=>{ var option=document.createElement("option"); option.value=item[1]; option.innerText=item[0]; if(item[1]==searchMode){ option.selected=true; } modeSelect.appendChild(option); }); modeSelect.style.display="inline"; numInput.value=searchNum; } }, "api.uomg.com":"buyersShow", "api.vvhan.com":"buyersShow", "www.hlapi.cn":"buyersShow", "api.ghser.com":"buyersShow", "api.03c3.cn":"buyersShow", "api.suxun.site":"buyersShow" }; var customRule=GM_getValue("RSPrules") || {}; var customRuleArr=[]; for(var j in customRule){ let href=customRule[j]; customRuleArr.push(href); } GM_registerMenuCommand("I am feeling lucky", ()=>{ var luckyUrls=[],targetUrl; for(var i in setuConfig){ let sc=setuConfig[i]; if(sc.hide){ continue; }else if(sc.luckyUrl){ luckyUrls=luckyUrls.concat(sc.luckyUrl); }else if(sc.urls){ luckyUrls=luckyUrls.concat(sc.urls); }else if(sc.url){ luckyUrls.push(sc.url); } } luckyUrls=luckyUrls.concat(customRuleArr); var randomIndex=Math.floor(Math.random()*luckyUrls.length); targetUrl=luckyUrls[randomIndex]; location.href=targetUrl; }); const _unsafeWindow = (typeof unsafeWindow == 'undefined') ? window : unsafeWindow; const escapeHTMLPolicy = (_unsafeWindow.trustedTypes && _unsafeWindow.trustedTypes.createPolicy) ? _unsafeWindow.trustedTypes.createPolicy('rspp_default', { createHTML: (string, sink) => string }) : null; function createHTML(html) { return escapeHTMLPolicy ? escapeHTMLPolicy.createHTML(html) : html; } if (location.href.indexOf("randomsexypicparser") != -1) { GM_addStyle(".discussion-rating{display:none}"); } var curConfig=setuConfig[document.domain],jsonData,hasFloatImg=false,grabed=false,oClient; if(curConfig){ if(!curConfig.run){ curConfig=setuConfig[curConfig]; } if(curConfig.include && !curConfig.include.test(location.href)){ curConfig=false; } } if(!curConfig){ let currentParsing=customRule[document.domain+location.pathname]; if(!currentParsing){ GM_registerMenuCommand("Parse current api", customSet); return; }else{ GM_registerMenuCommand("Stop parse api", () => { delete customRule[document.domain+location.pathname]; GM_setValue("RSPrules", customRule); location.reload(); }); curConfig={run:()=>{ var searchNum=getSearchParam("num"); var leftNum=searchNum; r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none"; let parsePics=(data)=>{ let picUrls=[],urlReg=/(https?|ftp|file):\/\/[\-A-Za-z0-9\+&@#/%?=~_\|!:,\.;]+[\-A-Za-z0-9\+&@#/%=~_\|]/g; if(typeof data == "string"){ picUrls=data.match(urlReg); }else{ let checkJson=obj=>{ for(let i in obj){ if(typeof obj[i] == "string"){ let pics=obj[i].match(urlReg); if(pics)picUrls=picUrls.concat(pics); }else checkJson(obj[i]); } }; checkJson(data); } if(picUrls){ picUrls=picUrls.filter((item, index) => picUrls.indexOf(item) === index); picUrls.forEach(url=>{ leftNum--; createImg(unescape(url)); }); } } parsePics(jsonData); processByTime(leftNum||1, loadNum=>{ let href=location.href.replace(/num=\d+(&time=\d+)?/,"num="+loadNum+"&time="+Date.now()),postParams=href.match(/#p{(.*)}/); if(postParams){ postParams=postParams[1]; href=href.replace(/#p{.*/,""); } GM_xmlhttpRequest({ method: postParams?'POST':'GET', data: postParams, headers: { 'Referer': location.href, "Content-Type": (postParams ? "application/x-www-form-urlencoded" : "text/html") + ";charset=" + (document.characterSet || document.charset || document.inputEncoding), }, url: href, timeout:15000, onload: function(result) { var parseData; try{ parseData=JSON.parse(result.responseText); console.log(parseData); }catch(e){ parseData=result.responseText; } parsePics(parseData); } }); }, (leftNum < searchNum - 1 ? 5 : 1), 1000); }, getSearch:(param)=>{ var href=location.href; if(/\bnum=/.test(href)){ href=href.replace(/\bnum=\d+(&time=\d+)?/,"num="+param.num+"&time="+Date.now()); }else{ if(href.indexOf("?")==-1){ if(href.indexOf("#")==-1){ href+="?num="+param.num+"&time="+Date.now(); }else{ href=href.replace("#","?num="+param.num+"&time="+Date.now()+"#"); } }else{ href+="&num="+param.num+"&time="+Date.now(); } } return href; }, initSearch:()=>{ var searchNum=getSearchParam("num"); numInput.value=searchNum; }}; } } document.title=curConfig.name?curConfig.name:"Random Sexy Pictures"; try{ var firstText = ""; for (var i = 0; i < document.body.childNodes.length; i++) { var curNode = document.body.childNodes[i]; if (curNode.nodeType == 1 || curNode.nodeName == "PRE") { firstText = curNode.nodeValue || curNode.innerText; if (firstText) break; } } if(firstText)jsonData=JSON.parse(firstText); }catch(e){ console.log(e); jsonData=firstText; } document.body.innerHTML=createHTML(""); var imgCon=document.createElement("div"); var btns=document.createElement("div"); var numInput=document.createElement("input"); var r18Check=document.createElement("input"); var r18CheckLabel=document.createElement("label"); var sfwCheck=document.createElement("input"); var sfwCheckLabel=document.createElement("label"); var modeSelect=document.createElement("select"); var submit=document.createElement("button"); var referrerMeta=document.createElement("meta"); var viewportMeta=document.createElement("meta"); var overMask=document.createElement("div"); var homepage=document.createElement("a"); var lightBtn=document.createElement("span"); for(var name in setuConfig){ var config=setuConfig[name]; if(config.hide || !config.name)continue; var siteA=document.createElement("a"); var url=config.url; if(config.urls){ var randomIndex=Math.floor(Math.random()*config.urls.length); url=config.urls[randomIndex]; config.url=url; } siteA.href=url; siteA.innerText=config.name; btns.appendChild(siteA); } if(customRuleArr.length){ var otherSiteA=document.createElement("a"); otherSiteA.href=customRuleArr[Math.floor(Math.random()*customRuleArr.length)]; otherSiteA.innerText="Other"; btns.appendChild(otherSiteA); } btns.appendChild(numInput); btns.appendChild(r18Check); btns.appendChild(r18CheckLabel); btns.appendChild(sfwCheck); btns.appendChild(sfwCheckLabel); btns.appendChild(modeSelect); btns.appendChild(submit); btns.appendChild(homepage); btns.appendChild(lightBtn); overMask.className="over-mask"; imgCon.appendChild(overMask); referrerMeta.name="referrer"; referrerMeta.content="never"; document.head.appendChild(referrerMeta); viewportMeta.name="viewport"; viewportMeta.content="width=device-width, initial-scale=1"; document.head.appendChild(viewportMeta); curConfig.run(); if(curConfig.initSearch)curConfig.initSearch(); function sleep(fn,param,time) { return new Promise((resolve) => { setTimeout(() => resolve(fn(param)), time) }) } async function processByTime(num,fn,limit,time) { while(num>0){ var loadNum=limit; if(num<limit)loadNum=num; num-=loadNum; await sleep(fn,loadNum,time); } } overMask.onclick=e=>{ if(hasFloatImg){ restoreImg(hasFloatImg); } }; function mousedownHandler(e){ let img=e.target; img.addEventListener("mouseup",mouseupHandler); img.addEventListener("mousemove",mousemoveHandler); img.style.cursor="grabbing"; oClient={ x:window.scrollX+e.clientX, y:window.scrollY+e.clientY, }; e.stopPropagation(); e.preventDefault(); e.returnValue=false; } function mousemoveHandler(e){ let img=e.target; grabed=true; window.scrollTo(oClient.x-e.clientX, oClient.y-e.clientY); } function mouseupHandler(e){ let img=e.target; img.removeEventListener("mouseup",mouseupHandler); img.removeEventListener("mousemove",mousemoveHandler); img.style.cursor="grab"; } function grabHandler(img,add){ if(add){ img.addEventListener("mousedown",mousedownHandler); }else{ img.removeEventListener("mousedown",mousedownHandler); } } function restoreImg(img){ hasFloatImg=false; img.style.zIndex=0; img.style.bottom=""; img.style.width="100%"; img.style.position=""; img.style.margin=""; document.body.style.overflow=""; imgCon.style.maxHeight=""; imgCon.style.maxWidth=""; overMask.style.display="none"; overMask.style.opacity=0; img.className="list-show"; grabHandler(img,false); img.style.cursor=""; img.scrollIntoView({ block: "center", inline: "center" }); } function createImg(url){ let img=document.createElement("img"); img.onerror=e=>{ img.style.display="none"; }; img.src=url; img.className="list-show"; img.style.width="100%"; img.onclick=()=>{ if(grabed){ grabed=false; return; } window.scrollTo(0,0); var de=document.documentElement; var body=document.body; var backCompat=document.compatMode=='BackCompat'; var windowSize={ h: backCompat ? body.clientHeight : de.clientHeight, w: backCompat ? body.clientWidth : de.clientWidth, }; if(img.style.zIndex==2){ restoreImg(img); }else if(img.style.zIndex==1){ img.style.bottom=""; img.style.width=""; img.style.maxWidth=""; img.style.maxHeight=""; img.style.zIndex=2; img.style.cursor="grab"; grabHandler(img,true); document.body.style.overflow=""; imgCon.style.maxWidth="100vw"; imgCon.style.maxHeight="100vh"; }else{ if(hasFloatImg)return; hasFloatImg=img; document.body.style.overflow="hidden"; img.style.bottom=0; if(img.naturalWidth>windowSize.w || img.naturalHeight>windowSize.h){ img.style.zIndex=1; img.style.maxWidth="99%"; img.style.maxHeight="99%"; }else{ img.style.zIndex=2; img.style.maxWidth=""; img.style.maxHeight=""; } img.style.width=""; img.style.position="absolute"; img.style.margin="auto"; overMask.style.display="block"; img.className=""; setTimeout(()=>{ overMask.style.opacity=1; }, 0); } }; imgCon.appendChild(img); return img; } function getSearchParam(name){ let reg = new RegExp("(&|^)" + name + "=([^&]*)(&|$)", "i"); let r = window.location.search.substr(1).match(reg); if (r != null) { return decodeURIComponent(r[2]); }; return ""; } function submitParam(){ var num=numInput.value,mode; if(modeSelect.options.length>0){ mode=modeSelect.options[modeSelect.selectedIndex].value; } var r18=2; if(sfwCheck.checked && !r18Check.checked){ r18=0; }else if(!sfwCheck.checked && r18Check.checked){ r18=1; } if(numInput.value != ""){ location.href=curConfig.getSearch({"r18":r18, "num":num, "mode":mode}); }else{ location.reload(); } } function customSet(){ if(window.confirm("Parse current api?")){ customRule[document.domain+location.pathname]=location.href; GM_setValue("RSPrules", customRule); location.reload(); } } GM_addStyle(` @media screen and (min-width: 1024px) { .img-con{ column-count: 5; -moz-column-count: 5; -webkit-column-count: 5; } .img-con>img{ min-height: 250px; } } @media screen and (max-width: 1024px) { .img-con{ column-count: 2; -moz-column-count: 2; -webkit-column-count: 2; } .img-con>img{ min-height: 50px; } } body{ background: black; scrollbar-width: none; } body::-webkit-scrollbar { width: 0 !important; height: 0 !important; } .btns>select{ display: none; height: 29px; border-radius: 3px 0 0 3px; -moz-border-radius: 3px 0 0 3px; -webkit-border-radius: 3px 0 0 3px; -ms-border-radius: 3px 0 0 3px; -o-border-radius: 3px 0 0 3px; border: none; color: #cacaca; background-color: #363636; font-size: 14px; outline: 0; padding: 2px 5px; vertical-align: top; } .over-mask{ display: none; opacity: 0; width: 100%; height: 100%; background-color: #000000e6; position: fixed; z-index: 1; top: 0; left: 0; transition: opacity .3s ease-in-out; -moz-transition: opacity .3s ease-in-out; -o-transition: opacity .3s ease-in-out; -webkit-transition: opacity .3s ease-in-out; } .list-show:hover,.list-show.hover{ opacity: 1; transform: scale(1.05); } .list-show{ opacity: 0.6; transition: opacity .3s ease-in-out, transform .3s; -moz-transition: opacity .3s ease-in-out, transform .3s; -webkit-transition: opacity .3s ease-in-out, transform .3s; } .img-con{ overflow-x: hidden; overflow: auto; width: 100%; min-height: calc(100vh - 70px); display: block; scrollbar-width: none; } .img-con::-webkit-scrollbar { width: 0 !important; height: 0 !important; } .img-con>img{ -webkit-column-break-inside: avoid; break-inside: avoid; float: left; margin-bottom: 15px; margin-right: 15px; overflow: hidden; position: relative; top: 0; left: 0; right: 0; background: url() no-repeat center center; } .btns{ padding: 10px 0; text-align: center; line-height: 30px; position: fixed; z-index: 1; width: 100%; top: 0; left: 0; background: #000000de; -webkit-transition:transform .5s ease-out; -o-transition:transform .5s ease-out; transition:transform .5s ease-out; } .btns.hide{ -webkit-transform:translateY(-100px); -ms-transform:translateY(-100px); -o-transform:translateY(-100px); transform:translateY(-100px); } .btns>a{ padding: 5px; background: #f8981e; color: black; border-radius: 5px; font-weight: bold; text-decoration: none; margin: 1px; font-family: Arial,Helvetica,sans-serif; } .btns>a:hover{ background: #ffa31a; } .btns>a>span{ background: #2f2f2f; color: white; padding: 5px; margin: 0 5px 0 -5px; border-radius: 5px 0 0 5px; } .btns>a:hover>span{ background: #3f3f3f; } .btns>label{ background: #f8981e; color: black; border-radius: 5px; font-weight: bold; text-decoration: none; padding: 3px; } .btns>input[type=checkbox]{ width:20px; height:20px; vertical-align: top; } .btns>input[type=number]{ width: 48px; height: 25px; border-radius: 3px 0 0 3px; -moz-border-radius: 3px 0 0 3px; -webkit-border-radius: 3px 0 0 3px; -ms-border-radius: 3px 0 0 3px; -o-border-radius: 3px 0 0 3px; border: none; color: #cacaca; background-color: #363636; display: inline-block; font-size: 14px; outline: 0; padding: 2px 5px; vertical-align: top; margin: 0 5px; } .btns>span{ right: 10px; font-size: x-large; position: absolute; cursor: pointer; filter: brightness(0.5); } .lighted>.btns>span{ filter: none; } .btns>button:hover{ transform: scale3d(1.1, 1.1, 1.1); } .lighted>.img-con>img.list-show{ opacity: 1; } .btns>button{ cursor: pointer; background: #0075ff; color: white; border-radius: 5px; font-weight: bold; text-decoration: none; padding: 8px 5px 5px 5px; margin: 0px 10px 0 10px; border: 0; transition: transform .3s ease 0s; transform: scale3d(1, 1, 1); }`); btns.className="btns"; document.body.appendChild(btns); homepage.innerHTML=createHTML("<span>Home</span>page"); homepage.href="https://sleazyfork.org/en/users/8227-hoothin"; homepage.target="_blank"; numInput.type="number"; numInput.title=numInput.placeholder="Num of sexy pictures"; r18Check.type="checkbox"; r18Check.id="r18Check"; r18CheckLabel.innerText="R18 "; r18CheckLabel.htmlFor="r18Check"; sfwCheck.type="checkbox"; sfwCheck.id="sfwCheck"; sfwCheckLabel.innerText="SFW "; sfwCheckLabel.htmlFor="sfwCheck"; submit.innerText="Refresh"; submit.onclick=submitParam; document.onkeyup = function(e) { var event = e || window.event; var key = event.which || event.keyCode || event.charCode; if (key == 13) { submitParam(); } }; lightBtn.innerText="💡"; lightBtn.onclick=e=>{ document.body.classList.toggle("lighted"); } imgCon.className="img-con"; document.body.appendChild(imgCon); imgCon.style.paddingTop=parseInt(window.getComputedStyle(btns).height.replace("px",""))+20+"px"; document.body.addEventListener("touchstart",e=>{ var lastHover=document.querySelector(".list-show.hover"); if(lastHover)lastHover.classList.remove("hover"); if(e.target.className=="list-show"){ e.target.classList.add("hover"); } }); var newPos,lastPos=0; window.addEventListener('scroll', function(e) { newPos=window.scrollY; if (newPos > lastPos) { btns.classList.add("hide"); } else { btns.classList.remove("hide"); } lastPos=newPos; }); })();