做过Web开发的朋友相信都使用过富文本编辑器,比较出名的
CuteEditor
和
CKEditor
很多人应该已经使用过,在功能强大的同时需要加载的东西也变得很多。下面要推荐的两款富文本编辑器都是使用JS编写,使用简单,非常轻量级。
NicEdit
NicEdit是一个轻量级,跨平台的Inline Content Editor。NicEdit能够让任何 element/div变成可编辑或者能够把标准的TextArea转换成富文本编辑器。
主页:http://nicedit.com/
下载:http://nicedit.com/download.php
示例:http://nicedit.com/demos.php
NicEdit是我见过最轻量级的富文本编辑器,总共就一个JS文件和一张图片
data:image/s3,"s3://crabby-images/2ab82/2ab82346e04147e265c9912f2cfc6e74750bf4dc" alt=""
使用也非常简单,只需在页面中添加简单的JS代码就可以将TextBox或是TextArea控件转换成富文本编辑器,代码如下
view plain copy to clipboard print ?
- <span style="font-family:Microsoft YaHei;"> <head runat="server">
- <title></title>
- </head>
- <body>
- <form id="form1" runat="server">
- <script src="../JS/Eidtor/nicEdit.js" type="text/javascript"></script>
- <script type="text/javascript">
- bkLib.onDomLoaded(function() {
- new nicEditor({ fullPanel: true }).panelInstance('txtContent');
- });
- </script>
- <asp:TextBox runat="server" ID="txtContent" TextMode="MultiLine" Height="200px" Width="600px" ></asp:TextBox>
- </form>
- </body>
- </html></span>
<span style="font-family:Microsoft YaHei;"> <head runat="server"> <title></title> </head> <body> <form id="form1" runat="server"> <script src="../JS/Eidtor/nicEdit.js" type="text/javascript"></script> <script type="text/javascript"> bkLib.onDomLoaded(function() { new nicEditor({ fullPanel: true }).panelInstance('txtContent'); }); </script> <asp:TextBox runat="server" ID="txtContent" TextMode="MultiLine" Height="200px" Width="600px" ></asp:TextBox> </form> </body> </html></span>
运行效果如下
data:image/s3,"s3://crabby-images/db506/db506ba4fdb2eaae81d06793057ac8b819531340" alt="两款富文本编辑器:NicEdit和Kindeditor_第1张图片"
官网中的版本为英文版,而且字体设置也只能设置英文字体,我对英文版本做了简单的汉化,并且增加了几种中文字体,如下图
data:image/s3,"s3://crabby-images/75f28/75f28634558bcfcbc52a82516bbc204741e3aca2" alt="两款富文本编辑器:NicEdit和Kindeditor_第2张图片"
中文本下载
KindEditor
KindEditor是一套开源的HTML可视化编辑器,主要用于让用户在网站上获得所见即所得编辑效果,兼容IE、Firefox、Chrome、Safari、Opera等主流浏览器。 KindEditor使用JavaScript编写,可以无缝的与Java、.NET、PHP、ASP等程序接合。这个是官网上的介绍。
主页:http://www.kindsoft.net/index.php
下载:http://www.kindsoft.net/down.php
示例:http://www.kindsoft.net/demo.php
KindEditor相比较NicEditor涉及的文件要多很多,不过大小也才几百K而已,下图为文件结构
data:image/s3,"s3://crabby-images/bb2e9/bb2e9bb49c770572772393aafe5c7261cde98476" alt="两款富文本编辑器:NicEdit和Kindeditor_第3张图片"
view plain copy to clipboard print ?
- <span style="font-family:Microsoft YaHei;"><html xmlns="http://www.w3.org/1999/xhtml">
- <head runat="server">
- <title></title>
- </head>
- <body>
- <form id="form1" runat="server">
- <script charset="utf-8" src="../JS/KindEditor/kindeditor-min.js"
- type="text/javascript"></script>
- <script type="text/javascript" charset="utf-8">
- KE.show({
- id: 'txtContent',
- resizeMode: 1,
- allowPreviewEmoticons: false,
- allowUpload: false,
- });
- </script>
- <textarea cols="60" id="txtContent" style="width: 600px; height: 300px;" runat="server"
- readonly="readonly"></textarea>
- </form>
- </body>
- </html></span>
<span style="font-family:Microsoft YaHei;"><html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title></title> </head> <body> <form id="form1" runat="server"> <script charset="utf-8" src="../JS/KindEditor/kindeditor-min.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> KE.show({ id: 'txtContent', resizeMode: 1, allowPreviewEmoticons: false, allowUpload: false, }); </script> <textarea cols="60" id="txtContent" style="width: 600px; height: 300px;" runat="server" readonly="readonly"></textarea> </form> </body> </html></span>
运行效果如下
data:image/s3,"s3://crabby-images/f9c36/f9c364d27a38763a436bb63536c37ec32d278340" alt="两款富文本编辑器:NicEdit和Kindeditor_第4张图片"
总结
选择这两款富文本编辑器的原因有
1 都是使用JS编写,这样使用起来比较简单不用去引用DLL。
2 体积都很小。
3 都可以直接将现有的TextBox或是TextArea变成富文本编辑器。
NicEditor相比较KindEditor来说还显的不是很成熟。在我最近的一个需求中就有两点没有达到,最后选用了KindEdior。
1 TextBox的宽度只能设置成固定数值的宽度,如果设置成百分比,如100%,在有的浏览器中就会显示有问题。
2 貌似还没有禁用编辑器的编辑功能,也有可能是我没有找到设置的方法