前段时间发表过一篇关于“KindEditor在JSP中使用”的博文。这几天在沈阳东软进行JavaWeb方面的实习工做,在一个CMS系统的后台和博客板块中又要用到文本编辑器,忽然发现了这个——百度编辑器(官网http://ueditor.baidu.com/website/index.html)。javascript
Ueditor由百度开发,传说中的百度更懂中文嘛,不像KindEditor有时会显示乱码。Ueditor提供中文“utf-8”和“gbk”版本的下载。并且分为完整版和定制版。完整版没什么可说的,下面说下定制版:php
定制版就是能够选择本身须要的功能,而后根据用户所选组件生成下载包。地址(http://ueditor.baidu.com/website/ipanel/panel.html)。定制的内容包括组件,编辑器背景颜色或图片,编辑器高度和宽度等;css
值得一提的是,Ueditor提供了功能说明文档和使用说明文档。可让开发者快速的清楚他能实现的功能,并节约阅读原JS代码的时间,熟练的使用Ueditor。文档连接(http://ueditor.baidu.com/website/document.html),附使用说明文档(摘自Ueditor官网):html
先后端数据交互前端 2012-05-11 16:09:13java 1、富文本内容交互web 一、编辑器内容初始化(即往编辑器中设置富文本) 在editor_config.js文件中找到initialContent参数,设置其值为须要的提示或者问候语便可,如initialContent:’欢迎使用UEditor!’。 场景二:编辑旧文章,从数据库中取出富文本放置到编辑器中。json 显然,编辑文章时须要从后台数据库中取出大段富文本,若是仍然采用场景一中的方式去设置初始值的话,必然会带来诸如引号匹配被截断等问题,所以须要采用另一种方式去设置,以下代码所示: <script type="text/plain" id="editor"> //从数据库中取出文章内容打印到此处 </script> 此处采用了script标签做为编辑器容器对象,并设置了其类型是纯文本,从而在避免了标签内部JS代码执行的同时解决了部分同窗在使用传统的textarea标签做为容器所带来的一次额外转码问题。
二、提交编辑器内容至后端 场景一:在编辑器所在的Form中存在提交按钮,提交动做由点击此按钮完成。 该场景适用于最普通的场合,没有太大问题须要注意,仅三点说明: 1) 默认状况下提交到后台的表单名称是 “editorValue”,在editor_config.js中能够配置,参数名为textarea。 2) 能够在容器标签(即script标签)上设置name属性,以覆盖editor_config.js中的默认配置。实例代码以下,此处的myContent将成为新的提交表单名称: <form action="" method="post"> <script type="text/plain" id="editor" name="myContent"> </script> <input type="submit" name="submit" value="提交"> </form> 3)后端接收程序能够经过以下几种方式来获取编辑器中的富文本内容。 //PHP获取: $_POST["myContent"] //JSP获取: request.getParameter("myContent"); //ASP获取: request("myContent"); //NET获取: context.Request.Form["myContent"]; 场景二:编辑器所在的Form中不存在提交按钮,提交动做由外部事件触发。 该场景适用于站点前端交互较多的场合,须要注意的事项主要是在触发form提交动做以前执行编辑器内容同步操做。通常的代码模式以下所示: //知足提交条件时同步内容并提交,此处editor为编辑器实例 if(editor.hasContent()){ //此处以非空为例 editor.sync(); //同步内容 someForm.submit(); //提交Form } 此处editor是编辑器实例对象。 场景三:编辑器不在任何Form中,提交动做由外部事件触发。 该场景使用很少,但特殊时候可能须要。UEditor也提供了对应的处理方案,基本逻辑跟场景二同样,只是在执行同步操做的时候须要传入提交form的id,如editor.sync(myFormID)便可。其余同场景二。
2、图片上传交互 一、传统图片上传 路径配置完成以后,还须要配置imageFieldName参数做为文件表单的表单名,后台能够据此获取文件句柄。该参数一样位于editor_config.js中。 //图片上传提交地址 imageUrl:URL+"server/upload/php/imageUp.php", //图片修正地址,引用了fixedImagePath,若有特殊需求,可自行配置 imagePath:fixedImagePath, //图片描述的key imageFieldName:"upFile", //等比压缩的基准,肯定maxImageSideLength参数的参照对象. //0为按照最长边,1为按照宽度,2为按照高度 compressSide:0, //上传图片最大容许的边长,超过会自动等比缩放,不缩放就设置一个比较大的值 //更多设置在image.html中 maxImageSideLength:900 完成上述配置以后,理论上后台应该能够接收到前台上传的图片文件了。在正确保存以后,传统图片上传至此就结束了。可是,在使用Flash上传的编辑器中,流程还远未结束。 首先,后台须要计算得出图片文件存放的地址字符串。该字符串UEditor极力推荐使用从网站根目录开始算起,一直到图片名结束为止。若是不从网站根目录开始算起,后面须要考虑“先后端修正地址”参数。 其次,后台返回一个json格式的字符串,格式具体要求以下: { "url":"图片地址", "title":"图片描述", "state":"上传状态" } 其中,url对应计算出的图片保存地址——再强调一遍,尽可能构造出从网站根目录开始的地址字符串;title对应flash中的描述字段,在图片上将会被设置到title属性中;state对应服务器端返回的图片上传状态字符:除了上传成功返回“SUCCESS”以外,其余任何值都将被直接显示在返回的图片描述字段内。 最后,UEditor会在返回的url地址前面增长“先后端修整路径”这个参数值做为最后插入编辑器中的图片地址。所以,若是服务器端返回的是从根目录开始的图片路径或者http开头的绝对路径,“先后端修正路径”必须留空。 举例来说,若是服务器返回的路径是“/myProject/uploads/sun.jpg”,那么插入到编辑器中的路径会是“先后端修正路径 + /myProject/uploads/sun.jpg”。 3、Word图片转存交互 一、图片转存原理 该功能的基本操做步骤:复制word文档——》粘贴到编辑器——》编辑器会将全部图片转换成一个占位图,同时在工具栏中高亮转存按钮——》点击转存按钮弹出图片上传框——》点击复制按钮复制图片目录地址——》点击“添加照片”按钮,在弹出的选择框中粘贴刚复制的图片目录地址——》点击打开按钮,选择目录下的全部图片文件,在此点击打开——》执行图片上传——》上传成功确认插入,UEditor将自动完成对应占位图的替换过程。 二、配置要点及注意事项 4、远程图片抓取交互 一、远程抓取原理 图片远程抓取是指在插入本地域名以外的图片连接地址时,由服务器将这些外部图片抓取到本地服务器保存的一个功能。实现原理为在编辑器中向服务器发送包含全部外域图片地址的ajax请求,而后由服务器在后端抓取保存后返回图片地址给编辑器,再由编辑器完成外域地址和本地地址的替换工做。 //是否开启远程图片抓取 catchRemoteImageEnable:true, //处理远程图片抓取的地址 catcherUrl:URL +"server/submit/php/getRemoteImage.php", //提交到后台远程图片uri合集的表单名 catchFieldName:"upFile", //图片修正地址,同imagePath catcherPath:fixedImagePath, //本地顶级域名,当开启远程图片抓取时,除此以外的全部其它域名下的 //图片都将被抓取到本地 localDomain:["baidu.com","10.81.2.114"], 二、注意事项 远程抓取功能是否开启可在edicot_config.js中经过配置catchRemoteImageEnable参数实现。与这个功能相关的配置还包括了远程抓取的处理程序地址,表单域名称,本地域和“先后端修正地址”。远程抓取处理程序实现了依据前端提交的地址列表(使用ue_separate_ue标示符进行分隔的字符串)进行图片抓取,而后返回地址列表给客户端的功能。 先后台交互数据格式样例:(URL1,URL2,URL3,URL4) URL1ue_separate_ueURL2ue_separate_ueURL3ue_separate_ueURL4 5、图片在线管理交互 一、图片在线管理介绍 图片在线管理是指经过读取服务器端的文件目录并将其展现到编辑器中的进行额外一些操做的功能。处于安全考虑,目前UEditor仅实现了图片二次插入操做,其余诸如删除、移动等操做将会在后续二次开发教程中陆续放出。 //图片在线管理的处理地址 imageManagerUrl:URL + "server/submit/php/imageManager.php", //图片修正地址,同imagePath imageManagerPath:fixedImagePath 二、注意事项 图片在线管理须要配置的参数跟远程图片抓取一致,二者不一样的地方是图片在线管理中的图片数据是由服务器端指定某个目录,而后遍历其下的全部图片文件获得,而后将地址返回给编辑器,而远程图片抓取则是由编辑器提交图片地址,通过服务器端的抓取处理后返回新的地址给编辑器。二者的初始触发都须要ajax的介入。 6、屏幕截图交互 一、屏幕截图介绍 使用了ActiveX控件,目前只支持IE浏览器。 二、注意事项 须要配置的参数除了跟图片上传同样的内容以外,还多出了服务器地址和端口的配置。具体使用时请根据自身服务器的特色作出适应修改。 //屏幕截图的server端文件所在的网站地址或者ip,请不要加http:// snapscreenHost: '127.0.0.1', //屏幕截图的server端保存程序,UEditor的范例代码为“URL snapscreenServerUrl: URL +"server/upload/php/snapImgUp.php", +"server/upload/php/snapImgUp.php"” //屏幕截图的server端端口 snapscreenServerPort: 80, //截图的图片默认的排版方式 snapscreenImgAlign: 'center', //截图显示修正地址 snapscreenPath: fixedImagePath, 7、附件上传交互 一、附件上传注意事项 附件上传的基本配置跟图片相似。另外,因为附件上传采用了至关成熟的swfupload开源框架,所以大部分的文档和资料尽可参考swfupload的官网教程。官网地址:http://www.swfupload.org |
Ueditor的部署说明(摘自Ueditor官网):
完整版的部署与体验 2012-05-11 16:16:57 1、官网上下载完整源码包,解压到任意目录,解压后的源码目录结构以下所示: _examples:编辑器完整版的示例页面 _demos:编辑器的各类使用案例 dialogs:弹出对话框对应的资源和JS文件 themes:样式图片和样式文件 server:涉及到服务器端操做的PHP、JSP等文件 third-party:第三方插件 editor_all.js:_src目录下全部文件的打包文件 editor_all_min.js:editor_all.js文件的压缩版,建议在正式部署时才采用 editor_config.js:编辑器的配置文件,建议和编辑器实例化页面置于同一目录 2、部署UEditor到实际项目(UETest)中的步骤: 图表 1 第一步:在项目的任一文件夹中创建一个用于存放UEditor相关资源和文件的目录,此处在项目根目录下创建,起名为ueditor。 第二步:拷贝源码包中的dialogs、themes、third-party、editor_all.js和editor_config.js到ueditor文夹中。其中,除了ueditor目录以外的其他文件均为具体项目文件,此处所列仅供示例。 第三步:为简单起见,此处将以根目录下的index.php页面做为编辑器的实例化页面,用来展现UEditor的完整版效果。在index.php文件中,首先导入编辑器须要的三个入口文件,示例代码以下: <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>编辑器完整版实例</title> <script type="text/javascript" src="ueditor/editor_config.js"></script> <script type="text/javascript" src="ueditor/editor_all.js"></script> <link rel="stylesheet" href="ueditor/themes/default/ueditor.css"> 第四步:而后在index.php文件中建立编辑器实例及其DOM容器。具体代码示例以下: <div id="myEditor"></div> <script type="text/javascript"> var editor = new baidu.editor.ui.Editor(); editor.render("myEditor"); </script> 最后一步: 在/UETest/ueditor/ editor_config.js中查找URL变量配置编辑器在你项目中的路径。 //强烈推荐以这种方式进行绝对路径配置
URL= window.UEDITOR_HOME_URL||"/UETest/ueditor/";
至此,一个完整的编辑器实例就已经部署到我们的项目中了!在浏览器中输入http://localhost/UETest 运行下试试UE强大的功能吧! 3、注意事项 1.在引用editor_config.js时,最好先于editor_all.js加载,不然特定状况下可能会出现报错。 此外若是你使用的是相对路径,例如"ueditor/"(相对于图表1路径结构) 若是站点中有多个不在同一层级的页面须要实例化编辑器,且引用了同一UEditor的时候,可能不适用于每一个页面的编辑器。所以,UEditor提供了针对不一样页面的编辑器可单独配置的根路径,具体来讲,在须要实例化编辑器的页面最顶部写上以下代码便可。 固然,须要令此处的URL等于对应的配置。window.UEDITOR_HOME_URL ="/xxxx/xxxx/"; |
博客转自:《又一编辑神器-百度编辑器-Ueditor 》