序文Web 上でオンライン コード コンパイルの効果を実現したい場合は、
環境の準備npm インストール jshint npm インストール jsonlint npm スクリプトローダーをインストールします npm で vue-codemirror をインストールします パッケージコンポーネントプロジェクトの <テンプレート> <コードミラー ref="myCm" v-model="エディター値" :options="cmオプション" @changes="onCmCodeChanges" @blur="onCmBlur" @keydown.native="onKeyDown" @mousedown.native="onMouseDown" @paste.native="貼り付け時" > </codemirror> </テンプレート> <スクリプト> 「vue-codemirror」から { codemirror } をインポートします。 'codemirror/keymap/sublime' をインポートします 「codemirror/mode/javascript/javascript.js」をインポートします。 「codemirror/mode/xml/xml.js」をインポートします。 「codemirror/mode/htmlmixed/htmlmixed.js」をインポートします。 「codemirror/mode/css/css.js」をインポートします。 「codemirror/mode/yaml/yaml.js」をインポートします。 「codemirror/mode/sql/sql.js」をインポートします。 「codemirror/mode/python/python.js」をインポートします。 「codemirror/mode/markdown/markdown.js」をインポートします。 「codemirror/addon/hint/show-hint.css」をインポートします。 「codemirror/addon/hint/show-hint.js」をインポートします。 「codemirror/addon/hint/javascript-hint.js」をインポートします。 「codemirror/addon/hint/xml-hint.js」をインポートします。 「codemirror/addon/hint/css-hint.js」をインポートします。 「codemirror/addon/hint/html-hint.js」をインポートします。 「codemirror/addon/hint/sql-hint.js」をインポートします。 「codemirror/addon/hint/anyword-hint.js」をインポートします。 「codemirror/addon/lint/lint.css」をインポートします。 「codemirror/addon/lint/lint.js」をインポートします。 「codemirror/addon/lint/json-lint」をインポートします。 'codemirror/addon/selection/active-line' をインポートします。 「codemirror/addon/hint/show-hint.js」をインポートします。 「codemirror/addon/hint/anyword-hint.js」をインポートします。 スクリプトローダーのjsonlintが必要です。 「codemirror/addon/lint/javascript-lint.js」をインポートします。 「codemirror/addon/fold/foldcode.js」をインポートします。 「codemirror/addon/fold/foldgutter.js」をインポートします。 「codemirror/addon/fold/foldgutter.css」をインポートします。 「codemirror/addon/fold/brace-fold.js」をインポートします。 「codemirror/addon/fold/xml-fold.js」をインポートします。 「codemirror/addon/fold/comment-fold.js」をインポートします。 「codemirror/addon/fold/markdown-fold.js」をインポートします。 「codemirror/addon/fold/indent-fold.js」をインポートします。 「codemirror/addon/edit/closebrackets.js」をインポートします。 「codemirror/addon/edit/closetag.js」をインポートします。 「codemirror/addon/edit/matchtags.js」をインポートします。 「codemirror/addon/edit/matchbrackets.js」をインポートします。 「codemirror/addon/selection/active-line.js」をインポートします。 「codemirror/addon/search/jump-to-line.js」をインポートします。 「codemirror/addon/dialog/dialog.js」をインポートします。 「codemirror/addon/dialog/dialog.css」をインポートします。 「codemirror/addon/search/searchcursor.js」をインポートします。 「codemirror/addon/search/search.js」をインポートします。 「codemirror/addon/display/autorefresh.js」をインポートします。 「codemirror/addon/selection/mark-selection.js」をインポートします。 「codemirror/addon/search/match-highlighter.js」をインポートします。 エクスポートデフォルト{ 名前: "インデックス", コンポーネント: {codemirror}, プロパティ: ["cmTheme", "cmMode", "cmIndentUnit", "autoFormatJson"], データ() { 戻る { エディター値: '{}', オプション: { : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : 「CodeMirror-lint-markers」、 「CodeMirror-行番号」、 「CodeMirror-foldgutter」 ]、 ハイライト選択一致: { 最小文字数: 2, スタイル: "matchhighlight", 表示トークン: true }, }, enableAutoFormatJson: this.autoFormatJson == null ? true : this.autoFormatJson, // json 編集モードで、入力ボックスがフォーカスを失ったときに自動的にフォーマットするかどうか。有効にする場合は true、無効にする場合は false です} }, 作成された() { 試す { if (!this.editorValue) { this.cmOptions.lint = false; 戻る; } this.cmOptions.mode が "application/json" の場合 { AutoFormatJsonを有効にする場合 戻る; } this.editorValue = this.formatStrInJson(this.editorValue); } } キャッチ (e) { console.log("codemirror の初期化中にエラーが発生しました: " + e); } }, メソッド: { リセットリント() { (!this.$refs.myCm.codemirror.getValue())の場合{ this.$nextTick(() => { this.$refs.myCm.codemirror.setOption("lint", false); }); 戻る; } this.$refs.myCm.codemirror.setOption("lint", false); this.$nextTick(() => { this.$refs.myCm.codemirror.setOption("lint", true); }); }, //文字列をJSON形式の文字列としてフォーマットする formatStrInJson(strValue) { JSON.stringify() を返す JSON.parse(strValue)、 ヌル、 this.cmインデント単位 ); }, onCmCodeChanges(cm, 変更) { this.editorValue = cm.getValue(); この関数は、Lint をリセットします。 }, // フォーカスを失ったときの処理関数 onCmBlur(cm, event) { 試す { editorValue を cm.getValue() にします。 if (this.cmOptions.mode === "application/json" && editorValue) { AutoFormatJsonを有効にする場合 戻る; } エディター値 = this.formatStrInJson(エディター値); } } キャッチ (e) { // 何もしない} }, //キーボードイベント処理関数 onKeyDown(event) { const keyCode = event.keyCode || event.which || event.charCode; 定数キーの組み合わせ = イベント.ctrlキー || イベント.altキー || イベント.metaキー; if (!キーの組み合わせ && キーコード > 64 && キーコード < 123) { this.$refs.myCm.codemirror.showHint({ completeSingle: false }); } }, //マウスが押されたときのイベント処理関数 onMouseDown(event) { this.$refs.myCm.codemirror.closeHint(); }, // 貼り付けイベント処理関数 OnPaste(event) { this.cmOptions.mode が "application/json" の場合 { 試す { this.editorValue = this.formatStrInJson(this.editorValue); } キャッチ (e) { // 何もしない} } }, } } </スクリプト> <スタイルスコープ> </スタイル> このコンポーネントは、デフォルトでjsonコンパイラで構成されています。cmOptions 文字列を json 形式で入力したことがわかります。形式が正しくない場合でも、エラー メッセージが表示され、自動的にフォーマットされます。 Python コンパイラカプセル化するコンポーネントは、デフォルトでは JSON コンパイラです。他の言語を使用する場合も非常に簡単です。他の言語のモードをインポートするだけです。 <テンプレート> <div> <el-button type="primary" icon="el-icon-circle-check-outline" @click="handleConfirm" round> 保存をクリックします</el-button> <el-button icon="el-icon-caret-right" type="info" @click="handleRunCode" round> オンラインで実行</el-button> <コードエディタ :cmTheme="cmテーマ" :cmMode="cmMode" > </コードエディター> </div> </テンプレート> <スクリプト> '@/components/CodeEditor/index' から codeEditor をインポートします。 import 'codemirror/theme/monokai.css' // monokaiテーマをインポート import 'codemirror/mode/python/python.js' // pythonをインポート エクスポートデフォルト{ 名前: "インデックス", コンポーネント: コードエディター }, データ() { 戻る { cmテーマ:「モノカイ」 cmモード: "python", } }, メソッド: { ハンドル確認() {}, ハンドル実行コード() {} } } </スクリプト> <スタイル> .コードミラー { 位置: 相対的; 高さ:100vh; オーバーフロー: 非表示; 上マージン: 10px; } </スタイル> <style lang="scss" スコープ> </スタイル> 効果は以下のとおりです これで、vue codemirror のオンライン コード コンパイラの実装に関するこの記事は終了です。vue codemirror オンライン コード コンパイラに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Docker-compose インストール yml ファイルの設定方法
>>: MySQLは外部SQLスクリプトファイルのコマンドを実行します
目次1. 基本2. ノード、ツリー、仮想DOM 1. 仮想DOM 3. createElementパ...
目次1. 二重連結リストとは何か2. 双方向リンクリストのカプセル化3. 双方向リンクリストの一般的...
メインライブラリのバイナリログ: # 2420 で #170809 17:16:20 サーバー ID...
毎日jQueryプラグイン - 検索履歴を作成するためのものです。参考までに、具体的な内容は次のとお...
1. VPSとCentOSシステムを購入しましたが、サーバーの時間が北京時間と一致せず、時差があるこ...
JSON 文字列を JSON オブジェクトに変換するにはどうすればいいですか? JSON.parse...
Linux での Hadoop インストール チュートリアルはインターネットや書籍に多数ありますが、...
公式サイトの説明: コンポーネントを定義する場合、コンポーネントは複数のインスタンスを作成するために...
Docker コンテナはサービスを提供し、ポート 8888 をリッスンします。外部からアクセスできる...
MySQL ストアド プロシージャ パラメータには、in、out、inout の 3 種類があります...
序文Linux サーバーを操作および管理するときに、最もよく使用されるコマンドの 1 つが nets...
目次nginxとは1. 必要な依存関係をダウンロードする2. nginxの圧縮パッケージをダウンロー...
序文以前のプロジェクトでは、SQL の CASE WHEN ソート関数が使用されました。ではブログメ...
この記事では、jQuery キャンバスを使用して QR コード付きのポスターを生成するための具体的な...
Linux でバージョン情報を表示する方法。ビット数、バージョン情報、CPU コア情報、CPU 固有...