多选框伴侣

Ctrl+Alt点击全选多选框,Alt加鼠标悬停选择多选框,Shift选择两个多选框之间的所有多选框

目前为 2022-01-07 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name Select All Checkboxes
  3. // @name:zh-CN 多选框伴侣
  4. // @name:zh-TW 多選框伴侶
  5. // @namespace hoothin
  6. // @version 0.6
  7. // @description A mate for checkbox, select all checkboxes by press Ctrl+Alt+mouse1, or select checkboxes with mouse over by press Alt, or select checkboxes between 2 marks by press Shift.
  8. // @description:zh-CN Ctrl+Alt点击全选多选框,Alt加鼠标悬停选择多选框,Shift选择两个多选框之间的所有多选框
  9. // @description:zh-TW Ctrl+Alt點擊全選多選框,Alt加鼠標懸停選擇多選框,Shift選擇兩個多選框之間的所有多選框
  10. // @author Hoothin
  11. // @include http*://*/*
  12. // @require http://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.min.js
  13. // @grant GM_registerMenuCommand
  14. // @grant GM.registerMenuCommand
  15. // @contributionURL https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=rixixi@sina.com&item_name=Greasy+Fork+donation
  16. // @contributionAmount 1
  17. // ==/UserScript==
  18.  
  19. (function() {
  20. 'use strict';
  21. var type=navigator.appName;
  22. var lang = null;
  23. if (type=="Netscape"){
  24. lang = navigator.language;
  25. }else{
  26. lang = navigator.userLanguage;
  27. }
  28. var langStr = lang.substr(0,2);
  29. if (langStr == "zh"){
  30. langStr = "全选";
  31. }else{
  32. langStr = "SelectAll";
  33. }
  34. var _GM_registerMenuCommand;
  35. if(typeof GM_registerMenuCommand=='undefined')_GM_registerMenuCommand=GM&&GM.registerMenuCommand?GM.registerMenuCommand:(s,f)=>{};
  36. else _GM_registerMenuCommand=GM_registerMenuCommand;
  37. _GM_registerMenuCommand(langStr, selectAll);
  38. var selector="input:checkbox:enabled,.checkbox";
  39.  
  40. function selectAll(){
  41. $(selector).click();
  42. }
  43.  
  44. var preObj;
  45. $(document).on("mousedown",selector,function (event) {
  46. if(!event.shiftKey&&event.altKey&&event.ctrlKey){
  47. $(selector).click();
  48. this.click();
  49. }else if(event.shiftKey&&!event.altKey&&!event.ctrlKey){
  50. var curParent=this;
  51. var preParent=preObj;
  52. for(var i=0;i<5;i++){
  53. curParent=curParent.parentNode;
  54. preParent=preParent.parentNode;
  55. if(!curParent||!preParent)return;
  56. if(curParent==preParent){
  57. var target=this;
  58. var find=false;
  59. $(curParent).find(selector).each(function(){
  60. if(this==preObj||this==target){
  61. if(find){
  62. find=false;
  63. return;
  64. }
  65. find=true;
  66. }else if(find){
  67. this.click();
  68. }
  69. });
  70. break;
  71. }
  72. }
  73. }
  74. preObj=this;
  75. });
  76. $(document).on("mouseenter",selector,function (event) {
  77. if(!event.shiftKey&&event.altKey&&!event.ctrlKey){
  78. this.click();
  79. }
  80. });
  81. })();