日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

Monaco Editor使用時右鍵功能菜單漢化

京東云 ? 來源:jf_75140285 ? 作者:jf_75140285 ? 2024-07-19 16:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

背景

某天產(chǎn)品要求在項目的某個頁面添加一個代碼編輯器,包含編輯器常見的功能。看完需求,想到了強大的Monaco Editor。按照官方文檔進行配置開發(fā),就在自己覺得大功告成之際,右擊編輯框,發(fā)現(xiàn)功能菜單是英文狀態(tài),然后就開啟了我的右鍵功能菜單漢化之路。

image.png

問題剖析

在Monaco Editor的整個使用配置過程中,我沒有添加關(guān)于本地語言的配置,所以目前使用的應該是默認配置。
所以目前解決問題的思路是:

查看官方API文檔尋找關(guān)于本地語言的配置

尋找可以進行本地語言配置的第三方插件/庫

按照以上思路首先在Monaco Editor官方文檔中進行一番搜索嘗試無果后,開始轉(zhuǎn)向相關(guān)第三方插件/庫的尋找,最終找到了monaco-editor-esm-webpack-plugin和monaco-editor/loader

解決方案

方案一:使用monaco-editor-esm-webpack-plugin

依賴下載

npm install monaco-editor-esm-webpack-plugin --save-dev

npm install monaco-editor monaco-editor-webpack-plugin monaco-editor-nls

vue.config.js文件

const MonacoWebpackPlugin = require('monaco-editor-esm-webpack-plugin');
configureWebpack: {
    plugins: [
        new MonacoWebpackPlugin()
    ]
}

xx.vue文件

import { setLocaleData } from 'monaco-editor-nls';
import zh_CN from 'monaco-editor-nls/locale/zh-hans';
setLocaleData(zh_CN);
// 先漢化語言,再加載monaco才能漢化成功,使用import方式無法漢化
// 需要使用require方式引入monaco-editor
const monaco = require('monaco-editor/esm/vs/editor/editor.api');

monaco.editor.create(document.getElementById('root'), { language: 'xml' });

效果圖如下:

image.png

從效果圖我們發(fā)現(xiàn)功能菜單的”命令面板“是中文的了,但是”Copy“還是英文

方案二:使用monaco-editor/loader

依賴下載

npm install @monaco-editor/loader

xx.vue

import loader from '@monaco-editor/loader';
loader.config({ 'vs/nls': { availableLanguages: { '*': 'zh-cn' } } }); // availableLanguages中可以配置想要的語言,例如de、zh-cn等
loader.init().then(monaco => {
    monaco.editor.create(document.querySelector("#mxlContainer"), {
    value: '',
    language: 'xml',
  });
});

至此已經(jīng)完成。瀏覽下效果圖

image.png


從效果圖來看已經(jīng)達到了我們的目標。但仔細看上方代碼發(fā)現(xiàn)我們用的monaco實例是monaco-editor/loader自動從CDN下載后返回的,
如果我們想通過npm包的方式使用應該怎么做呢?廢話不多說,直接上代碼

import loader from '@monaco-editor/loader';
import * as monaco from 'monaco-editor';
// 通過config方法我們可以配置我們使用的資源是通過非CDN方式引入
loader.config({ monaco });
// 需要注意本地語言(locales)的配置一定放在loader.config({ monaco })后邊,否則設置的locales會被npm包的monaco配置覆蓋,導致設置locales失敗
loader.config({ "vs/nls": { availableLanguages: { "*": "zh-cn" } } });
loader.init().then(monacoInstance => { 
    // 通過loader.config({monaco})的配置后,此處的monacoInstance其實是我們 import * as monaco from 'monaco-editor'進來的npm包
   monacoInstance.editor.create(document.querySelector("#mxlContainer"), {
    value: '',
    language: 'xml',
  }); 
});

版本

"monaco-editor": "^0.30.1"
"monaco-editor/loader": "^1.3.2"
"node": "v14.15.4"
"webpack": "v4.28.4"

小結(jié)

