Hello, 大家好~我是米洛,欢注迎我的关公号众测试开发坑货!

回顾

上节我们编写了JSON比对相关方法,虽然还没有运用到断言之中,但丝毫不影响我们插播另一篇文章。

其实我们的AceEditor引入许多主题的时候会有些卡顿,目前还不知道是主题太多呢,还是补全代码太多,所以我们先减少下主题再说。

但由于个人一直没有特别喜欢的主题,所以其实很是苦恼,但我看到leetcode的代码编辑器,又很羡慕,它的monaco-editor支持了material,如图。

测试平台系列(57) 美化代码编辑器 - 图1

调研一番

在经历了各种调研之后,发现了2个极品网站。

http://tmtheme-editor.herokuapp.com/#!/editor/theme/Material%20One%20Dark

  • 一键生成主题文件
    但是主题文件是tmTheme格式的,不是太好用。

测试平台系列(57) 美化代码编辑器 - 图2

我们找到自己最想要的2个: material one dark和atom dark

测试平台系列(57) 美化代码编辑器 - 图3

点击Download就可以下载到对应的主题文件啦,其实这文件是用于vscode之中的,但咱们想嵌入WebIDE怎么弄呢?

我们还有下面一个网站:

https://bitwiser.in/monaco-themes/

这个网站可以把主题文件转为JSON文件,这样就能嵌入到monaco编辑器了!

言归正传

不过话说回来,我们因为是要改造AceEditor,所以我们要找找AceEditor怎么添加自定义主题

苦心人,天不负。在Ace的github官网找到了这样的文档:

测试平台系列(57) 美化代码编辑器 - 图4

我们来翻译一下他的步骤:

  1. 把代码拉下来,进入tool文件夹,并安装依赖
  2. 把tmtheme文件放到ththemes目录里面
  3. 更新ththeme.js文件,包含我们的新主题
  4. 执行node tmtheme.js

简单粗暴!!!

试验一下

测试平台系列(57) 美化代码编辑器 - 图5

测试平台系列(57) 美化代码编辑器 - 图6

我这省略了npm install的步骤,我们直接node执行ththeme.js

测试平台系列(57) 美化代码编辑器 - 图7

我们去检查下有没有文件生成:

测试平台系列(57) 美化代码编辑器 - 图8

结合react-ace

因为我们用的是React组件,那么我们势必要像之前的主题一样import.

测试平台系列(57) 美化代码编辑器 - 图9

但我们生成了js和css,没事我们来看下比如monokai是怎么玩的:

测试平台系列(57) 美化代码编辑器 - 图10

这样就达到了只引入js就能有样式的目的,好家伙!!!

测试平台系列(57) 美化代码编辑器 - 图11

话不多说,我们也来试验一下:

测试平台系列(57) 美化代码编辑器 - 图12

照搬monokai的代码,把它require时候用的相对路径都改为绝对路径,最后把cssText用``括起来写进去。

