ace.js实现一个在线代码编辑器[通俗易懂]

ace.js实现一个在线代码编辑器[通俗易懂]TableofContents背景ACE简介:功能实现1、引入js2、初始化组件3、保存时代码语法检测4、效果图:5、遇到的一些问题:背景项目需要,在一些场景,用户需要手动编写一些js脚本来实现自己的功能;前期一直用文本框显示,不便于编辑和查看。因此需要引入一个在线代码编辑器。效果如下:ACE简介:ACE是一个开源的、独立的、基于浏览器的代码编辑器,可以嵌入到任何web页面或JavaScript应用…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

背景

ACE简介:

功能实现

1、引入js

         2、添加控件

3、初始化组件

4、保存时代码语法检测 

5、效果图:

6、官网在线测试: 

7、遇到的一些问题:


背景

      项目需要,在一些场景,用户需要手动编写一些js脚本来实现自己的功能;前期一直用文本框显示,不便于编辑和查看。因此需要引入一个在线代码编辑器。效果如下:

         ace.js实现一个在线代码编辑器[通俗易懂]

ACE简介:

        ACE是一个开源的、独立的、基于浏览器的代码编辑器,可以嵌入到任何web页面或JavaScript应用程序中。ACE支持超过40种语言语法高亮,缩进,代码提示功能且具有大量的主题;并能够处理代码多达404万行的大型文档。ACE开发团队称,ACE在性能和功能上可以媲美本地代码编辑器(如SublimeText、TextMate和Vim等)。

官方网址:https://ace.c9.io
Github地址:https://github.com/ajaxorg/ace

支持语言:java、javascript、json、jsp、markdown、mysql、nginx…

功能实现

1、引入js

   方式一:下载源码   

  下载地址1:https://github.com/ajaxorg/ace-builds/

<!-- 代码编辑ace.js  本地-->
<script src="../js/ace/src-min/ace.js" type="text/javascript"></script>	
<script src="../js/ace/src-min/ext-language_tools.js" type="text/javascript"></script>	

方式二: 引用在线的  

bootstrap中文网提供的cdn服务;http://www.bootcdn.cn/

<!-- 代码编辑ace.js   远程  -->
 <script src="http://cdn.bootcss.com/ace/1.2.4/ace.js"></script>
 <script src="http://cdn.bootcss.com/ace/1.2.4/ext-language_tools.js"></script>

 

2、添加控件

<pre id="codeEditor" class="ace_editor" style="min-height:320px">
 <s:textarea class="ace_text-input"   cssStyle="width:97.5%;height:320px;"/>
</pre>

3、初始化组件

//初始化代码编辑器
	function initEditor(){
		//获取控件   id :codeEditor
		editor = ace.edit("codeEditor");
		//设置风格和语言(更多风格和语言,请到github上相应目录查看)
		theme = "monokai";
		//theme = "terminal";
		//语言
		language = "javascript";
		editor.setTheme("ace/theme/" + theme);
		editor.session.setMode("ace/mode/" + language);
		//字体大小
		editor.setFontSize(15);
		//设置只读(true时只读,用于展示代码)
		editor.setReadOnly(false);
		//自动换行,设置为off关闭
		editor.setOption("wrap", "free");
		//启用提示菜单
		ace.require("ace/ext/language_tools");
		editor.setOptions({
			enableBasicAutocompletion: true,
			enableSnippets: true,
			enableLiveAutocompletion: true
		});
	}

4、保存时代码语法检测 

(正常情况下,输入的代码存在语法错误时会有红色叉号提示;由于本项目中的代码会多达几百行,所以,在保存时需要获取一下编辑的的语法校验结果,存在异常时给出提示。)

        
//获取编辑器中语法校验的结果
var annotations = editor.getSession().getAnnotations();
//错误
var error="";
var errorNum=0;
//警告
var warning="";
var warningNum=0;
//遍历结果 记录提示信息
for(var aid = 0, alen = annotations.length; aid < alen; ++aid) {
	var row=annotations[aid].row+1;
	//存在错误 必须修改
	if(annotations[aid].type === 'error') {
	    var txt=" 行:"+row+";列:"+annotations[aid].column+";  提示:"+annotations[aid].text;
		error+=txt+"<br>";
		errorNum++;
	}
	//存在警告 可以不修改
	if(annotations[aid].type === 'warning'||annotations[aid].type === 'info') {
		var txt=" 行:"+row+";列:"+annotations[aid].column+";  提示 : "+annotations[aid].text;
		warning+=txt+"<br>";
		warningNum++;
	}
}
//存在错误 必须修改
if( error!="") {
	
			
}else {
//存在警告 可以不修改
if(warning!="") {
			 
	} 
        }

