【JavaScript】富文本编辑器UEditor与代码高亮插件SyntaxHighlighter整合,实现用户贴代码功能

来源:互联网 发布:sql嵌套循环语句 编辑:程序博客网 时间:2024/05/29 18:50

在《【JavaScript】网页中对代码的处理,代码高亮插件SyntaxHighlighter》(点击打开链接)已经提及到,国内著名,完美兼容IE6的富文本编辑器UEditor已经自然整合代码高亮插件SyntaxHighlighter插件了,那么如何实现用户贴代码功能呢?

值得注意的是,单纯的富文本编辑器UEditor写一段代码,是无法实现如代码高亮插件SyntaxHighlighter带行号、关键词高亮显示的,仅仅是变了字体而已。要实现代码高亮,还要自己手动编辑一下。

比如如下图的效果:

只允许用户贴JavaScript、php、C&C++、C#、Css、Java、HTML、XML、SQL、Java、VB、SQL、Python这些代码,当然,你自己还可以根据自己的需要添加。


用户编辑完功能提交之后,在网页,对这些代码段高亮显示。

制作过程如下:

1、首先到UEditor的官网http://ueditor.baidu.com/website/(点击打开链接)点击"下载"之后,找到更多历史版本,选择适合自己编程语言、网页编码的1.3.6。其实,如果你不开上传功能,各个编程语言的UEditor都是一样的。选择1.3.X版,是因为度娘说在1.4以后的版本中开始不兼容IE6、IE7了,当然大家根据自己的网站可以选择更高更好的版本。


下载UEditor之后将其解压到你的网站文件夹,随后与《【JavaScript】网页中对代码的处理,代码高亮插件SyntaxHighlighter》(点击打开链接)一文一样,下载SyntaxHighlighter,取走里面的scripts、styles,将其部署到你的网站文件夹中。最终的文件结构,如下图所示:


2、UEditor的功能太多,根本就不用向用户开放这么多功能。首先,UEditor的元素路径就不用显示给用户看了,没这个必要,打开ueditor.config.js。如下图所示,将关于元素路径的第307行的注释去掉,将默认的true改成false,这里注意前面的逗号不能去掉,因为这行实际上是处于一个超大的Json数组里面,此乃其中的一个元素。


之后,打开ueditor.all.js,设置允许用户所贴的代码,也就是你的网站所能够解释的代码。在第12330行的me.setOpt数组中,将你的网站不打算解释的代码注释掉。此处需要注意的是,无论如何请保留Plain这个代码,Plain是一个有行号、无代码关键字的解释器,就是现在CSDN的“其它代码”。

这里左边的是SyntaxHighlighter所对应的brush,brush是什么在介绍SyntaxHighlighter的文章已经说过了,这里不再赘述了,右边是给用户看的信息,也就是在编辑器上显示的文字。


3、改好之后,终于可以开始富文本编辑器UEditor的实现,demo.html的代码如下所示:

[html] view plain copy
 print?
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">    
  2. <html>    
  3.     <head>    
  4.         <meta http-equiv="Content-Type" content="text/html; charset=utf-8">    
  5.         <title>UEditor</title>     
  6.   
  7.     </head>    
  8.     <body>  
  9.         <div style="width:99%">  
  10.             <form action="submit.php" method="post">  
  11.                 标题:<input type="text" name="title" style="width:90%"/><br/>  
  12.                 内容:  
  13.                 <textarea id="container" name="content" type="text/plain"></textarea><br/><!--加载编辑器的容器-->  
  14.                 <input type="submit" value="提交" />  
  15.             </form>  
  16.         </div>  
  17.     </body>    
  18. </html>   
  19.    
  20. <script type="text/javascript" src="./ueditor1_3_6-utf8-php/ueditor.config.js"></script><!-- 配置文件 -->  
  21. <script type="text/javascript" src="./ueditor1_3_6-utf8-php/ueditor.all.js"></script><!-- 编辑器源码文件 -->  
  22. <!-- 实例化编辑器 -->  
  23. <script type="text/javascript">  
  24.     var ue = UE.getEditor("container",{toolbars:[  
  25.         [  
  26.             //'anchor', //锚点  
  27.             'undo', //撤销  
  28.             'redo', //重做  
  29.             'bold', //加粗  
  30.             //'indent', //首行缩进  
  31.             //'snapscreen', //截图(需要插件,一般不开);  
  32.             'italic', //斜体  
  33.             'underline', //下划线  
  34.             'strikethrough', //删除线  
  35.             'subscript', //下标  
  36.             //'fontborder', //字符边框  
  37.             'superscript', //上标  
  38.             //'formatmatch', //格式刷  
  39.             //'source', //源代码  
  40.             //'blockquote', //引用  
  41.             //'pasteplain', //纯文本粘贴模式  
  42.             'selectall', //全选  
  43.             //'print', //打印  
  44.             'preview', //预览  
  45.             'horizontal', //分隔线  
  46.             'removeformat', //清除格式  
  47.             //'time', //时间  
  48.             //'date', //日期  
  49.             'unlink', //取消链接  
  50.             //'insertrow', //前插入行  
  51.             //'insertcol', //前插入列  
  52.             //'mergeright', //右合并单元格  
  53.             //'mergedown', //下合并单元格  
  54.             //'deleterow', //删除行  
  55.             //'deletecol', //删除列  
  56.             //'splittorows', //拆分成行  
  57.             //'splittocols', //拆分成列  
  58.             //'splittocells', //完全拆分单元格  
  59.             //'deletecaption', //删除表格标题  
  60.             //'inserttitle', //插入标题  
  61.             //'mergecells', //合并多个单元格  
  62.             //'deletetable', //删除表格  
  63.             //'cleardoc', //清空文档  
  64.             //'insertparagraphbeforetable', //"表格前插入行"  
  65.             'insertcode', //代码语言  
  66.             'fontfamily', //字体  
  67.             'fontsize', //字号  
  68.             //'paragraph', //段落格式  
  69.             'simpleupload', //单图上传  
  70.             //'insertimage', //多图上传  
  71.             //'edittable', //表格属性  
  72.             //'edittd', //单元格属性  
  73.             'link', //超链接  
  74.             //'emotion', //表情  
  75.             'spechars', //特殊字符  
  76.             'searchreplace', //查询替换  
  77.             //'map', //Baidu地图  
  78.             //'gmap', //Google地图  
  79.             //'insertvideo', //视频  
  80.             //'help', //帮助  
  81.             'justifyleft', //居左对齐  
  82.             'justifyright', //居右对齐  
  83.             'justifycenter', //居中对齐  
  84.             'justifyjustify', //两端对齐  
  85.             'forecolor', //字体颜色  
  86.             //'backcolor', //背景色  
  87.             //'insertorderedlist', //有序列表  
  88.             //'insertunorderedlist', //无序列表  
  89.             //'fullscreen', //全屏  
  90.             //'directionalityltr', //从左向右输入  
  91.             //'directionalityrtl', //从右向左输入  
  92.             //'rowspacingtop', //段前距  
  93.             //'rowspacingbottom', //段后距  
  94.             //'pagebreak', //分页  
  95.             //'insertframe', //插入Iframe  
  96.             //'imagenone', //默认  
  97.             //'imageleft', //左浮动  
  98.             //'imageright', //右浮动  
  99.             //'attachment', //附件  
  100.             //'imagecenter', //居中  
  101.             //'wordimage', //图片转存  
  102.             //'lineheight', //行间距  
  103.             //'edittip ', //编辑提示  
  104.             //'customstyle', //自定义标题  
  105.             //'autotypeset', //自动排版  
  106.             //'webapp', //百度应用  
  107.             //'touppercase', //字母大写  
  108.             //'tolowercase', //字母小写  
  109.             //'background', //背景  
  110.             //'template', //模板  
  111.             //'scrawl', //涂鸦  
  112.             //'music', //音乐  
  113.             //'inserttable', //插入表格  
  114.             //'drafts', // 从草稿箱加载  
  115.             //'charts', // 图表  
  116.         ]  
  117.     ]});  
  118. </script>  
  119.    

