百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

UEditor二次开发之为行内代码添加code标签

yuyutoo 2024-10-12 01:13 6 浏览 0 评论

UEditor是由百度WEB前端研发部开发的所见即所得的开源富文本编辑器,具有轻量、可定制、用户体验优秀等特点。开源基于BSD协议,所有源代码在协议允许范围内可自由修改和使用。百度UEditor的推出,可以帮助不少网站开发者在开发富文本编辑器所遇到的难题,节约开发者因开发富文本编辑器所需要的大量时间,有效降低了企业的开发成本。

做为一个资深的码农,网站里代码高亮是必不可少的,通常分享好几行代码的时候我们都是用到代码高亮插件,但是对于函数或者短代码来说如果也用插件也未免太大材小用了,所以我的思路是行内的代码用<code></code>标签,而多行代码用<pre></pre>标签,pre标签用插件识别高亮,code标签自己定义样式。UEditor集成了pre标签的代码功能,所以code就要我们二次开发来完成了!

最终效果展示:

官方文档介绍:

UEditor从1.4.1开始,添加对于二次开发的扩展支持。无需对 UEditor 代码做任何修改,只需在UEditor之外通过UEditor提供的二次开发接口开发定制功能.这种开发方式不仅避免了修改UEditor源码,方便日后UEditor的升级,而且通过接口,可以将开发的定制功能维护到一个文件中或者一个目录中,方便日后对其维护。更多请查看UEditor官网。

首先我们需要添加一个按钮,在UEditor目录下新建一个addCustomizeButton.js文件

使用文件方式:

<script type="text/javascript" charset="utf-8" src="ueditor.config.js"></script>

<script type="text/javascript" charset="utf-8" src="ueditor.all.js"></script>

<!--添加按钮-->

<script type="text/javascript" charset="utf-8" src="addCustomizeButton.js"></script>

然后编辑addCustomizeButton.js添加按钮和功能写入以下代码:

UE.registerUI('code', function(editor, uiName) {

//注册按钮执行时的command命令,使用命令默认就会带有回退操作

editor.registerCommand(uiName, {

execCommand: function() {

alert('execCommand:' + uiName)

}

});

//创建一个button

var btn = new UE.ui.Button({

//按钮的名字

name: uiName,

//提示

title: 'code',

//添加额外样式,指定icon图标,这里默认使用一个重复的icon

cssRules: 'background-position: -440px -40px;',

//点击时执行的命令

onclick: function() {

// 获取当前光标选中的文本

var range = UE.getEditor('editor').selection.getRange();

range.select();

var txt = UE.getEditor('editor').selection.getText();

var value;

// 判断如果当前没有选中文本弹出提示框输入文本

if(txt != ''){

value = txt;

}else{

value = prompt('插入html代码', '');

}

if(value != "null" && value != null){

UE.getEditor('editor').execCommand('insertHtml', "&nbsp;<code>"+value+"</code>&nbsp;");

}

}

});

//当点到编辑内容上时,按钮要做的状态反射

editor.addListener('selectionchange', function() {

var state = editor.queryCommandState(uiName);

if (state == -1) {

btn.setDisabled(true);

btn.setChecked(false);

} else {

btn.setDisabled(false);

btn.setChecked(state);

}

});

//因为你是添加button,所以需要返回这个button

return btn;

});

为了分别出code标签和普通文本的区别我们需要给UEditor编辑器内添加一下样式文件路径ueditor/themes/iframe.css

code{

background: #f5f2f0;

color: #e90;

display: inline-block;

padding: 3px;

font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;

text-shadow: 0 1px white;

}

至此效果已全部达成!

原创文章,转载请注明出处!

相关推荐

MySQL中的数据类型(mysql数据类型有哪些,并举例)

MySQL中的数据类型...

mysql窗口函数over中rows_MySQL窗口函数

下面的讲解将基于这个employee2表:mysql>SELECT*FROMemployee2;+----+-----------+------+---------+---------...

别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究

总想写一篇MySQL的设计和列类型选取的文章,一直挤不出时间。天天晚上都要加班,正逢5.1放假,抽了几天就有了此文。如果对朋友们能有帮助的话,关注一波不过分吧?求关!选择更优的数据类型尽量选择存储空间...

MySQL数据库知识(mysql数据库相关知识)

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

MySQL实战——表结构设计之数字类型

整型不建议刻意去用unsigned属性,因为在做一些数据分析时,SQL可能返回的结果并不是想要得到的结果。比如在财务的场景下,经常会做一些加减操作。MySQL要求unsigned数值相减之...

MySQL数据库入门(四)数据类型简介

在MySQL中数据类型有以下五种:数字整数:常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyintunsigned,用来表示年龄(值范围是0-...

mysql常用语句超级详细汇总(mysql常用语法)

1.连接数据库:连接本地数据库:mysql-uroot-p连接远程数据库:mysql-h192.169.22.199-uroot-p退出数据库:exit...

MYSQL——CAST()函数的用法(mysql中case)

语法为:Cast(字段名as转换的类型),其中类型可以为:CHAR[(N)]字符型DATE日期型DATETIME日期和时间型...

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择引言部分你是否遇到过这样的情况:明明已经按照最佳实践选择了MySQL的InnoDB引擎,却发现某些查询依然缓慢得令人沮丧?或者当你的...

MySQL 表分区?涨知识了(mysql数据表分区)

1.什么是表分区...

《MySQL必知必会》_笔记08(mysql必知必会mobi)

第19章插入数据一、数据插入概述INSERT语句用于向数据库表中插入(添加)数据,是SQL中常用的数据操作语句之一。它可以用多种方式使用,包括插入完整的行、插入行的一部分、插入多行以及插入某些查询的...

当 SQL Server(mssql-jdbc) 遇上 BigDecimal → 精度丢失,真坑!

开心一刻  中午和哥们一起喝茶  哥们说道:晚上喝酒去啊...

MYSQL有哪些数据类型(mysql有哪些数据类型,有哪些运算符)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

使用MySQL分区的注意事项(使用mysql分区的注意事项有哪些)

MySQL分区是将一个表分解成多个区块进行操作和保存,从而降低每次操作的数据量,提高性能。从逻辑上看,只有一个表,但物理上这个表可能由多个物理分区组成,每个分区都是一个独立的对象,可以进行独立处理。...

取消回复欢迎 发表评论: