优化方法 1 2 3 4 5 6 7 8 import * as monaco from 'monaco-editor'; // or import * as monaco from 'monaco-editor/esm/vs/editor/editor.api'; // if shipping only a subset of the features & languages is desired monaco.editor.create(document.getElementById('container'), { value: 'console.log("Hello, world")', language: 'javascript' });
.只需要把
import * as Monaco from ‘monaco-editor’
换成
import * as Monaco from ‘monaco-editor/esm/vs/editor/editor.api’
即可
方法出处:[https://github.com/microsoft/monaco-editor/tree/main/webpack-plugin#:~:text=if%20shipping%20only%20a%20subset%20of%20the%20features%20%26%20languages%20is%20desired] (https://github.com/microsoft/monaco-editor/tree/main/webpack-plugin#:~:text=if shipping only a subset of the features %26 languages is desired)
原因
根据官方文档描述
By default, all languages shipped with the monaco-editor will be included.
默认情况下monaco-editor会包含所有的语言文件
优化前效果 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 > vite build --config ./config/vite.config.prod.ts vite v3.0.4 building for production... 12:23:56 ✓ 160 modules transformed. 12:24:35 ✓ 183 modules transformed. 12:24:36 ✓ 186 modules transformed. 12:24:41 ✓ 187 modules transformed. 12:24:42 ✓ 229 modules transformed. 12:24:46 ✓ 6391 modules transformed. 12:25:13 dist/assets/logo.b4229389.svg 20.28 KiB 12:25:18 dist/assets/codicon.c99115f8.ttf 69.12 KiB 12:25:18 dist/assets/editor.worker.55353356.js 166.90 KiB 12:25:18 dist/assets/json.worker.2be2570f.js 292.56 KiB 12:25:18 dist/assets/html.worker.3376e5b8.js 602.41 KiB 12:25:18 dist/assets/css.worker.1bba75ea.js 901.06 KiB 12:25:18 dist/assets/ts.worker.9acd5107.js 4777.10 KiB 12:25:18 dist/index.html 0.68 KiB 12:25:18 dist/assets/azcli.4c9b6b47.js 1.07 KiB / gzip: 0.45 KiB 12:25:18 dist/assets/bat.8a420ace.js 2.04 KiB / gzip: 0.98 KiB 12:25:18 dist/assets/bicep.5032e09b.js 2.72 KiB / gzip: 1.08 KiB 12:25:18 dist/assets/apex.4a5ec4a4.js 4.10 KiB / gzip: 1.86 KiB 12:25:18 dist/assets/cameligo.00bc63f8.js 2.37 KiB / gzip: 1.07 KiB 12:25:18 dist/assets/coffee.54897858.js 3.75 KiB / gzip: 1.41 KiB 12:25:18 dist/assets/cpp.337468ce.js 5.56 KiB / gzip: 2.20 KiB 12:25:18 dist/assets/csp.aec2811b.js 1.63 KiB / gzip: 0.65 KiB 12:25:18 dist/assets/csharp.01a8eaa8.js 4.66 KiB / gzip: 1.82 KiB 12:25:18 dist/assets/css.4c22ed20.js 4.64 KiB / gzip: 1.48 KiB 12:25:18 dist/assets/dockerfile.de6a0f2c.js 2.07 KiB / gzip: 0.79 KiB 12:25:18 dist/assets/abap.6ba285e6.js 14.07 KiB / gzip: 5.34 KiB 12:25:18 dist/assets/dart.50deccbd.js 4.39 KiB / gzip: 1.73 KiB 12:25:18 dist/assets/flow9.c44e3f2e.js 2.01 KiB / gzip: 0.96 KiB 12:25:18 dist/assets/clojure.bc79377e.js 9.66 KiB / gzip: 3.65 KiB 12:25:18 dist/assets/ecl.19ccc34b.js 5.46 KiB / gzip: 2.33 KiB 12:25:18 dist/assets/elixir.a6460ae7.js 9.77 KiB / gzip: 2.55 KiB 12:25:18 dist/assets/fsharp.d9204eef.js 3.15 KiB / gzip: 1.42 KiB 12:25:18 dist/assets/go.1e1292ae.js 2.83 KiB / gzip: 1.25 KiB 12:25:18 dist/assets/graphql.900d9927.js 2.45 KiB / gzip: 1.13 KiB 12:25:18 dist/assets/handlebars.37474df0.js 6.85 KiB / gzip: 1.69 KiB 12:25:18 dist/assets/ini.75848fa5.js 1.32 KiB / gzip: 0.66 KiB 12:25:18 dist/assets/hcl.c0959a07.js 3.75 KiB / gzip: 1.58 KiB 12:25:18 dist/assets/html.b86df8d8.js 4.96 KiB / gzip: 1.46 KiB 12:25:18 dist/assets/javascript.cec1b257.js 1.15 KiB / gzip: 0.60 KiB 12:25:18 dist/assets/java.13c44e5c.js 3.39 KiB / gzip: 1.50 KiB 12:25:18 dist/assets/freemarker2.23a5c729.js 15.95 KiB / gzip: 4.15 KiB 12:25:18 dist/assets/typescript.f4b5ff31.js 5.50 KiB / gzip: 2.21 KiB 12:25:18 dist/assets/kotlin.3399aeb6.js 3.60 KiB / gzip: 1.57 KiB 12:25:18 dist/assets/lexon.44f813b3.js 2.62 KiB / gzip: 1.04 KiB 12:25:18 dist/assets/julia.21f68d09.js 7.29 KiB / gzip: 2.69 KiB 12:25:18 dist/assets/less.b6aad23a.js 4.04 KiB / gzip: 1.52 KiB 12:25:18 dist/assets/lua.bbdfa9c0.js 2.31 KiB / gzip: 1.04 KiB 12:25:18 dist/assets/mips.148d2978.js 2.76 KiB / gzip: 1.19 KiB 12:25:18 dist/assets/m3.92f755b1.js 2.99 KiB / gzip: 1.41 KiB 12:25:18 dist/assets/markdown.236ff8ef.js 3.94 KiB / gzip: 1.48 KiB 12:25:18 dist/assets/liquid.c200d198.js 4.10 KiB / gzip: 1.74 KiB 12:25:18 dist/assets/objective-c.67633c2a.js 2.59 KiB / gzip: 1.17 KiB 12:25:18 dist/assets/pascaligo.1c7de3c7.js 2.19 KiB / gzip: 1.03 KiB 12:25:18 dist/assets/msdax.f39564e2.js 5.04 KiB / gzip: 2.05 KiB 12:25:18 dist/assets/pascal.c9d19959.js 3.17 KiB / gzip: 1.50 KiB 12:25:18 dist/assets/pla.c3f817e8.js 1.88 KiB / gzip: 0.77 KiB 12:25:18 dist/assets/perl.140c1c72.js 8.30 KiB / gzip: 3.16 KiB 12:25:18 dist/assets/php.a9540a84.js 8.08 KiB / gzip: 2.15 KiB 12:25:18 dist/assets/mysql.fdc04fe1.js 11.23 KiB / gzip: 4.09 KiB 12:25:18 dist/assets/powershell.d93de61d.js 3.43 KiB / gzip: 1.47 KiB 12:25:18 dist/assets/pgsql.1a3b46c8.js 13.33 KiB / gzip: 4.50 KiB 12:25:18 dist/assets/postiats.8064247a.js 7.91 KiB / gzip: 2.49 KiB 12:25:18 dist/assets/protobuf.0ea0cf3d.js 9.07 KiB / gzip: 2.15 KiB 12:25:18 dist/assets/python.ae9bd45d.js 3.74 KiB / gzip: 1.66 KiB 12:25:18 dist/assets/pug.03a3b993.js 4.96 KiB / gzip: 1.74 KiB 12:25:18 dist/assets/r.1e4576a7.js 3.30 KiB / gzip: 1.39 KiB 12:25:18 dist/assets/qsharp.c08b4fea.js 3.10 KiB / gzip: 1.46 KiB 12:25:18 dist/assets/powerquery.bc98d188.js 16.78 KiB / gzip: 4.88 KiB 12:25:18 dist/assets/restructuredtext.992abef6.js 4.04 KiB / gzip: 1.46 KiB 12:25:18 dist/assets/redis.8da5f515.js 3.71 KiB / gzip: 1.58 KiB 12:25:18 dist/assets/sb.e7ab3b92.js 2.03 KiB / gzip: 0.94 KiB 12:25:18 dist/assets/rust.349e1143.js 4.30 KiB / gzip: 1.91 KiB 12:25:18 dist/assets/razor.12f90da6.js 8.80 KiB / gzip: 2.35 KiB 12:25:18 dist/assets/scheme.d835dccb.js 1.97 KiB / gzip: 0.93 KiB 12:25:18 dist/assets/ruby.71d129bb.js 8.54 KiB / gzip: 2.64 KiB 12:25:18 dist/assets/scala.ef542eb6.js 7.39 KiB / gzip: 2.17 KiB 12:25:18 dist/assets/shell.4305d323.js 3.24 KiB / gzip: 1.31 KiB 12:25:18 dist/assets/sophia.69f82176.js 2.94 KiB / gzip: 1.31 KiB 12:25:18 dist/assets/scss.19caa34f.js 6.50 KiB / gzip: 1.84 KiB 12:25:18 dist/assets/st.3f9156a8.js 7.46 KiB / gzip: 2.31 KiB 12:25:18 dist/assets/sql.5f2f7ebd.js 10.30 KiB / gzip: 3.89 KiB 12:25:18 dist/assets/swift.575aa114.js 5.29 KiB / gzip: 2.15 KiB 12:25:18 dist/assets/sparql.1dcfd6e8.js 2.73 KiB / gzip: 1.27 KiB 12:25:18 dist/assets/tcl.50105b28.js 3.73 KiB / gzip: 1.47 KiB 12:25:18 dist/assets/redshift.4a60845d.js 11.76 KiB / gzip: 4.35 KiB 12:25:18 dist/assets/solidity.212cde55.js 18.40 KiB / gzip: 4.48 KiB 12:25:18 dist/assets/xml.4337ae7f.js 2.59 KiB / gzip: 1.06 KiB 12:25:18 dist/assets/twig.74745959.js 6.07 KiB / gzip: 1.62 KiB 12:25:18 dist/assets/systemverilog.a897e382.js 7.67 KiB / gzip: 2.82 KiB 12:25:18 dist/assets/yaml.7d8c6ae6.js 3.70 KiB / gzip: 1.33 KiB 12:25:18 dist/assets/vb.42b9f30d.js 5.90 KiB / gzip: 2.14 KiB 12:25:18 dist/assets/tsMode.b126b833.js 21.74 KiB / gzip: 6.27 KiB 12:25:18 dist/assets/htmlMode.75dc5775.js 33.40 KiB / gzip: 8.79 KiB 12:25:18 dist/assets/cssMode.64adcf2e.js 32.66 KiB / gzip: 8.65 KiB 12:25:18 dist/assets/jsonMode.1a7b82cd.js 38.76 KiB / gzip: 10.77 KiB 12:25:18 dist/assets/monaco.d7562f15.css 79.13 KiB / gzip: 13.34 KiB 12:25:18 dist/assets/index.2d7343dc.js 161.36 KiB / gzip: 54.37 KiB 12:25:18 dist/assets/index.1da917fa.css 355.96 KiB / gzip: 74.46 KiB 12:25:18 dist/assets/core.8989ee89.js 539.72 KiB / gzip: 180.41 KiB 12:25:18 dist/assets/monaco.5273bca9.js 2600.87 KiB / gzip: 659.07 KiB 12:25:18
可以看到一坨的语言都被打包进去了,不管有没有用到都在里面
优化后效果 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 > vite build --config ./config/vite.config.prod.ts vite v3.0.4 building for production... 12:15:43 ✓ 160 modules transformed. 12:16:21 ✓ 185 modules transformed. 12:16:23 ✓ 186 modules transformed. 12:16:24 ✓ 187 modules transformed. 12:16:24 ✓ 229 modules transformed. 12:16:33 ✓ 6009 modules transformed. 12:16:55 dist/assets/logo.b4229389.svg 20.28 KiB 12:17:04 dist/assets/codicon.c99115f8.ttf 69.12 KiB 12:17:04 dist/assets/editor.worker.55353356.js 166.90 KiB 12:17:04 dist/assets/json.worker.2be2570f.js 292.56 KiB 12:17:04 dist/assets/html.worker.3376e5b8.js 602.41 KiB 12:17:04 dist/assets/css.worker.1bba75ea.js 901.06 KiB 12:17:04 dist/assets/ts.worker.9acd5107.js 4777.10 KiB 12:17:04 dist/index.html 0.68 KiB 12:17:04 dist/assets/monaco.16ea583f.css 79.13 KiB / gzip: 13.36 KiB 12:17:04 dist/assets/index.f40ca15f.js 161.36 KiB / gzip: 54.37 KiB 12:17:04 dist/assets/index.1da917fa.css 355.96 KiB / gzip: 74.46 KiB 12:17:04 dist/assets/core.8989ee89.js 539.72 KiB / gzip: 180.41 KiB 12:17:04 dist/assets/monaco.5c75dc57.js 1730.89 KiB / gzip: 440.94 KiB 12:17:04