ACE Editor在線代碼編輯器簡介及使用引導

ACE 是一個開源的、獨立的、基於瀏覽器的代碼編輯器,可以嵌入到任何web頁面或JavaScript應用程序中。ACE支持超過60種語言語法高亮,並能夠處理代碼多達400萬行的大型文檔。ACE開發團隊稱,ACE在性能和功能上可以媲美本地代碼編輯器(如Sublime Text、TextMate和Vim等)。

ACE是Mozilla Skywriter(以前稱爲Bespin)項目的繼任者,並作爲Cloud9的主要在線編輯器。

以下是它的詳細特性:

  • 可以對60多種語言進行語法着色(可以導入TextMate/Sublime/.tmlanguage 文件)
  • 20多種主題(可以導入TextMate/Sublime/.tmtheme文件)
  • 自動縮進,減少縮進
  • 一個可選的命令行
  • 處理巨大的文件,可以處理4,000,000行代碼
  • 完全自定義的鍵綁定,包括V正則表達式搜索和替換
  • 高亮匹配括號
  • 軟標籤和真正的標籤之間切換
  • 顯示隱藏的字符
  • 用鼠標拖放文本
  • 換行
  • 代碼摺疊
  • 多個光標和選擇
  • 實時語法檢查器(支持 JavaScript/CoffeeScript/CSS/XQuery)
  • 剪切,複製和粘貼功能IM和Emacs模式

項目地址:

  1. git clone git://github.com/ajaxorg/ace.git

相關項目:

使用引導:
1、引入

  1. var ace = require("lib/ace");

2、設置主題

  1. editor.setTheme("ace/theme/twilight");

3、設置程序語言模式

  1. editor.getSession().setMode("ace/mode/javascript");

4、一般常用操作
設置、獲取內容:

  1. editor.setValue("the new text here"); // or session.setValue
  2. editor.getValue(); // or session.getValue

獲取選擇內容:

  1. editor.session.getTextRange(editor.getSelectionRange());

在光標處插入:

  1. editor.insert("Something cool");

獲取光標所在行或列:

  1. editor.selection.getCursor();

跳轉到行:

  1. editor.gotoLine(lineNumber);

獲取總行數:

  1. editor.session.getLength();

設置默認製表符的大小:

  1. editor.getSession().setTabSize(4);

使用軟標籤:

  1. editor.getSession().setUseSoftTabs(true);

設置字體大小,這個其實不算API:

  1. document.getElementById('editor').style.fontSize='12px';

設置代碼摺疊:

  1. editor.getSession().setUseWrapMode(true);

設置高亮:

  1. editor.setHighlightActiveLine(false);

設置打印邊距可見度:

  1. editor.setShowPrintMargin(false);

設置編輯器只讀:

  1. editor.setReadOnly(true); // false to make it editable

5、觸發尺寸縮放
編輯器默認自適應大小,如果要程序控制resize,使用如下方法:

  1. editor.resize();

6、搜索

  1. editor.find('needle',{
  2. backwards: false,
  3. wrap: false,
  4. caseSensitive: false,
  5. wholeWord: false,
  6. regExp: false
  7. });
  8. editor.findNext();
  9. editor.findPrevious();

下列選項可用於您的搜索參數:
needle: 要查找的字符串或正則表達式
backwards: 是否反向搜索,默認爲false
wrap: 搜索到文檔底部是否回到頂端,默認爲false
caseSensitive: 是否匹配大小寫搜索,默認爲false
wholeWord: 是否匹配整個單詞搜素,默認爲false
range: 搜索範圍,要搜素整個文檔則設置爲空
regExp: 搜索內容是否是正則表達式,默認爲false
start: 搜索起始位置
skipCurrent: 是否不搜索當前行,默認爲false
替換單個字符:

  1. editor.find('foo');
  2. editor.replace('bar');

替換多個字符:

  1. editor.replaceAll('bar');

editor.replaceAll使用前需要先調用editor.find('needle', ...)
7、事件監聽
監聽改變事件:

  1. editor.getSession().on('change', function(e) {
  2. // e.type, etc
  3. });

監聽選擇事件:

  1. editor.getSession().selection.on('changeSelection', function(e) {
  2. });

監聽光標移動:

  1. editor.getSession().selection.on('changeCursor', function(e) {
  2. });

8、添加新命令、綁定按鍵
要指定鍵綁定到一個自定義函數:

  1. editor.commands.addCommand({
  2. name: 'myCommand',
  3. bindKey: {win: 'Ctrl-M', mac: 'Command-M'},
  4. exec: function(editor) {
  5. //...
  6. },
  7. readOnly: true // 如果不需要使用只讀模式,這裏設置false
  8. });
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章