react中使用Ace Editor編輯器

安裝插件

"ace-builds": "^1.4.12",
"react-ace": "^9.4.0",
"sql-formatter": "^4.0.2"

使用

import React, { Component } from 'react'
import { Button } from 'antd';
import AceEditor from 'react-ace';
// js編輯器插件中實(shí)現(xiàn)sql格式化 sql-formatter
import { format } from 'sql-formatter';
import 'ace-builds/src-noconflict/mode-sql'; // sql模式的包
import 'ace-builds/src-noconflict/mode-mysql';// mysql模式的包
import 'ace-builds/src-noconflict/theme-xcode';// xcode,(亮白)的主題樣式
import "ace-builds/src-noconflict/theme-twilight";// twilight,(暗黑)的主題樣式
//以下import的是風(fēng)格,還有好多種婉徘,可以根據(jù)自己需求導(dǎo)入
// github寄啼、tomorrow、kuioir卒落、twilight、xcode蜂桶、textmeta儡毕、terminal、solarized-light扑媚、solarized-dark
import 'ace-builds/src-noconflict/ext-language_tools'; //(編譯代碼的文件)


// console.log(format('SELECT * FROM tbl'));

export class index extends Component {
    constructor(props) {
        super(props)
    
        this.state = {
        }
    }
    
    // 美化代碼
    beautify = () => {
        this.setState({
            TextAceEditor: format(this.state.TextAceEditor)
        })
    }

        render() {
            // 增加需要自定義的代碼提示
            const completers = [
                {
                    name: 'name',
                    value: 'one',
                    score: 100,
                    meta: '阿Sir腰湾,看這里'
                },
                {
                    name: 'name',
                    value: 'two',
                    score: 100,
                    meta: '阿Sir,看這里'
                },
                {
                    name: 'name',
                    value: 'three',
                    score: 100,
                    meta: '阿Sir疆股,看這里'
                }
            ];


            const complete = editor => {
                editor.completers.push({
                    getCompletions: function (editors, session, pos, prefix, callback) {
                        callback(null, completers);
                    }
                });
            };

            // ————————————————
            // 版權(quán)聲明:本文為CSDN博主「IT和尚」的原創(chuàng)文章费坊,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明旬痹。
            // 原文鏈接:https://blog.csdn.net/u013040887/article/details/103310440/



            return (
                <div>
                    <AceEditor
                        mode='mysql' // 設(shè)置編輯語言 
                        theme="xcode" // 設(shè)置主題  cobalt monokai附井,twilight,(暗黑)讨越,xcode,(亮白)
                        name="app_code_editor"
                        fontSize={20} // 設(shè)置字號(hào)
                        onChange={ (value) => this.setState({TextAceEditor: value}) } // 獲取輸入框的 代碼
                        value={this.state.TextAceEditor} // 
                        style={{ width: '100%', height: 500 }}
                        setOptions={{
                            enableBasicAutocompletion: true,   //啟用基本自動(dòng)完成功能 不推薦使用
                            enableLiveAutocompletion: true,   //啟用實(shí)時(shí)自動(dòng)完成功能 (比如:智能代碼提示)
                            enableSnippets: true,  //啟用代碼段
                            showLineNumbers: true,
                            tabSize: 2,
                            wrap: true, // 換行
                            autoScrollEditorIntoView: true, // 自動(dòng)滾動(dòng)編輯器視圖
                        }}
                        onLoad={complete}
                    />
                    <Button type="primary" onClick={() => this.beautify()} >美化代碼</Button>
                </div>
            )
        }
    }

    export default index
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市永毅,隨后出現(xiàn)的幾起案子把跨,更是在濱河造成了極大的恐慌,老刑警劉巖沼死,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件着逐,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡意蛀,警方通過查閱死者的電腦和手機(jī)耸别,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來县钥,“玉大人秀姐,你說我怎么就攤上這事】猓” “怎么了囊扳?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)兜看。 經(jīng)常有香客問我锥咸,道長(zhǎng),這世上最難降的妖魔是什么细移? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任搏予,我火速辦了婚禮,結(jié)果婚禮上弧轧,老公的妹妹穿的比我還像新娘雪侥。我一直安慰自己,他們只是感情好精绎,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布速缨。 她就那樣靜靜地躺著,像睡著了一般代乃。 火紅的嫁衣襯著肌膚如雪旬牲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天搁吓,我揣著相機(jī)與錄音原茅,去河邊找鬼。 笑死堕仔,一個(gè)胖子當(dāng)著我的面吹牛擂橘,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播摩骨,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼通贞,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼朗若!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起滑频,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤捡偏,失蹤者是張志新(化名)和其女友劉穎唤冈,沒想到半個(gè)月后峡迷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡你虹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年绘搞,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片傅物。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡夯辖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出董饰,到底是詐尸還是另有隱情蒿褂,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布卒暂,位于F島的核電站啄栓,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏也祠。R本人自食惡果不足惜昙楚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望诈嘿。 院中可真熱鬧堪旧,春花似錦、人聲如沸奖亚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昔字。三九已至爆袍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間李滴,已是汗流浹背螃宙。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留所坯,地道東北人谆扎。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像芹助,于是被迫代替她去往敵國(guó)和親堂湖。 傳聞我的和親對(duì)象是個(gè)殘疾皇子闲先,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容