您现在的位置是:首页 > 教程 > 帝国CMS教程帝国CMS教程
帝国cms自带ckeditor编辑器代码高亮的方法codesnippet风格
张津广2023-06-11 00:14:40帝国CMS教程已有人查阅
导读无意中看到别人家的博客代码高亮非常漂亮,如下图所示,Mac OS风格,查阅资料为Pure Highlightjs,是WordPress插件。
无意中看到别人家的博客代码高亮非常漂亮,如下图所示,Mac OS风格,查阅资料为Pure Highlightjs,是WordPress插件。奈何咱们的博客不是WordPress程序,长叹一声~ 不过还好,Pure Highlightjs是基于Highlightjs,而本博客用的编辑器是帝国cms自带的ckeditor,ckeditor的代码高亮插件codesnippet也是基于Highlightjs,嘿嘿,那么动手改造吧。
关于ckeditor安装codesnippet高亮插件网上教程很多,本篇不再赘述,小伙伴们可自行查阅资料安装。 一、对比两个插件生成的高亮html代码
1、codesnippet生成的高亮Html代码
二、动手改造找到e/admin/ecmseditor/infoeditor/plugins/codesnippet目录下plugin.js修改
1、给template加上这三个class
涉及到的js和css文件:pri**.js,**c.css,clipboard.min.js,需要的小伙伴可以直接从本博客代码中获取
关于ckeditor安装codesnippet高亮插件网上教程很多,本篇不再赘述,小伙伴们可自行查阅资料安装。 一、对比两个插件生成的高亮html代码
1、codesnippet生成的高亮Html代码
<pre>
<code class="language-java hljs">
xxxxxx
</code>
</pre>
2、**c风格主题Pure Highlightjs生成的高亮Html代码
<pre class="pure-highlightjs line-numbers language-java">
<code class=" language-java">
xxxxxxxx
</code>
</pre>
对比之下发现,Pure Highlightjs生成的高亮代码中,pre标签多了pure-highlightjs line-numbers language-*这三个class。二、动手改造找到e/admin/ecmseditor/infoeditor/plugins/codesnippet目录下plugin.js修改
1、给template加上这三个class
template: '<pre class="pure-highlightjs line-numbers ' + codeClass + '"><code class="' + codeClass + '"></code></pre>'
2、修改 data函数,更新代码时,同时修改pre标签的language-* class
data: function() {
var newData = this.data,
oldData = this.oldData;
if ( newData.code )
this.parts.code.setHtml( CKEDITOR.tools.htmlEncode( newData.code ) );
// Remove old .language-* class.
if ( oldData && newData.lang != oldData.lang ) {
var odl = oldData.lang;
this.parts.code.removeClass( 'language-' + odl );
//修改代码时,更新pre标签的language-* class
this.parts.pre.removeClass( 'language-' + odl );
}
// Lang needs to be specified in order to apply for**tting.
if ( newData.lang ) {
// Apply new .language-* class.
var ndl = newData.lang;
this.parts.code.addClass( 'language-' + ndl );
//修改代码时,更新pre标签的language-* class
this.parts.pre.addClass( 'language-' + ndl );
this.highlight();
}
// Save oldData.
this.oldData = CKEDITOR.tools.copy( newData );
}
3、修改upcast函数,提交代码时,添加pre的language-*
upcast: function( el, data ) {
if ( el.name != 'pre' )
return;
var childrenArray = getNonEmptyChildren( el ),
code;
if ( childrenArray.length != 1 || ( code = childrenArray[ 0 ] ).name != 'code' )
return;
// Upcast <code> with text only: https://dev.ckeditor.com/ticket/11926#comment:4
if ( code.children.length != 1 || code.children[ 0 ].type != CKEDITOR.NODE_TEXT )
return;
// Read language-* from <code> class attribute.
var **tchResult = editor._.codesnippet.langsRegex.exec( code.attributes[ 'class' ] );
if ( **tchResult )
data.lang = **tchResult[ 1 ];
// Use textarea to decode HTML entities (https://dev.ckeditor.com/ticket/11926).
textarea.setHtml( code.getHtml() );
data.code = textarea.getValue();
code.addClass( codeClass );
//pre标签添加codeClass
el.addClass( codeClass );
return el;
}
4、修改downcast函数
downcast: function( el ) {
var code = el.getFirst( 'code' );
// Remove pretty for**tting from <code>...</code>.
code.children.length = 0;
// Remove config#codeSnippet_codeClass.
code.removeClass( codeClass );
//删除pre标签codeClass
el.removeClass( codeClass );
// Set raw text inside <code>...</code>.
code.add( new CKEDITOR.htmlParser.text( CKEDITOR.tools.htmlEncode( this.data.code ) ) );
return el;
}
三、加入Pure Highlightjs的js和样式文件涉及到的js和css文件:pri**.js,**c.css,clipboard.min.js,需要的小伙伴可以直接从本博客代码中获取
本文标签:
很赞哦! ()
相关文章
- 帝国cms自定义字段ReturnClassAddField标签截取字数的方法
- 自定义函数解决帝国cms简介截取字符出现html代码的方法
- 本地环境phpStudy搭建帝国CMS的方法
- 帝国cms提示Table 'px.***_enewspubtemp_2' doesn't exist的解决方法
- 帝国cms通过栏目ID获取栏目名称,别名,链接的方法
- 帝国CMS二次开发新浪iplookup根据ip跳转到不同域名的方法
- 帝国CMS怎么实现内容关键字替换图片alt的办法
- 帝国CMS怎么使用egetip()获取用户IP函数
- 帝国cms二次开发实现纯JS版的地区联动筛选功能
- 帝国CMS批量提取第一张图片为标题缩略图的方法
- 帝国CMS文章和TAG删除编号ID从1开始的方法
- 帝国cms后台关闭金刚模式后一片空白的解决方法
随机图文
-
帝国CMS灵动标签按点击数怎么实现天周月排行榜调用的方法
今天(24小时):newstime>UNIX_TIMESTAMP()-86400*1 必须是今天发布的文章,一周:newstime>UNIX_TIMESTAMP()-86400*7 必须是一周内发布的文章 -
帝国CMS后台批量显示或者导出后台点卡为TXT文本的方法
帝国CMS后台有批量生成点卡功能,很多小伙伴用来制作在线交易流程,若生成几千上万个点卡,显然是不方便一个个录入到某些第三方点卡平台的,但是这些点卡平台都有批量导入的功能 -
帝国7.5安装教程(帝国cms7.5怎么安装)
然后需要配置环境,帝国CMS支持PHP和MySQL数据库”或服务器已经成功安装“PHP和MySQL数据库”。正常登录后台,安装完成。 -
帝国CMS多作者调用的方法,帝国CMS调用有作者链接和没有连接
多个作者的调用方法1、标签调用[!--writer--]方法2、代码分割调用(用php分割$navinfor[writer]字段内容再显示)
留言与评论 (共有 条评论) |