monaco-editor/loader會自動處理配置和加載monaco源碼,并且它的使用方式與項目打包方式解耦,只需在需要使用的文件中引入即可。使用方式靈活,適用范圍更加廣闊。

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編輯器
    +關(guān)注

    關(guān)注

    1

    文章

    829

    瀏覽量

    33078
  • Editor
    +關(guān)注

    關(guān)注

    0

    文章

    20

    瀏覽量

    14555
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    怎么清除不用的桌面右鍵菜單功能

    -----------------------------------------------------------------------@ ECHO 很多顯卡在裝了驅(qū)動之后,桌面右鍵會多出一項或多項菜單,這些功能
    發(fā)表于 05-07 08:58

    有圖有真相,Orcad Capture V16.3漢化版。有興趣的同學趕早!

    Orcad CaptureV16.3 V1漢化測試版,效果圖如下!親自試了一下,主菜單沒有漢化,作者描述漢化會導致程序不穩(wěn)定,菜單錯位。下拉
    發(fā)表于 11-13 17:41

    labview做一個右鍵功能菜單

    我想用labview做一個右鍵功能菜單誰會啊求助 我是新人
    發(fā)表于 11-28 09:53

    Protel99SE菜單完全漢化包,解決網(wǎng)上下載的漢化菜單部分菜...

    `Protel99SE菜單完全漢化,解決網(wǎng)上下載的漢化菜單部分菜單項缺失的問題,英語水平有限,有些翻譯可能不是特別貼切;
    發(fā)表于 07-22 23:05

    右鍵菜單出故障?

    點擊鼠標右鍵彈出菜單,有時候出現(xiàn)控件屬性,這個是怎么回事,無法解決?
    發(fā)表于 09-16 11:03

    動態(tài)創(chuàng)建右鍵自定義快捷菜單

    程序運行菜單一樣,當針對某對象的操作項比較多的時候,比較適合用右鍵快捷菜單來代替多個控件,用來精簡界面。(2)比較符合人右鍵查看功能的操作習
    發(fā)表于 09-15 00:06

    關(guān)于控件右鍵菜單的那個勾怎么顯示

    我知道可以右鍵從高級功能里自定義這個菜單,但是不知道怎么做出像默認控件的這種前面還有一個√的。另外還想問一下,如果我菜單只有兩個選項,怎么才可以讓其中一個顯示√,另一個不顯示。當點擊另
    發(fā)表于 12-12 01:11

    【干貨技巧】AD18如何漢化菜單標題?

    如果漢化最合適我們電工咯,那有何高招呢? 見下文:執(zhí)行菜單:Tools --> Preferences,彈出以下界面:接著選打鉤,彈出以下界面,按OK,再OK保存,最后關(guān)閉AD軟件,重新啟動,就可以看到菜單
    發(fā)表于 11-27 19:33

    如何漢化電子仿真軟件Multisim 7菜單

    如何漢化電子仿真軟件Multisim 7菜單:電子仿真軟件Multisim7 功能強大,使用方便,越來越受到廣大電子愛好者的喜歡,它必將在電子仿真和電路設計領域得到廣泛應用。有讀者來信詢
    發(fā)表于 10-23 08:15 ?93次下載

    如何清除多余的不用的桌面右鍵菜單

    如何清除多余的桌面右鍵菜單   復制下面內(nèi)容,保存為XX.bat,運行就就可以。怎么使用
    發(fā)表于 05-07 08:57 ?6863次閱讀
    如何清除多余的不用的桌面<b class='flag-5'>右鍵</b><b class='flag-5'>菜單</b>

    如何添加右鍵菜單

    如何添加右鍵菜單 1、在所有的文件右鍵菜單中加入命令 (1).打開“HKEY_CLASSES_ROOT*”;
    發(fā)表于 09-11 18:21 ?1.8w次閱讀

    JAVA教程之右鍵彈出菜單

    JAVA教程之右鍵彈出菜單,很好的學習資料。
    發(fā)表于 03-31 11:13 ?13次下載

    屏蔽超文本瀏覽框右鍵菜單

    易語言是一門以中文作為程序代碼編程語言學習例程:易語言-屏蔽超文本瀏覽框右鍵菜單
    發(fā)表于 06-06 17:36 ?3次下載

    Labview自定義右鍵快捷菜單功能實用小技巧

    Labview自定義右鍵快捷菜單功能實用小技巧
    發(fā)表于 02-11 11:27 ?28次下載

    谷歌Chrome瀏覽器新增功能:生成隨機右鍵菜單密碼

    據(jù)悉,Google已于Canary版本Chrome瀏覽器添加了“Password manual fallback”的實驗性標志,支持用戶通過右鍵菜單生成密碼建議。
    的頭像 發(fā)表于 05-14 09:46 ?2268次閱讀
    博兴县| 光泽县| 紫阳县| 兰考县| 榆社县| 敖汉旗| 德令哈市| 青龙| 呼伦贝尔市| 大渡口区| 平顶山市| 顺昌县| 乌鲁木齐市| 如东县| 曲麻莱县| 五大连池市| 罗定市| 上思县| 方城县| 莒南县| 黄龙县| 上思县| 平邑县| 彩票| 乐至县| 邢台县| 浦江县| 三江| 化隆| 海南省| 独山县| 扬中市| 河源市| 靖江市| 福鼎市| 兰溪市| 如皋市| 丰镇市| 长岛县| 镇远县| 揭东县|