switch content editable

open/close content editable (by alt+e)

  1. // ==UserScript==
  2. // @name switch content editable
  3. // @name:zh 页面可编辑切换
  4. // @supportURL https://github.com/rectcircle/switch-content-editable
  5. // @namespace https://github.com/rectcircle/switch-content-editable
  6. // @license MIT
  7. // @version 1.0.1
  8. // @description open/close content editable (by alt+e)
  9. // @description:zh 打开或者关闭页面可编辑属性 (通过快捷键alt+e)
  10. // @author Rectcircle <rectcircle96@gmail.com>
  11. // @icon 
  12. // @include *
  13. // @run-at document-end
  14. // ==/UserScript==
  15.  
  16. //创建一个闭包,避免污染外部名字空间
  17. ;(function(){
  18. // 全局变量:记录`s`键是否松开状态
  19. var s_up = true;
  20. // 常量
  21. const lockIcon = "";
  22. const unlockIcon = "";
  23.  
  24. const lockText = "页面编辑已锁定";
  25. const unlockText = "页面编辑已解锁";
  26.  
  27. //提示窗口
  28. var tipDiv = document.createElement('div');
  29. tipDiv.style = 'z-index:200000000;background-color: #272822; color: #F8F8F2; position: fixed; right:40px; top:40px; padding: 10px 20px; font-size: 18px; border-radius: 6px; display: none;'; ;
  30. var tipInnerDiv = document.createElement('div');
  31. tipInnerDiv.style = 'height:40px; line-height:40px; text-align:center';
  32. var iconImg = document.createElement('img');
  33. iconImg.style = 'vertical-align:middle;'
  34. iconImg.src = unlockIcon;
  35. var tipText = document.createElement('span');
  36. tipText.style = 'vertical-align:middle;margin-left:10px;'
  37. tipText.textContent = unlockText
  38.  
  39. tipDiv.appendChild(tipInnerDiv);
  40. tipInnerDiv.appendChild(iconImg);
  41. tipInnerDiv.appendChild(tipText);
  42.  
  43. document.body.appendChild(tipDiv);
  44.  
  45. //定时器
  46. var timer=0;
  47.  
  48. //显示提示
  49. function showTips(nowStatus){
  50. if(nowStatus){
  51. iconImg.src = unlockIcon;
  52. tipText.textContent = unlockText;
  53. } else {
  54. iconImg.src = lockIcon;
  55. tipText.textContent = lockText;
  56. }
  57. clearTimeout(timer);
  58. timer = setTimeout(function () {
  59. tipDiv.style['display'] = 'none';
  60. }, 3000);
  61. tipDiv.style['display'] = 'block';
  62.  
  63. }
  64.  
  65. //切换页面可编辑状态
  66. function changeContentEditable(){
  67. var newStatus = document.body.contentEditable=="true"?false:true;
  68. document.body.contentEditable = newStatus;
  69. if (newStatus){
  70. document.body.focus();
  71. }
  72. tipDiv.contentEditable = "false";
  73. showTips(newStatus);
  74. }
  75.  
  76. document.addEventListener('keydown', function (e) {
  77. if(s_up==true && e.keyCode == 69 && e.altKey){
  78. changeContentEditable()
  79. s_up = false;
  80. }
  81. });
  82. document.addEventListener('keyup', function (e) {
  83. if (s_up == false && e.keyCode == 69) {
  84. s_up = true;
  85. }
  86. });
  87. })()