网站首页 > java教程 正文
今天给大家分享一个超强大开源的基于web云端代码编辑器ACE Editor。
Ace 基于 JavaScript 编写的浏览器可嵌入式代码编辑器,Star高达21.9K+。
号称性能和功能可以媲美于Sublime,Vim等本地编辑器。可以轻松地嵌入到任何网页和JavaScript应用程序中。
ACE支持超过40种语言语法高亮 PHP、Javascript、HTML、CSS、Java、C++、Python等。
功能特性
- 语法高亮:支持 40 多种语言的语法高亮 (可以导入 TextMate/Sublime 等文件)
- 自动缩排
- 更换主题:支持超过20多款主题
- 自定义快捷键绑定
- 搜索和替换支持正则表达式
- 高亮选中
- 可以处理大型文档(能够处理代码多达400万行)
- 在线语法检测器
简单使用
<div id="editor" style="height: 500px; width: 500px">some text</div>
<script src="src/ace.js" type="text/javascript"></script>
<script>
var editor = ace.edit("editor");
</script>
配置主题及语言模式
// 设置主题
editor.setTheme("ace/theme/clouds");
// or
editor.setTheme("ace/theme/twilight");
默认情况下,编辑器为纯文本,所有其他语言模式都可以作为单独的模块按需引入。
// 设置语言
editor.session.setMode("ace/mode/javascript");
// or
editor.session.setMode("ace/mode/html");
// or
editor.session.setMode("ace/mode/php");
demo示例
<!DOCTYPE html>
<html>
<head>
<title>Demo of ACE Editor</title>
<!--导入js库-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/ace/1.2.6/ace.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/ace/1.2.6/ext-language_tools.js" type="text/javascript"></script>
</head>
<body>
<!--代码输入框(注意请务必设置高度,否则无法显示)-->
<pre id="code" class="ace_editor" style="min-height:400px">
<textarea class="ace_text-input">
function cloneObject(obj) {
var newObj = {} //如果不是引用类型,直接返回
if (typeof obj !== 'object') {
return obj
}
//如果是引用类型,遍历属性
else {
for (var attr in obj) {
//如果某个属性还是引用类型,递归调用
newObj[attr] = cloneObject(obj[attr])
}
}
return newObj
}
</textarea>
</pre>
<script type="text/javascript">
//初始化对象
editor = ace.edit("code");
//设置风格和语言(更多风格和语言,请到github上相应目录查看)
theme = "clouds"
language = "javascript"
editor.setTheme("ace/theme/" + theme);
editor.session.setMode("ace/mode/" + language);
//字体大小
editor.setFontSize(20);
//设置只读(true时只读,用于展示代码)
editor.setReadOnly(false);
//自动换行,设置为off关闭
editor.setOption("wrap", "free")
//启用提示菜单
ace.require("ace/ext/language_tools");
editor.setOptions({
enableBasicAutocompletion: true,
enableSnippets: true,
enableLiveAutocompletion: true
});
</script>
</body>
</html>
上面代码运行效果如下
官网提供了丰富的文档及API方法。
附上文档及项目地址
# 文档地址
https://ace.c9.io/
# 仓库地址
https://github.com/ajaxorg/ace
ok,就介绍到这里。如果大家感兴趣可以去看下哈,欢迎一起交流讨论!
猜你喜欢
- 2024-10-29 Thymeleaf+LayUI使用百度富文本编辑器(Ueditor)
- 2024-10-29 eclipse插件属性编辑器的离线安装
- 2024-10-29 基于Java的XML编辑器Oxygen XML Editor
- 2024-10-29 Markdown(编辑器)工具与使用总结(markdown编辑器用法)
- 2024-10-29 Java项目本地部署宝塔搭建实战报修小程序springboot版系统源码
- 2024-10-29 五大最佳代码编辑器,让你的开发效率翻倍
- 2024-10-29 CHM Editor——WYSIWYG编辑器(chm编辑器哪种好)
- 2024-10-29 Android平台上最好的几款免费的代码编辑器
- 2024-10-29 高级程序员最爱用的8款代码编辑器,你用哪几个?
- 2024-10-29 8个免费且优秀的代码编辑器,让开发速度飞起来
你 发表评论:
欢迎- 07-15采用Oracle OSB总线进行服务注册和接入
- 07-15javaEE 新闻管理系统 oracle11+tomcat6
- 07-15从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 07-15如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 07-15【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 07-15【mykit-data】 数据库同步工具(数据库表同步工具)
- 07-15[Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- 07-15Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- 最近发表
-
- 采用Oracle OSB总线进行服务注册和接入
- javaEE 新闻管理系统 oracle11+tomcat6
- 从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 【mykit-data】 数据库同步工具(数据库表同步工具)
- [Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- Oracle数据库云服务系列新增前所未有的企业级功能
- 直播预告丨如何实现Oracle存储过程到java的一键转化
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)