首先,这里,无须像官方的例子一样,用script标签来实现编辑器,就是普普通通的form表单中的textarea就可以,注意其id不能丢,下面的UEditor脚本根据此id来初始化。之后可以看到在初始化的时候,我注释掉一大堆应用,都什么鬼。一个博客给你加粗、斜体、下划线、变颜色、字体、居中等已经足够了,还开放iframe我觉得是这个作死行为。当然,这里由于此文关键说明怎么整合富文本编辑器UEditor与代码高亮插件SyntaxHighlighter,我没有开放上传图片的功能,免得富文本编辑器UEditor的上传图片又说一大堆。

此页demo.html无须解释用户贴的代码,因此也就没有用代码高亮插件SyntaxHighlighter。

4、下面看看提交页submit.php,虽然这里用了php,但就两句$_POST取表单的值,换成其他语言也一样:

[html] view plain copy
 print?
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  5. <title>结果页</title>  
  6.     <!--SyntaxHighlighter的基本脚本-->  
  7.     <script type="text/javascript" src="syntaxhighlighter/scripts/shCore.js"></script>  
  8.     <!--SyntaxHighlighter的对各个编程语言解析的脚本-->  
  9.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushJScript.js"></script>  
  10.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushPhp.js"></script>  
  11.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushJava.js"></script>  
  12.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushCSharp.js"></script>  
  13.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushCpp.js"></script>  
  14.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushAS3.js"></script>  
  15.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushPython.js"></script>  
  16.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushVb.js"></script>  
  17.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushSql.js"></script>  
  18.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushXml.js"></script>  
  19.     <script type="text/javascript" src="syntaxhighlighter/scripts/shBrushPlain.js"></script>  
  20.     <!--所使用的SyntaxHighlighter样式-->  
  21.     <link type="text/css" rel="stylesheet" href="syntaxhighlighter/styles/shCoreEclipse.css"/>  
  22.     <!--初始化SyntaxHighlighter的必须代码,必须放在head中,引入文件之后-->  
  23.     <script type="text/javascript">SyntaxHighlighter.all();</script>  
  24.     <!--用于消除右上角的广告-->  
  25.     <script type="text/javascript">SyntaxHighlighter.defaults['toolbar'] = false;</script>  
  26. </head>  
  27.   
  28. <body>  
  29.     <p><b>标题:</b><?php echo $_POST["title"]?></p>  
  30.     <p><b>内容:</b><?php echo $_POST["content"]?></p>  
  31.     <p><a href="demo.html">返回</a></p>  
  32. </body>  
  33. </html>  

此页的逻辑,与《【JavaScript】网页中对代码的处理,代码高亮插件SyntaxHighlighter》(点击打开链接)一文完全一样,这里就不再赘述了。

由于富文本编辑器UEditor里面的代码段,会自动放在pre节点中,同时自动加上代码高亮插件SyntaxHighlighter里的class="brush:xx",因此,我们只需要在此页submit.php上加上代码高亮插件SyntaxHighlighter的JS引用即可。

最终的效果如下图:

用户在编辑器编辑时,有明显的淡灰色背景:


贴完代码解释时,对代码的解释在IE6也不失色:


基本上能够100%地满足论坛、博客贴代码的需求了。

0 0
原创粉丝点击