wordpress结合Kindeditor实现代码高亮和代码自动行号

其实wp有很多优秀的代码高亮插件:

1、codecolorer  2、WP-SynHighlight   3、wp-syntax

但是貌似都不太好用,要不就是需要切换到源码修改, 然后wp自带的编辑器也不太好用,索性换个编辑器插件 Kindeditor for wordpress 

既解决了编辑器不好用,又解决了代码高亮问题


wordpress下KindEditor代码高亮与行号显示

本次测试的kindeditor是1.3.7版本的插件

方法1、手动开启行号,加上linenums样式  。

kindeditor默认未开启代码行号显示功能的,可以通过在html视图下,将需要显示行号的代码做如下更改:
<pre class="prettyprint'
//改为:
<pre class="prettyprint linenums'

方法二、自动开启行号

在kindeditor插件所在路劲找到code.js,修改如下

修改以后缓存特别严重 ,一定记得清空缓存

添加类似SyntaxHighlighter相关样式,

样式多少有点不太满意 自己另行修改
pre.prettyprint {
margin-left: 5px;
padding-left: 18px;
border-left: 3px solid #6CE26C;
font-family: Monaco, 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Lucida Console', monospace !important;
overflow: auto;}
/*font-family: Monaco, 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Lucida Console', monospace !important;*/
/*font-family: Consolas, 'Bitstream Vera Sans Mono', 'Courier New', Courier, monospace !important;*/
pre.prettyprint.linenumstrigger {
margin-left: 0px;
padding-left: 0px;
border-left: 0px; }
pre.prettyprint
ol li { margin-left: 18px;
padding-left: 18px;
border-left: 3px solid #6CE26C; }
pre ol li.highlighttrigger {
background-color: #DAD7FF; }
.str { color: #080; }
.kwd { color: #008; font-weight: bold; }
.com { color: #800; }
.typ { color: #606; font-weight: bold; }
.lit { color: #066; }
.pun { color: #660; }
.pln { color: #000; }
.tag { color: #008; }
.atn { color: #606; }
.atv { color: #080; }
.dec { color: #606; }
@media print {
.str { color: #060; }
.kwd { color: #006; font-weight: bold; }
.com { color: #600; font-style: italic; }
.typ { color: #404; font-weight: bold; }
.lit { color: #044; }
.pun { color: #440; }
.pln { color: #000; }
.tag { color: #006; font-weight: bold; }
.atn { color: #404; }
.atv { color: #060; }}
注意:以上样式我是添加在模板的样式中,而不是修改Kindeditor插件里面的prettify.css,这是因为防止升级造成不必要麻烦,而且在后台没有开启代码高亮功能,如果Kindeditor插件会在html中追加一个js和css文件反而增加了请求数

后记:

正常使用了一段时间的行号显示和代码高亮在升级wordpress版本后前端又出现异常,后来增加了一处优化的地方,打开/wp-content/plugins/kindeditor-for-wordpress/kindeditor.php文件,找到:
add_action('wp_enqueue_scripts', array(&$kindeditor, 'add_head_script'));
修改为:
add_action('wp_footer', array(&$kindeditor, 'add_head_script'));
修改的作用是把 Kindeditor 的高亮代码 js 注册在底部(注意:不一定要在wp_footer,你可以根据实际情况自己修改,总之在引入 jQuery 之后就好了),保存。这样就OK了。因为无论什么页面都会调用footer底部

案例地址:http://17dev.sinaapp.com/css-center.html  css水平居中,垂直居中完全结局方案

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
写在前面 用WordPress以来,本站一直是用CodeColorer来实现代码高亮,但原版的汉化不够完全,且与不少主题都冲突,因此本人将原版修改过后使用,并加入了可视化代码插入功能,之前也想发布出来,但因为懒,一直推迟到现在,既然大家希望我提供下载,因此我把它打包出来提供给大家。 CodeColorer CodeColorer是一款基于GeSHi库的WordPress代码语法高亮插件。功能简单,使用方便,是一款比较轻量的插件。CodeColorer支持[cc lang="lang"]code[/cc]和code两种语法。 属性说明 属性列表如下,括号内是参数类型.string是字符串;integer是整数;boolean是布尔型(开关),可接受“true” “false”, “on” “off”, 整数 1 or 0. lang (string) – 代码使用的语言。 tab_size (integer) – 用以替换制表符的空格数,可在设置界面更改。 line_numbers (boolean) – 是否显示行号,可在设置界面更改。 first_line (integer) – 指定代码块第一行的行号 highlight (string) – 用于指定整行高亮代码行行数,参数是用半角逗号分隔的数字串(如 1,5,8,9)。 no_links (boolean) – 当值为false时,关键字将会添加一个到官方文档的链接,可在设置界面更改。 lines (integer) –指定代码块显示的行数,当值设置为-1时,不出现纵向滚动条,可在设置界面更改。 width (integer or string) – 代码块宽度,可在设置界面更改。 height (integer or string) – 代码块高度,当这个高度可显示的行数比lines指定的值大才会生效,可在设置界面更改。 rss_width (integer or string) – 代码块在RSS输出时的宽度,可在设置界面更改。 theme (string) – 代码块颜色风格 (default, blackboard, dawn, mac-classic, twitlight, vibrant),可在设置界面更改。 inline (boolean) – 内嵌模式开关,用于将一行代码插入到文本中。 strict (boolean) – 严格模式的开关。 nowrap (boolean) – 当值指定为false时,过长的行将会被自动换行,以避免出现横向滚动条。 noborder (boolean) – 是否显示边框的开关。 no_cc (boolean) – 当值为true时,code标签将会被解析,但代码块不会有格式。 class (string) – 添加一个新的CSS。 escaped (string) – 当值为false,代码块里的html转义字符不会被转义,如<不会转义为<,默认为false。 What's New? 添加可视化代码插入按钮并汉化界面; 可视化代码插入界面添加Java,CSS两种语言; 兼容官方主题及各种自定义主题; 修复不自动换行时行号显示不正确的问题; 优化高亮代码显示方式,放弃Table布局,改用Div+CSS,兼容多种浏览器乃至IE6; 添加代码工具栏,实现一键复制等功能,同样兼容多种浏览器。 等待你们去发现…… 我的博客: http://lanfei.sinaapp.com/ http://blog.csdn.net/CooLanfei 欢迎访问交流。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值