• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SyntaxHighlighter配合CKEditor插件轻松打造代码语法着色
    上网搜索了一下相关的文章不少,大同小异,本人一直使用的是CKeditor的文字编辑器,所以偿试使用网上很多网友介绍的SyntaxHighlighter配合CKEditor插件的方式实现。可能是因为SyntaxHighlighter和CKEditor版本不同,过程中遇到了一些问题,解决的同时也根据个人理解做部分调整,所以本文所描述的方法仅供参考。



    一、SyntaxHighlighter简介

    SyntaxHighlighter(原名:dp.SyntaxHighlighter)是一套在浏览器上对各种代码进行语法着色的独立JavaScript库。

    下载网站:http://alexgorbatchev.com/SyntaxHighlighter/
    脚本之家下载:https://www.jb51.net/codes/15916.html

    本文使用的版本是3.0.83版,下载后只需要syntaxhighlighter文件夹下的“scripts”和“styles”文件夹内的文件,在代码语法着色高亮显示的页面引用“styles/shCore.css”样式文件,“scripts/shCore.js”JS文件,因为每一种代码语言都要引用各自的JS文件,为了降低HTTP请求,把所有代码语言的JS文件内容都放到一个“scripts/shBrushSeaYee.js”JS文件里,把所代码写成一行,优化一下。

    例如:
    复制代码 代码如下:

    link rel="stylesheet" type="text/css" href="/syntaxhighlighter/styles/shCoreDefault.css" />
    script language="javascript" type="text/javascript" src="/syntaxhighlighter/scripts/shCore.js">/script>
    script language="javascript" type="text/javascript" src="/syntaxhighlighter/scripts/shBrushSeaYee.js">/script>


    二、CKEditor简介

    CKeditor是一个专门使用在网页上属于开放源代码的所见即所得文字编辑器。它志于轻量化,不需要太复杂的安装步骤即可使用。它可和PHP、JavaScript、ASP、ASP.NET、ColdFusion、Java、以及ABAP等不同的编程语言相结合。它原名FCKEditor,在2009年发布更新到3.0,并改名为CKEditor。原来叫FCK,是因为最初的开发者叫Frederico Calderia Knabben;现在叫CK,意指"Content and Knowledge"。据官方的解释,CKEditor是对FCKEditor的代码的完全重写,而且此项工作从2007年就开始了,更新包括:新的用户界面,一个支持Plug-in的Javascript API,并提供对视觉障碍者的使用支持。

    下载网站:http://ckeditor.com/

    本文使用的版本是3.5.3版,安装配置都比较简单,本文不再赘述。

    三、CKEditor代码语法着色高亮显示的插件开发

    1、在"ckeditor\plugins\"目录下新建一个"insertcode"目录,然后在"insertcode"目录下新建一个"plugin.js",输入以下代码:
    复制代码 代码如下:

    CKEDITOR.plugins.add('insertcode',
    {
    init: function(editor)
    {
    //plugin code goes here
    var pluginName = 'Insertcode';
    CKEDITOR.dialog.add(pluginName, this.path + 'insertcode.js');
    editor.config.flv_path = editor.config.flv_path || (this.path);
    editor.addCommand(pluginName, new CKEDITOR.dialogCommand(pluginName));
    editor.ui.addButton('Insertcode',
    {
    label: '插入代码',
    command: pluginName,
    icon: this.path + 'insertcode.gif'
    });
    }
    });


    注:第1行代码中“insertcode”必须与文件夹名称相同且区分大小写字母,因为在Linux系统的Web服务器中,路径是区分大小写字母的。
    2、"insertcode"目录下放入一个"insertcode.gif"16*16大小的图片,可自己做或上网找。
    3、"insertcode"目录下新建一个"insertcode.js",输入如下代码:
    复制代码 代码如下:

    CKEDITOR.dialog.add('Insertcode', function(editor){
    var escape = function(value){return value;};
    return{
    title: '插入代码',
    resizable: CKEDITOR.DIALOG_RESIZE_BOTH,
    minWidth: 720,
    minHeight: 520,
    contents: [{
    id: 'cb',
    name: 'cb',
    label: 'cb',
    title: 'cb',
    elements: [{
    type: 'select',
    label: 'Language',
    id: 'lang',
    required: true,
    'default': 'csharp',
    items: [['ActionScript3', 'as3'], ['Bash/shell', 'bash'], ['ColdFusion', 'cf'], ['C#', 'csharp'], ['C++', 'cpp'], ['CSS', 'css'], ['Delphi', 'delphi'], ['Diff', 'diff'], ['Groovy', 'groovy'], ['JavaScript', 'js'], ['Java', 'java'], ['JavaFX', 'jfx'], ['Perl', 'perl'], ['PHP', 'php'], ['Plain Text', 'plain'], ['PowerShell', 'ps'], ['Python', 'py'], ['Ruby', 'rails'], ['Scala', 'scala'], ['SQL', 'sql'], ['Visual Basic', 'vb'], ['XML', 'xml']]
    }, {
    type: 'textarea',
    style: 'width:718px;height:450px',
    label: 'Code',
    id: 'code',
    rows: 31,
    'default': ''
    }]
    }],
    onOk: function(){
    code = this.getValueOf('cb', 'code');
    lang = this.getValueOf('cb', 'lang');
    html = '' + escape(code) + '';
    editor.insertHtml("pre class=\"brush:" + lang + ";\">" + html + "/pre>");
    },
    onLoad: function(){}
    };
    });

    4、在"ckeditor\"目录下找到“config.js”文件,这是CKEditor的配置文件,添加如下代码:

    复制代码 代码如下:
    config.extraPlugins = 'insertcode';


    注:代码中“insertcode”也必须与文件夹名称相同,区分大小写字母。

    要在CKEditor工具栏添加按钮就在此配置文件中添加上“,Insertcode”,依然要注意区分大小写字母。至此就大功造成了。
    您可能感兴趣的文章:
    • FCKeditor .NET的配置、扩展与安全性经验交流
    • CKEditor 4.4.1 添加代码高亮显示插件功能教程【使用官方推荐Code Snippet插件】
    • CKeditor富文本编辑器使用技巧之添加自定义插件的方法
    • CKEDITOR二次开发之插件开发方法
    • ckeditor自定义插件使用方法详解
    • FCKeditor 插件开发 示例(详细版本)
    • 添加FCKeditor插件需要注意的地方
    • fckeditor 修改记录添加行距功能插件
    • ckeditor插件开发简单实例
    • fckeditor 插件开发参考文档
    • ckeditor syntaxhighlighter代码高亮插件配置分享
    • 手把手教你 CKEDITOR 4 扩展插件制作
    上一篇:Fckeditor XML Request error:internal server error (500) 解决方法小结
    下一篇:ajax php实现给fckeditor文本编辑器增加图片删除功能
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SyntaxHighlighter配合CKEditor插件轻松打造代码语法着色 SyntaxHighlighter,配合,CKEditor,