JavaScript建立一個語法高亮輸入框?qū)崿F(xiàn)思路
更新時間:2013年02月26日 09:55:53 作者:
通常網(wǎng)站自帶的textarea編輯器不能滿足我們的需求比如高亮顯示代碼等,在這篇文章中,我將使用JavaScript庫ACE來創(chuàng)建一個輸入框效果,該腳本允許開發(fā)人員創(chuàng)建支持語法高亮的輸入框,感興趣的你可不要錯過了哈
textarea元素已被廣泛用于網(wǎng)頁Web的IDE。通常網(wǎng)站自帶的textarea編輯器不能滿足我們的需求,作為一名開發(fā)者我們經(jīng)常需要進(jìn)行代碼的在線編輯,高亮顯示代碼等,因此,通過其他的開源項(xiàng)目,我們可以添加一些實(shí)用的功能, 在這篇文章中,我將使用JavaScript庫ACE來創(chuàng)建一個輸入框效果。這是一個完全開源的腳本。該腳本允許開發(fā)人員創(chuàng)建支持語法高亮的輸入框。然后你可以代碼嵌入到網(wǎng)站中的任何地方
下載庫 首先我們需要Github上下載ACE代碼。 下載完成后解壓縮,在你的header部分引入js文件
<script src="src-min/ace.js" type="text/javascript" charset="utf-8"></script>
添加代碼到編輯器
首先設(shè)置一個id為editor的div 然后在script里面調(diào)用ace.edit()方法,代碼如下
var editor = ace.edit("editor");
editor.getSession().setMode("ace/mode/javascript");您可以重命名變量,為了方便起見,我定義了var editor作為變量,你也可以定義var demoeditor作為變量。第二行聲明使用哪種類型的語言高亮顯示。您可以從 src 目錄選擇其他語言集合。這里是一些支持支持的語言集合:
SQL
Ruby
SASS
PHP
Objectivec
Csharp
Java
JSON
使用額外的參數(shù)
editor.setTheme("ace/theme/dawn");
editor.getSession().setTabSize(2);
editor.getSession().setUseWrapMode(true);
這3行代碼是關(guān)于文本輸入效果的,第一行改變代碼默認(rèn)的語法顏色和主題,在src目錄下個有幾十個新的主題,你可以從中任意選擇
另外兩個選項(xiàng)是關(guān)于用戶體驗(yàn)。通常情況下,按一個鍵盤上的Tab鍵將輸入4個空格,這里我設(shè)置成2個空格,此外,該文本在默認(rèn)情況下將不會自動換行,超了會追加一個水平滾動條向外延伸。但使用這種方法setUseWrapMode(true),我們可以修復(fù)自動換行的問題。
還有一些其他的命令,你可以參考ACE向?qū)?。這里面包含了改變光標(biāo)的位置,動態(tài)添加新內(nèi)容,或復(fù)制的文本的全部內(nèi)容。
CSS代碼
#editor {
margin-left: 15px;
margin-top: 15px;
width: 1000px;
height: 400px;
}
下載庫 首先我們需要Github上下載ACE代碼。 下載完成后解壓縮,在你的header部分引入js文件
復(fù)制代碼 代碼如下:
<script src="src-min/ace.js" type="text/javascript" charset="utf-8"></script>
添加代碼到編輯器
首先設(shè)置一個id為editor的div 然后在script里面調(diào)用ace.edit()方法,代碼如下
復(fù)制代碼 代碼如下:
var editor = ace.edit("editor");
editor.getSession().setMode("ace/mode/javascript");您可以重命名變量,為了方便起見,我定義了var editor作為變量,你也可以定義var demoeditor作為變量。第二行聲明使用哪種類型的語言高亮顯示。您可以從 src 目錄選擇其他語言集合。這里是一些支持支持的語言集合:
SQL
Ruby
SASS
PHP
Objectivec
Csharp
Java
JSON
使用額外的參數(shù)
復(fù)制代碼 代碼如下:
editor.setTheme("ace/theme/dawn");
editor.getSession().setTabSize(2);
editor.getSession().setUseWrapMode(true);
這3行代碼是關(guān)于文本輸入效果的,第一行改變代碼默認(rèn)的語法顏色和主題,在src目錄下個有幾十個新的主題,你可以從中任意選擇
另外兩個選項(xiàng)是關(guān)于用戶體驗(yàn)。通常情況下,按一個鍵盤上的Tab鍵將輸入4個空格,這里我設(shè)置成2個空格,此外,該文本在默認(rèn)情況下將不會自動換行,超了會追加一個水平滾動條向外延伸。但使用這種方法setUseWrapMode(true),我們可以修復(fù)自動換行的問題。
還有一些其他的命令,你可以參考ACE向?qū)?。這里面包含了改變光標(biāo)的位置,動態(tài)添加新內(nèi)容,或復(fù)制的文本的全部內(nèi)容。
CSS代碼
復(fù)制代碼 代碼如下:
#editor {
margin-left: 15px;
margin-top: 15px;
width: 1000px;
height: 400px;
}

相關(guān)文章
js之切換全屏和退出全屏實(shí)現(xiàn)代碼實(shí)例
這篇文章主要介紹了js之切換全屏和退出全屏實(shí)現(xiàn)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09javaScript中push函數(shù)用法實(shí)例分析
這篇文章主要介紹了javaScript中push函數(shù)用法,較為詳細(xì)的分析了javascript中push函數(shù)的功能、定義及使用技巧,需要的朋友可以參考下2015-06-06基于js原生和ajax的get和post方法以及jsonp的原生寫法實(shí)例
下面小編就為大家?guī)硪黄趈s原生和ajax的get和post方法以及jsonp的原生寫法實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10Webpack實(shí)現(xiàn)按需打包Lodash的幾種方法詳解
這篇文章主要給大家介紹了關(guān)于Webpack實(shí)現(xiàn)按需打包Lodash的幾種方法,文中介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-05-05JavaScript使用localStorage存儲數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了JavaScript使用localStorage存儲數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09用javascript實(shí)現(xiàn)li 列表數(shù)據(jù)隔行變換背景顏色
客戶端效果,效率自然不錯。以前的做法是偶數(shù)行時給li加一個class,方法當(dāng)然不可取,如果后臺讀取再加class就很麻煩了,看看這個效果2007-08-08