JavaScript建立一个语法高亮输入框实现思路_javascript技巧
程序员文章站
2022-06-11 07:53:28
...
textarea元素已被广泛用于网页Web的IDE。通常网站自带的textarea编辑器不能满足我们的需求,作为一名开发者我们经常需要进行代码的在线编辑,高亮显示代码等,因此,通过其他的开源项目,我们可以添加一些实用的功能, 在这篇文章中,我将使用JavaScript库ACE来创建一个输入框效果。这是一个完全开源的脚本。该脚本允许开发人员创建支持语法高亮的输入框。然后你可以代码嵌入到网站中的任何地方
下载库 首先我们需要Github上下载ACE代码。 下载完成后解压缩,在你的header部分引入js文件
添加代码到编辑器
首先设置一个id为editor的div 然后在script里面调用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
使用额外的参数
editor.setTheme("ace/theme/dawn");
editor.getSession().setTabSize(2);
editor.getSession().setUseWrapMode(true);
这3行代码是关于文本输入效果的,第一行改变代码默认的语法颜色和主题,在src目录下个有几十个新的主题,你可以从中任意选择
另外两个选项是关于用户体验。通常情况下,按一个键盘上的Tab键将输入4个空格,这里我设置成2个空格,此外,该文本在默认情况下将不会自动换行,超了会追加一个水平滚动条向外延伸。但使用这种方法setUseWrapMode(true),我们可以修复自动换行的问题。
还有一些其他的命令,你可以参考ACE向导。这里面包含了改变光标的位置,动态添加新内容,或复制的文本的全部内容。
CSS代码
#editor {
margin-left: 15px;
margin-top: 15px;
width: 1000px;
height: 400px;
}
下载库 首先我们需要Github上下载ACE代码。 下载完成后解压缩,在你的header部分引入js文件
复制代码 代码如下:
添加代码到编辑器
首先设置一个id为editor的div 然后在script里面调用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
使用额外的参数
复制代码 代码如下:
editor.setTheme("ace/theme/dawn");
editor.getSession().setTabSize(2);
editor.getSession().setUseWrapMode(true);
这3行代码是关于文本输入效果的,第一行改变代码默认的语法颜色和主题,在src目录下个有几十个新的主题,你可以从中任意选择
另外两个选项是关于用户体验。通常情况下,按一个键盘上的Tab键将输入4个空格,这里我设置成2个空格,此外,该文本在默认情况下将不会自动换行,超了会追加一个水平滚动条向外延伸。但使用这种方法setUseWrapMode(true),我们可以修复自动换行的问题。
还有一些其他的命令,你可以参考ACE向导。这里面包含了改变光标的位置,动态添加新内容,或复制的文本的全部内容。
CSS代码
复制代码 代码如下:
#editor {
margin-left: 15px;
margin-top: 15px;
width: 1000px;
height: 400px;
}
上一篇: unity shader:初探纹理
下一篇: UE4 C++ 从内存数据创建动态材质
推荐阅读
-
JavaScript建立一个语法高亮输入框实现思路_javascript技巧
-
js在数组中删除重复的元素自保留一个(两种实现思路)_javascript技巧
-
js在数组中删除重复的元素自保留一个(两种实现思路)_javascript技巧
-
JavaScript实现输入框编辑器语法高亮思路及代码详解
-
用json方式实现在 js 中建立一个map_javascript技巧
-
用json方式实现在 js 中建立一个map_javascript技巧
-
js实现当前输入框高亮显示的方法_javascript技巧
-
一个网页标题title的闪动提示效果实现思路_javascript技巧
-
javascript判断两个IP地址是否在同一个网段的实现思路_javascript技巧
-
一个网页标题title的闪动提示效果实现思路_javascript技巧