代码片段高亮

选择代码片段后点击图标高亮并美化代码

目前为 2016-10-20 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name HighlightEveryCode
  3. // @name:zh-CN 代码片段高亮
  4. // @name:zh-TW 代碼片斷高亮
  5. // @namespace hoothin
  6. // @version 0.3
  7. // @description Add a icon that allows syntax highlighting and beautify of source code snippets on current page
  8. // @description:zh-CN 选择代码片段后点击图标高亮并美化代码
  9. // @description:zh-TW 選擇代碼片段后點擊圖標高亮並美化代碼
  10. // @author Hoothin
  11. // @include *
  12. // ==/UserScript==
  13.  
  14. (function() {
  15. 'use strict';
  16. var codeIcon=document.createElement("img");
  17. var codes;
  18. codeIcon.style="position:fixed;z-index:99999;display:none;cursor: pointer;";
  19. codeIcon.title="Show this code snippet";
  20. codeIcon.src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAaAgMAAADOGETTAAAACVBMVEX7+/swMDBTU1MLxgsCAAAAJklEQVQI12MIBYEAGLUKBBbAqAUMQICgAoAqoBQ95JaCnASnUAAAwhMx2cRx+SkAAAAASUVORK5CYII=";
  21. codeIcon.onclick=function(){
  22. let c = window.open("", "_blank", "width=750, height=400, location=0, resizable=1, menubar=0, scrollbars=0");
  23. let html='<title>Code Snippet</title>'+
  24. '<link rel="stylesheet" href="https://cdn.rawgit.com/google/code-prettify/master/styles/sons-of-obsidian.css"/>'+
  25. '<script>var code,codeStr;window.onload=function(){code=document.querySelector("#code");codeStr=code.innerHTML.replace(/&nbsp;/g," ");prettyPrint();}</script>'+
  26. '<script src="https://cdnjs.cloudflare.com/ajax/libs/prettify/r298/prettify.min.js?skin=sons-of-obsidian"></script>'+
  27. '<script src="https://cdnjs.cloudflare.com/ajax/libs/js-beautify/1.6.4/beautify.min.js"></script>'+
  28. '<script src="https://cdnjs.cloudflare.com/ajax/libs/js-beautify/1.6.4/beautify-html.min.js"></script>'+
  29. '<script src="https://cdnjs.cloudflare.com/ajax/libs/js-beautify/1.6.4/beautify-css.min.js"></script>'+
  30. 'Code formatting: <a href="#" onclick="code.innerHTML=js_beautify(codeStr);code.className=\'prettyprint linenums\';prettyPrint();return false;">Javaspcript</a> '+
  31. '<a href="#" onclick="code.innerHTML=html_beautify(codeStr);code.className=\'prettyprint linenums\';prettyPrint();return false;">Html</a> '+
  32. '<a href="#" onclick="code.innerHTML=css_beautify(codeStr);code.className=\'prettyprint linenums\';prettyPrint();return false;">Css</a> '+
  33. '<a href="#" onclick="code.innerHTML=codeStr;code.className=\'prettyprint linenums\';prettyPrint();return false;">Raw</a>'+
  34. '<pre id="code" class="prettyprint linenums" style="word-wrap: break-word; white-space: pre-wrap;border: 1px solid rgb(136, 136, 204);border-radius: 8px;">' + codes + "</pre>";
  35. c.document.write(html);
  36. c.document.close();
  37. };
  38. document.body.appendChild(codeIcon);
  39. document.addEventListener('mouseup', function(o) {
  40. codeIcon.style.display="none";
  41. if (o.button === 0 && (o.ctrlKey || o.altKey || o.metaKey)) {
  42. setTimeout(function(){
  43. codes = document.getSelection().toString().replace(/\</g,"&lt;").replace(/\>/g,"&gt;");
  44. if(codes){
  45. codeIcon.style.display="block";
  46. let pos=getMousePos(o);
  47. codeIcon.style.top=pos.y+15+"px";
  48. codeIcon.style.left=pos.x+15+"px";
  49. }
  50. },1);
  51. }
  52. },false);
  53.  
  54. function getMousePos(event) {
  55. var e = event || window.event;
  56. var scrollX = document.documentElement.scrollLeft || document.body.scrollLeft;
  57. var scrollY = document.documentElement.scrollTop || document.body.scrollTop;
  58. var x = (e.pageX || e.clientX) - scrollX;
  59. var y = (e.pageY || e.clientY) - scrollY;
  60. return { 'x': x, 'y': y };
  61. }
  62. })();