在整合Ace過程中發現網路搜到資料比較零碎,且中文資料比較少,本文主要做一些記錄和整理,方便後續查閱
- 在Vue專案中整合Ace程式碼編輯器
- Ace配置項目的中文對照
- 踩坑:解決Ace editor 遊標錯位問題
- #最佳化:按需使用ace-builds
Ace 是一個用JavaScript 編寫的可嵌入程式碼編輯器。它與 Sublime、Vim 和 TextMate 等原生編輯器的功能和效能相符。它可以很容易地嵌入到任何網頁和 JavaScript 應用程式中。 Ace 被維護為Cloud9 IDE的主要編輯器 ,並且是 Mozilla Skywriter (Bespin) 專案的繼承者。
使用正則表達式搜尋和替換使用滑鼠拖放文字
程式碼折疊
多個遊標和選擇
即時語法檢查器(目前為JavaScript/CoffeeScript/CSS/XQuery)剪下、複製和貼上功能快速開始
你也可以直接使用vue2-ace-editor ,依照步驟整合即可
這裡主要記錄使用ace-builds,在專案中自己封裝Ace元件#安裝
npm install ace-builds --save-dev复制代码
安裝完的效果如下:
#整合
#在AceEditor文件,新建index.vue,程式碼如下:關於webpack-resolver.js的最佳化<template> <div ref="editorform" style="height: 250px" > </div> </template> <script> import ace from 'ace-builds' import './webpack-resolver' // 自定义webpack-resolver,按需引入 import 'ace-builds/src-noconflict/mode-json' import 'ace-builds/src-noconflict/mode-mysql' import 'ace-builds/src-noconflict/mode-text' import 'ace-builds/src-noconflict/theme-tomorrow' import 'ace-builds/src-min-noconflict/ext-language_tools' import { onMounted, onBeforeUnmount, ref, watch } from '@vue/composition-api' export default { name: 'AceEditor', emits: ['onChange'], props: { value: { type: String, default: '', }, // 这里可以接收更多组件传递的参数,做一些自定义效果 }, setup(props, vm) { let editor = null const editorform = ref(null) let options = { theme: 'ace/theme/tomorrow', // 主题 mode: 'ace/mode/mysql', // 代码匹配模式 tabSize: 2, //标签大小 fontSize: 14, //设置字号 wrap: true, // 用户输入的sql语句,自动换行 enableSnippets: true, // 启用代码段 showLineNumbers: true, // 显示行号 enableLiveAutocompletion: true, // 启用实时自动完成功能 (比如:智能代码提示) enableBasicAutocompletion: true, // 启用基本自动完成功能 scrollPastEnd: true, // 滚动位置 highlightActiveLine: true, // 高亮当前行 } const init = () => { if (editor) { //实例销毁 editor.destroy() } //初始化 editor = ace.edit(editorform.value, options) editor.setValue(props.value ? props.value : '') // 设置内容 editor.on('change', () => { vm.emit('onChange', editor.getValue()) }) } onMounted(() => { init() }) onBeforeUnmount(() => { editor.destroy() editor.container.remove() }) return { editorform } }, } </script> <style> @import '~ace-builds/css/ace.css'; </style>登入後複製
在webpack 環境中需要導入webpack-resolver.js,我們先看下node_modules/ace-builds/webpack-resolver .js文件,裡面大部分模組是我們用不到的,直接引入的話,會大大增加項目包的體積,所以這裡我們需要做下優化:按需引入
在AceEditor文件,新建webpack-resolver.js, 程式碼如下:
ace.config.setModuleUrl('ace/mode/mysql', require('file-loader?esModule=false!ace-builds/src-noconflict/mode-mysql.js')) ace.config.setModuleUrl('ace/mode/text', require('file-loader?esModule=false!ace-builds/src-noconflict/mode-text.js')) ace.config.setModuleUrl('ace/mode/json', require('file-loader?esModule=false!ace-builds/src-noconflict/mode-json.js')) ace.config.setModuleUrl('ace/theme/tomorrow', require('file-loader?esModule=false!ace-builds/src-noconflict/theme-tomorrow.js')) ace.config.setModuleUrl('ace/ext/language_tools', require('file-loader?esModule=false!ace-builds/src-noconflict/ext-language_tools.js'))
在專案的src目錄下,新建registAce.js
import ACE from '@/components/AceEditor' // 这里是你创建的AceEditor文件夹的路径 export default { install(Vue) { Vue.component('ace', ACE) }, }
在Vue 專案的入口檔案main.js 中引入Ace 模組, Vue.use()全域註冊ace元件
import ace from 'ace-builds' import RegistAce from './registAce' Vue.use(ace) Vue.use(RegistAce)
<ace v-model="content" @onChange="onChange"> </ace>
Ace官網設定項目
setOption(optionName, optionValue) setOptions({ optionName : optionValue ... }) getOption(optionName) getOptions()
選項名稱 | #值類型 | 預設值 | #可選值 | 功能 |
---|---|---|---|---|
selectionStyle | #String | text | line | text | 選取樣式 |
highlightActiveLine | Boolean | true | - | 高亮目前行 |
highlightSelectedWord | Boolean | #true | - | 高亮選取文字 |
#readOnly | Boolean | false | - | 是否只讀 |
cursorStyle | String | ace | ace | slim | smooth | wide | 遊標樣式 |
String | Boolean | false | always | 合併撤銷 | |
Boolean | true | - | 啟用行為 | |
Boolean | true | - | 啟用換行 | |
Boolean | false | #- | 啟用捲動 | |
Boolean | true | ##- | 複製空格 | |
#useSoftTabs | Boolean | false | ||
使用軟標籤 | navigateWithinSoftTabs | Boolean | false | |
軟體標籤跳轉 | ##enableMultiselect | #Boolean | false | - |
#選項名稱 | 值類型 | 預設值 | 可選值 | |
---|---|---|---|---|
hScrollBarAlwaysVisible | Boolean | |||
- | 縱向捲總是可見 | |||
##vScrollBarAlwaysVisible | Boolean | false | - | 橫向捲軸始終可見 |
highlightGutterLine | Boolean | true | - | 高亮邊線 |
animatedScroll | Boolean | false | - | 捲動動畫 |
showInvisibles | Boolean | #false | - | 顯示不可見字元 |
showPrintMargin | Boolean | true | ##-顯示列印邊距 | |
#Number | 80 | - | ||
##設定頁邊距 | printMargin | |||
false | - | 顯示並設定頁邊距 | fadeFoldWidgets | |
false | - | 淡入摺疊元件 | showFoldWidgets | |
true | - | 顯示折疊元件 | ||
showLineNumbers | Boolean | true | ||
顯示行號 | ##showGutter | |||
#布林 | true |
Boolean | ||||
---|---|---|---|---|
# #true | - | 顯示參考線 | fontSize | |
inherit | - | 設定字號 | fontFamily | |
inherit | ||||
選項名稱 | #值型別 | 預設值 | 可選值 | 備註 |
---|---|---|---|---|
firstLineNumber | Number | ##1- | #起始行號 | |
Boolean | - | - | 重做 | |
String | auto | #auto | unix |windows | #新開行模式 | |
Boolean | - | - | 使用輔助物件 | |
Boolean | - | - | 使用軟標籤 | |
##Number | - | - | 標籤大小 | |
Boolean | - | - | 換行 | |
String | - | markbegin | markbeginend | manual | 折疊樣式 | |
#String | - | ##-程式碼匹配模式,例如「ace/mode/text" |
預設值 | 可選值 | 備註 | ||
---|---|---|---|---|
- | - | 啟用基本自動完成 | enableLiveAutocompletion | |
- | - | 啟用即時自動完成 | #enableSnippets | |
# - | - | 啟用程式碼段 | enableEmmet | |
- | - | 啟用Emmet | useElasticTabstops | |
- | - | #使用彈性製表位 |
,導致計算不準確,將編輯框裡面的字體設定為等寬字體即可解決問題⚠️注意:這裡還有個小坑,在設定等寬字體時需要區分Mac、Windows
Mac 下可以使用
monospaceWindows 下可以使用
Consolas
參考網站/ 原始碼以上是圖文詳解如何在Vue專案中整合Ace程式碼編輯器的詳細內容。更多資訊請關注PHP中文網其他相關文章!