5、效果图:

   存在语法错误时(当语法存在错误时,会有红色叉号或黄色叹号,把鼠标放上去会显示提示信息):   ace.js实现一个在线代码编辑器[通俗易懂]

 

 正常时:

ace.js实现一个在线代码编辑器[通俗易懂]

在线效果可参考: https://www.w3cschool.cn/tryrun/runcode?lang=javascript

6、官网在线测试: 

https://ace.c9.io/build/kitchen-sink.html

基本所有的效果都可以在这测试,很方便。

ace.js实现一个在线代码编辑器[通俗易懂]

7、遇到的一些问题:

 1、可校验错误数默认为50个;当超过100多行时或者错误过多少时,之后的代码无法校验语法。所以下载了源码,源码中的错误检测数量(只是js其他的不清楚)。这里js的语法校验时引用了另一个插件 jshint插件;在引用时会有个初始化,初始化里有个参数是maxerr 由默认的50改为10000。  https://www.w3cschool.cn/tryrun/runcode?lang=javascript 也存在这个问题。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170425.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java单元测试框架 JUnit

    Java单元测试框架 JUnit

    2021年11月18日
    36
  • 结构体 变迁

    结构体 变迁

    2021年12月6日
    39
  • vue axios轮询更新echarts 页面崩溃问题

    vue axios轮询更新echarts 页面崩溃问题之前做过一个项目测试发现这个问题,就是页面停留3,4个小时之后页面崩溃了后来观察了浏览器的Memory发现echarts实例还有echarts数据缓存在不断累积解决:刚开始看了echarts官方api确实提供了echarts.clear()清空当前实例,会移除实例中所有的组件和图表。用了以后发现作用不是很大还是会崩溃。那就是实例的问题了刚开始只是加了个判断 letmyEcharts if(!myEcharts){ myEcharts=echarts.init

    2025年6月16日
    0
  • 2021年7月整理–简单方法 暴力激活成功教程WIFI密码

    2021年7月整理–简单方法 暴力激活成功教程WIFI密码2021年7月整理–简单方法暴力激活成功教程WIFI密码很多人都面临过短期租房、短期出差、住院而没有WIFI可用等境遇,有的是宽带太多办不起、有的是临时一阵子不值得折腾、有的是运营商不给扯线等等原因。然后就用手机下载了WIFI智能钥匙等APP,然后发现卵用么有,根本没有人共享自家WIFI密码给你用。以下是按步骤整理的软件和详细教程笔记本电脑+软件暴力激活成功教程出的密码我亲身用这个软件解开N多个密码此软件是家用路由器安全审计工具,切勿用作非法用途!!!….

    2022年8月22日
    5
  • 函数模板参数(函数参数在哪)

    C++模板实参的省略下面列举的几种情况不能省略模板实参:1)从模板函数实参表获得的信息有矛盾之处。template<typenameT>voidfun(Tconst&a,Tconst&b);但是你调用时却是fun(250,250.4);那你就必须写成fun<int>(250,250.4);2)需要获得特定类型的返回值,而不管参数…

    2022年4月15日
    57
  • WhatsAPP通讯协议端对端加密人工智能[通俗易懂]

    WhatsAPP通讯协议端对端加密人工智能[通俗易懂]本文是一个以whatsapp为案例的,针对端对端聊天加密通讯协议整理的一个学习笔记,仅供大家学习。Signalprotocol是真正的端到端的通讯加密协议,号称是世界上最安全的通讯协议,任何第三方包括服务器都无法查看通讯内容。全篇都是围绕着Signalprotocol进行梳理和解释,学习的内容大致分为三个大部分:1、术语解析2、了解5577850怎么来的3、WhatsAPP的通讯流程。术语解析要了解整个的加密通讯协议,首先就是要了解一些不常见的密钥交换方法和算法,可以先看第二部分,

    2022年6月7日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号