`
flm_llx
  • 浏览: 62567 次
  • 性别: Icon_minigender_1
  • 来自: 应县
社区版块
存档分类
最新评论

HTML编辑器FCKeditor使用详解

    博客分类:
  • js
阅读更多
Web 2.0时代时代的Web项目,是无论如何也少不了一个在线编辑器的,因此在我们的项目中整合一个Web编辑器就显得至关重要。在这里,我依然以前面的xkland项目为例,来探讨在项目中整合FCKeditor的方方面面。­

一、关于用户发表文章的功能设计­

  用户发表文章的功能,大家见过不少,也用过不少,最简单的,莫过于提供一个文本框,数据提交后直接写入数据库了事,稍复杂一点的最少也要提供一个输入标题和选择分类的功能。当然,我们也可以把我们的功能设计得更有特色。在这个示例项目中,我假设开发的是一个以图文为中心的网络社区,我们每一篇文章都需要用户在它上传的图片中选择一个作为主题图片,那么,在网站首页的文章列表上,大家看到的将不仅仅只是一个文字的标题,还有主题图片的缩略图。­

  先来看看数据表的结构,创建数据表的SQL语句如下:­

CREATE   TABLE  `topics` (­

  `id`  int ( 11 )  NOT   NULL  auto_increment,­

  `catalogid`  int ( 11 )  NOT   NULL ,­

  `subject`  varchar ( 60 )  default   NULL ,­

  `content`  text ,­

  `pictures`  varchar ( 2000 )  NOT   NULL ,­

  `mainpicture`  varchar ( 40 )  NOT   NULL ,­

  `userid`  int ( 11 )  NOT   NULL ,­

  `time`  timestamp   NOT   NULL   default   CURRENT_TIMESTAMP   on   update   CURRENT_TIMESTAMP ,­

  `lastedittime`  timestamp   NOT   NULL   default   ' 2007-01-01 00:00:00 ' ,­

  `lastreplytime`  timestamp   NOT   NULL   default   ' 2007-01-01 00:00:00 ' ,­

  `visitcount`  int ( 11 )  NOT   NULL ,­

   PRIMARY   KEY   (`id`),­

   KEY  `subject` (`subject`),­

   KEY  `userid` (`userid`),­

   KEY  `time` (`time`),­

   KEY  `lastreplytime` (`lastreplytime`)­

) ENGINE = InnoDB  DEFAULT  CHARSET = utf8  | ­

  其中,catalogid字段为文章分类,subject字段为标题,content字段为正文。比较特殊的是pictures字段和mainpicture字段,pictures保存文章中包含的所有图片的url,以“|”符号分割,如“001.jpg|002.jpg|003.jpg...”,而mainpicture就是主题图片的url了。有人会问:“保存主题图片的url就够了,为什么还要保存所有的图片url呢?”,这样设计主要是为了考虑到用户有时候会修改文章,重新选择别的图片作为主题图片,这个时候pictures字段就派上用场了,因为它可以向用户提供候选项。­

  这样的功能设计应该提供如下的用户界面,该页面文件名为EditPosts.jsp:­

­

  在这里,我们还没有Web编辑器可用,暂时用一个文本区域代替。­

二、初识FCKeditor­

  在听说FCKeditor之前,我用过一个在线编辑器eWebEditor,提供ASP/JSP/PHP等好几个版本,功能是非常的好,文档也很详细,但是听说只支持IE浏览器;而FCKeditor在网上大名鼎鼎,是一个受关注非常高的开源项目,并且能够跨浏览器支持。因此我选择FCKeditor。FCKeditor的最新版本是2.4,大家可以到­

http://www.fckeditor.net/download这里下载,如下图­

­

  下载并解压缩到fckeditor文件夹,打开该文件夹,我们可以看到如下文件及目录:­

­

  其中_samples目录下是示例,_testcases目录下是测试用例,editor目录下是编辑器的主要文件;此外,从该目录中的文件不难看出,FCKeditor提供支持asp、php、perl、python等等各种服务器技术的版本,但不支持.net和Java Web。不过不要担心,FCKeditor与Java Web之间的整合早就有人做好了,稍后我们就会用到。­

  了解浏览器技术的人都不难想到,Web编辑器其实应该是客户端技术,它是通过JavaScript来控制页面上的元素和通过弹出窗口来模拟对话框而做到的;只有在提交文章或者上传文件的时候才需要跟服务器端交互。因此,要将该编辑器快速整合到项目中以看到效果,是非常简单的。­

三、使用JavaScript整合FCKeditor­

  将刚刚解压得到的fckeditor目录拷贝到我们的项目中的src\main\webapp目录下,打开刚才建立的EditPosts.jsp,加入如下代码:­

1 ­

2  < script language = " javascript " > ­

3  window.onload  =   function ()  {­

4      var  oFCKeditor  =   new  FCKeditor( 'myTextArea' ) ;­

5     oFCKeditor.BasePath  =   " fckeditor/ " ;­

6     oFCKeditor.ReplaceTextarea();­

7 } ­

      </scrip> ­

  在这里,第一行代码是引入fckeditor中的fckeditor.js文件,其中定义了FCKeditor类,第四行就是利用该类创建一个编辑器对象,而myTextArea是表单中文本区域的名字,在第六行,通过FCKeditor类的ReplaceTextArea方法,文本区域就被替换成了Web编辑器。刷新页面,就可以看到效果:­

­

  FCKeditor类提供几个基本属性,可以让我们对编辑器进行简单的控制,它们是:­

  InstanceName:返回编辑器示例的名字­

  Width:设置编辑器的宽度,默认为100%­

  Height:设置编辑器的高度,默认值为200­

  ToolbarSet:设置编辑器的工具条集合,默认值为"default",稍后会讲到怎样自定义工具条­

  Value:设置显示在编辑器中的内容(包含HTML),默认值为空­

  BasePath:编辑器的目录,一定要设置正确,否则编辑器会找不到它需要的文件,在本例中,由于我们直接将fckeditor目录放到项目的根目录下,因此设置为"fckeditor/"­

  CheckBrowser:设置是否检测浏览器,默认为true­

  DisplayErrors:设置是否显示错误信息,默认为true­

  此外,FCKeditor类还有一个集合属性Config[ key ] = value,通过该集合属性,我们可以进行一个更高级的设置,如设置默认语言、更换皮肤等等。­

  综上所述,下面的代码将重新设置编辑器的高和宽、将工具条设置为基本工具条,将皮肤设置为office2003样式: ­

<script language="javascript">­

window.onload = function(){­

    var oFCKeditor = new FCKeditor( 'myTextArea' ) ;­

    ­

    oFCKeditor.BasePath = "fckeditor/";­

    oFCKeditor.Width = "800";­

    oFCKeditor.Height = "300";­

    oFCKeditor.ToolbarSet = "Basic";­

    ­

    oFCKeditor.Config["SkinPath"] = "skins/office2003/";­

    ­

    oFCKeditor.ReplaceTextarea();­



</script>­

  效果图:­
­

四、通过FCKeditor.java整合FCKeditor­

  使用JavaScript整合FCKeditor,我们很快就能看到编辑器的效果,并进行文章的编辑。但是,在需要和服务器端进行交互的时候(比如上传图片),就会出错。因此,我们不得不在服务器端做一点手脚。这里,我们需要使用的是FCKeditor.java,其最新版本是2.3,还是在刚才的下载页面,找到下载链接,如下图:­

­

  将下载文件解压,我们可以看到有doc目录,有src目录,甚至还有一个build.xml,让我们可以重新构建项目;但是,这些我们统统都不需要,我们只要web\WEB-INF目录下的东西,在这个目录下,提供了一个web.xml,同时在lib目录下提供了两个.jar文件,这便是全部。看到这里,大家肯定能够想到,Java Web项目的灵魂是什么?那就是web.xml。我们所要做的,就是把lib目录下的两个.jar文件拷贝到我们项目的src/main/webapp/WEB-INF/lib下,同时将web.xml中的内容整合到我们项目的src/main/webapp/WEB-INF/web.xml中。­

  web.xml中的内容很简单,只定义了两个Servlet映射,并且对上传文件的目录和允许哪些文件上传、拒绝哪些文件上传做了设置,如下: ­

<servlet>­

        <servlet-name>Connector</servlet-name>­

        <servlet-class>com.fredck.FCKeditor.connector.ConnectorServlet</servlet-class>­

        <init-param>­

            <param-name>baseDir</param-name>­

            <param-value>/UploadFiles/</param-value>­

        </init-param>­

        <init-param>­

            <param-name>debug</param-name>­

            <param-value>true</param-value>­

        </init-param>­

        <load-on-startup>1</load-on-startup>­

[img]http://b19.photo.store.qq.com/http_imgload.cgi?/ru­
分享到:
评论

相关推荐

    文本编辑器FCKEditor使用详解

    FCKeditor 是一款流行的开源文本编辑器,主要用于Web开发,它提供了所见即所得(WYSIWYG)的编辑体验,使得用户在网页上编辑内容时就像使用桌面文字处理软件一样方便。这款编辑器支持插入图片、Flash动画等多媒体...

    asp.net文本编辑器FCKeditor使用方法详解

    ASP.NET 文本编辑器 FCKeditor 使用方法详解 FCKeditor 是一个功能强大且流行的 ASP.NET 文本编辑器,提供了许多实用的功能,如格式化文本、插入图片、上传文件、创建表格等。下面将详细介绍如何使用 FCKeditor 在 ...

    文本编辑器FCKeditor使用方法详解--图文详解

    【FCKeditor使用方法详解】 FCKeditor是一款强大的开源文本编辑器,主要用于在网页中创建和编辑富文本内容。它的功能强大,支持多种语言,并且提供了丰富的API供开发者进行自定义扩展。以下是对FCKeditor使用方法的...

    asp.net文本编辑器FCKeditor使用方法详解.doc

    ASP.NET中的FCKeditor是一款强大的富文本编辑器,它允许用户在网页上创建和编辑复杂的HTML内容,类似于桌面的文字处理软件。以下是对FCKeditor在ASP.NET中使用方法的详细说明: 1. 获取FCKeditor资源:首先,你需要...

    FCKeditor使用详解.doc

    FCKeditor 使用详解 FCKeditor 是一个功能强大、支持所见即所得功能的文本编辑器,可以为用户提供微软 Office 软件一样的在线文档编辑服务。它不需要安装任何形式的客户端,兼容绝大多数主流浏览器,支持 ASP.Net、...

    FCKeditor使用方法详解

    FCKeditor 是一个基于JavaScript的开源富文本编辑器,它在Web开发领域中被广泛使用,尤其适用于那些需要提供用户友好、可视化的文本编辑功能的网站。FCKeditor 具备强大的功能,包括字体样式调整、图像处理、链接...

    Fck文本编辑器 FCKeditor fckeditor

    **FCK文本编辑器——FCKeditor与fckeditor详解** FCK文本编辑器,全称为FCKeditor,是一个开源的富文本编辑器,主要用于网页内容的编辑和格式化。FCKeditor以其强大的功能和易用性,被广泛应用于网站后台管理系统、...

    FCKEditor使用详解_2003.doc

    FCKEditor 是一款流行的开源HTML编辑器,提供所见即所得的编辑体验,广泛应用于Web应用程序中,允许用户在浏览器端创建和编辑富文本内容。这款编辑器支持多种功能,包括插入图片、Flash动画,以及自定义工具栏布局。...

    fckeditor文本编辑器详解.rar

    这个压缩包“fckeditor文本编辑器详解.rar”包含了关于该编辑器的详细资料,包括其工作原理、使用方法和一些常见的开发问题。 1. **基本介绍** fckeditor是一个JavaScript组件,它通过AJAX技术与服务器进行交互,...

    网页编辑器FCKeditor.jar 及使用方法

    **FCKeditor.jar 网页编辑器详解与使用指南** **一、FCKeditor简介** FCKeditor是一款开源的富文本编辑器,它允许用户在网页上进行类似Word的文本编辑操作,包括插入文本、图像、链接、表格、列表等。这个编辑器以...

    FCKeditor编辑器源码示例及详解

    2. **事件处理**:FCKeditor使用JavaScript事件驱动,开发者可以通过监听和处理编辑器的事件来实现特定的功能。 3. **插件系统**:FCKeditor支持扩展,通过编写插件可以添加自定义功能,如插入特殊字符、图表等。 4....

    fckeditor文档编辑器插件

    **fckeditor文档编辑器插件详解** 在网页开发过程中,为了提供用户友好的内容编辑体验,开发者常常会使用文档编辑器插件。fckeditor就是这样一款强大的Web页面编辑工具,它为用户提供了类似Microsoft Word的界面,...

    FCKeditor使用方法详解.doc

    ### FCKeditor使用方法详解 #### 一、引言 FCKeditor,一款基于JavaScript的网页编辑器,因其强大的功能、易配置性、跨浏览器兼容性以及对多种编程语言的支持而备受推崇。作为一款开源软件,FCKeditor不仅在国际上...

Global site tag (gtag.js) - Google Analytics