mylib

我的工具

目前为 2023-11-06 提交的版本。查看 最新版本

此脚本不应直接安装,它是一个供其他脚本使用的外部库。如果您需要使用该库,请在脚本元属性加入:// @require https://update.gf.qytechs.cn/scripts/435697/1276080/mylib.js

  1. // ==UserScript==
  2. // @name mylib
  3. // @description 我的工具
  4. // @dependency unsafeWindow GM_setValue GM_getValue
  5. // ==/UserScript==
  6. (function(win){
  7. const e=document.documentElement.firstElementChild,sv=GM_setValue,gv=GM_getValue;
  8. let z,myBtns;
  9. // win.gv=gv;win.sv=sv
  10. win.my=new class {
  11. constructor(){
  12. if(e.tagName==='Z') z=this.zone=e;
  13. else {
  14. z=this.zone=this.before('z',e,'',`class`,'rwf');
  15. win.cl=win.console.log;win.al=win.alert;
  16. }
  17. if(z.querySelector('my-btns')) myBtns=z.querySelector('my-btns');
  18. else{
  19. this.addStyle(`my-btns{display:block;z-index:9195129;position:fixed;height: min-content;}.my-btn{user-select: none}`,'my-btns');
  20. myBtns=this.append('my-btns',z,'',`class`,'rwf');
  21. myBtns.style.left=gv('left',0);
  22. myBtns.style.top=gv('top',0);
  23. // myBtns.style.display='flex';
  24. this.bindDrag(myBtns);
  25. myBtns.onmouseup=e=>{
  26. sv('left',myBtns.style.left);
  27. sv('top',myBtns.style.top);
  28. }
  29. }
  30. }
  31. sleep(time){
  32. return new Promise((resolve) => setTimeout(resolve, time));
  33. }
  34. addStyle(css,className='rwf'){//depend:after,zone
  35. return this.append('style',z,css,`class`,className);
  36. }
  37. append(tag,dom,content){
  38. if(!tag) return;
  39. const son=typeof tag==='string'?document.createElement(tag):tag instanceof EventTarget?tag:0;
  40. let len=arguments.length;
  41. if(dom instanceof EventTarget)dom.append(son);
  42. if(content)son.append(content);
  43. while(len>3){
  44. son.setAttribute([arguments[len-2]],arguments[len-1]);len-=2;
  45. }return son;
  46. }//my.append('tag',document.body,'content','idk','true','data-s')
  47. after(tag,dom,content){
  48. if(!tag) return;
  49. const bro=typeof tag==='string'?document.createElement(tag):tag instanceof EventTarget?tag:0;
  50. let len=arguments.length;
  51. if(dom instanceof EventTarget)dom.after(bro);
  52. if(content)bro.append(content);
  53. while(len>3){
  54. bro.setAttribute([arguments[len-2]],arguments[len-1]);len-=2;
  55. }return bro;
  56. }//my.after('div',document.body,'','suck','1','dick',000)
  57. before(tag,dom,content){
  58. if(!tag) return;
  59. const bro=typeof tag==='string'?
  60. document.createElement(tag):tag instanceof EventTarget?
  61. tag:0;
  62. let len=arguments.length;
  63. if(dom instanceof EventTarget)dom.before(bro);
  64. if(content)bro.append(content);
  65. while(len>3){
  66. bro.setAttribute([arguments[len-2]],arguments[len-1]);len-=2;
  67. }return bro;
  68. }// my.before('div',document.head,'','suck','1','dick')
  69.  
  70. eods(){//enable or disable style in my.zone
  71. z.querySelectorAll('style').forEach(e=>e.type==='0'?e.type='':e.type=0);
  72. }
  73. sohe(...args){//show or hide elements
  74. args.forEach(e=>{
  75. if(typeof e!=="string") e.style.display==='none'?e.style.display='initial':e.style.display='none';
  76. else document.querySelectorAll(e).forEach(e=>e.style.display==='none'?e.style.display='initial':e.style.display='none');
  77. });
  78. }
  79. s2d(seconds){//seconds2date
  80. const date=new Date(seconds),year=date.getFullYear(),month=date.getMonth()+1,day=date.getDate(),
  81. hour=date.getHours(),minute=date.getMinutes(),second=date.getSeconds(),milliseconds=date.getMilliseconds(),currentTime=year+"-"+month+"-"+day+" "+hour+":"+minute+":"+second+":"+milliseconds;
  82. return currentTime;
  83. }//my.s2d(new Date().getTime())
  84. tieba(uname,pwd){
  85. document.querySelector('[name="userName"]').value=uname;
  86. document.querySelector('[name="password"]').value=pwd;
  87. return document.querySelector('[value="登录(不可用)"]').click();
  88. }
  89. fixTitle(){//stop title be changed
  90. Object.defineProperty(document,"title",{
  91. writable:false
  92. });
  93. }
  94.  
  95. addBtns(...args){//depend:addStyle,append
  96. const len=args.length;
  97. for(let i=0;i<len;i++){
  98. const btn= this.append('input',myBtns,'','type','button','class','my-btn','value',args[i].name+' ');
  99. btn.addEventListener('click',args[i]);
  100. }
  101. return myBtns;
  102. }//my.addBtns(()=>{},e=>{confirm(e.target.id)},function(e){prompt(e.target.outerHTML)},function test(e){return 1})
  103. addAs(...args){//depend:addStyle,append
  104. const len=args.length;
  105. for(let i=0;i<args.length;i+=2){
  106. this.append('a',myBtns,args[i]+'|',`href`,args[i+1]);
  107. }
  108. }//my.addAs("bilibili","https://www.bilibili.com/","baidu","https://www.baidu.com/")
  109.  
  110. bindDrag(ele){//鼠标拖动
  111. ele.onmousedown=function(ev){
  112. if(ev.target.tagName==='TEXTAREA') return;
  113. const diffX=ev.clientX-ele.offsetLeft,diffY=ev.clientY-ele.offsetTop,iw=win.innerWidth,ih=win.innerHeight;
  114. document.onmousemove=function(ev){
  115. let moveX=ev.clientX-diffX,moveY=ev.clientY-diffY;
  116. moveX<0?moveX=0:moveX>iw-ele.offsetWidth?moveX=iw-ele.offsetWidth:0
  117. moveY<0?moveY=0:moveY>ih-ele.offsetHeight?moveY=ih-ele.offsetHeight:0;
  118. ele.style.left=moveX + 'px';
  119. ele.style.top=moveY + 'px'
  120. }
  121. document.onmouseup=function(ev){
  122. this.onmousemove=null;
  123. this.onmouseup=null;
  124. }
  125. }
  126. }
  127. }()
  128. })(unsafeWindow);

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址