cssClass等字段名字也要改掉哦~

  1. ace.define("ace/theme/material-one-dark",["require","exports","module","ace/lib/dom"], function(require, exports, module) {
  2. exports.isDark = false;
  3. exports.cssClass = "ace-material-one-dark";
  4. exports.cssText = `
  5. .ace-material-one-dark .ace_gutter {
  6. background: #272B33;
  7. color: rgb(103,111,122)
  8. }
  9. .ace-material-one-dark .ace_print-margin {
  10. // width: 1px;
  11. background: #e8e8e8
  12. }
  13. .ace-material-one-dark {
  14. background-color: #272B33;
  15. color: #A6B2C0
  16. }
  17. .ace-material-one-dark .ace_cursor {
  18. color: #528BFF
  19. }
  20. .ace-material-one-dark .ace_marker-layer .ace_selection {
  21. background: #3D4350
  22. }
  23. .ace-material-one-dark.ace_multiselect .ace_selection.ace_start {
  24. box-shadow: 0 0 3px 0px #272B33;
  25. border-radius: 2px
  26. }
  27. .ace-material-one-dark .ace_marker-layer .ace_step {
  28. background: rgb(198, 219, 174)
  29. }
  30. .ace-material-one-dark .ace_marker-layer .ace_bracket {
  31. margin: -1px 0 0 -1px;
  32. border: 1px solid #747369
  33. }
  34. .ace-material-one-dark .ace_marker-layer .ace_active-line {
  35. background: #2B313A
  36. }
  37. .ace-material-one-dark .ace_gutter-active-line {
  38. background-color: #2B313A
  39. }
  40. .ace-material-one-dark .ace_marker-layer .ace_selected-word {
  41. border: 1px solid #3D4350
  42. }
  43. .ace-material-one-dark .ace_fold {
  44. background-color: #61AEEF;
  45. border-color: #A6B2C0
  46. }
  47. .ace-material-one-dark .ace_keyword {
  48. color: #C679DD
  49. }
  50. .ace-material-one-dark .ace_keyword.ace_operator {
  51. color: #A6B2C0
  52. }
  53. .ace-material-one-dark .ace_keyword.ace_other.ace_unit {
  54. color: #D2945D
  55. }
  56. .ace-material-one-dark .ace_constant {
  57. color: #D2945D
  58. }
  59. .ace-material-one-dark .ace_constant.ace_numeric {
  60. color: #D2945D
  61. }
  62. .ace-material-one-dark .ace_constant.ace_character.ace_escape {
  63. color: #57B6C2
  64. }
  65. .ace-material-one-dark .ace_support.ace_function {
  66. color: #57B6C2
  67. }
  68. .ace-material-one-dark .ace_support.ace_class {
  69. color: #E5C17C
  70. }
  71. .ace-material-one-dark .ace_storage {
  72. color: #C679DD
  73. }
  74. .ace-material-one-dark .ace_invalid.ace_illegal {
  75. color: #272B33;
  76. background-color: #f2777a
  77. }
  78. .ace-material-one-dark .ace_invalid.ace_deprecated {
  79. color: #272B33;
  80. background-color: #d27b53
  81. }
  82. .ace-material-one-dark .ace_string {
  83. color: #90C378
  84. }
  85. .ace-material-one-dark .ace_string.ace_regexp {
  86. color: #57B6C2
  87. }
  88. .ace-material-one-dark .ace_comment {
  89. font-style: italic;
  90. color: #59626F
  91. }
  92. .ace-material-one-dark .ace_variable {
  93. color: #DF6A73
  94. }
  95. .ace-material-one-dark .ace_meta.ace_selector {
  96. color: #C679DD
  97. }
  98. .ace-material-one-dark .ace_entity.ace_other.ace_attribute-name {
  99. color: #D2945D
  100. }
  101. .ace-material-one-dark .ace_entity.ace_name.ace_function {
  102. color: #61AEEF
  103. }
  104. .ace-material-one-dark .ace_entity.ace_name.ace_tag {
  105. color: #DF6A73
  106. }
  107. .ace-material-one-dark .ace_markup.ace_list {
  108. color: #DF6A73
  109. }
  110. `;
  111. var dom = require("ace/lib/dom");
  112. dom.importCssString(exports.cssText, exports.cssClass);
  113. }); (function() {
  114. ace.require(["ace/theme/ace-material-one-dark"], function(m) {
  115. if (typeof module == "object" && typeof exports == "object" && module) {
  116. module.exports = m;
  117. }
  118. });
  119. })();

最终文件如上,我们给他取名叫MaterialOneDark.js,然后在编辑器引入:

测试平台系列(57) 美化代码编辑器 - 图13

测试平台系列(57) 美化代码编辑器 - 图14

看看效果:

测试平台系列(57) 美化代码编辑器 - 图15

心满意足,打完收工~!

在线体验地址: http://pity.buzz