FckEditor工具栏添加自定义按钮,并实现点击按钮的功能

2024-05-09 23:48

本文主要是介绍FckEditor工具栏添加自定义按钮,并实现点击按钮的功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

     由于前几天,项目中需要在fckeditor编辑器中,将别的网站中的新闻复制进来的时候,里面的图片存储在这些网站的服务器上,需要将这些外部图片下载下来,然后存放在我们自己的服务器上,然后替换这些外部图片地址。

     这里就需要在fckeditor编辑器中添加一个自定义的按钮,并实现该按钮的功能:下载和上传到我们自己的服务器。

需要修改的文件包括:

     fckconfig.js zh-cn.jsfckeditorcode_gecko.js(非IE浏览器)或者fckeditorcode_ie.jsIE浏览器)

 

步骤:

1、定义按钮

   Toolbar中添加新的功能按钮,需要在ToolbarSets中添加我们按钮的名称,我们定义按钮名称为TransExternalImg

   fckconfig.jsFCKConfig.ToolbarSets[content]中添加按钮名称(这个content是我们项目中使用的工具栏,跟defaultbasic中的类似)

   FCKConfig.ToolbarSets["Content"] = [

            .......

          ['Style','FontFormat','FontName','FontSize'],

          ['TextColor','BGColor','FitWindow','TransExternalImg']

    ] ;    

 

2、定义按钮的中文名字

   zh_cn.js文件中添加:

    var FCKLang =

     {

      ToolbarCollapse : "折叠工具栏",

      ToolbarExpand : "展开工具栏",

      // Toolbar Items and Context Menu

      Save : "保存",

      ransExternalImg : "转换外部图片资源",

     }

    这样当我们把鼠标移到工具栏的这个按钮时,会显示该按钮的中文名称   

 3、将按钮注册到toolbar

    需要在fckeditorcode_gecko.js中注册该按钮到工具栏:

    查找:

    case 'NewPage':

         B = new FCKToolbarButton('NewPage', FCKLang.NewPage, null, null, true, null, 4);

      break;

    在后面插入

      case 'TransExternalImg':

            B=new FCKToolbarButton('TransExternalImg',FCKLang.TransExternalImg,null,null,false,true,44);

      break;

  最后面的参数数字表示的是按钮显示的样子,你可以替换成其他数字。   这样就可以在工具栏中中显示定义的按钮了。

4、按钮功能实例化

    修改ckeditorcode_gecko.js

    查找

    case 'NewPage':

          B = new FCKNewPageCommand();

    break;

   在后面加:

    case 'TransExternalImg':

       B=new FCKTransExternalImgCommand();

    break;

 5、实现按钮点击的事件功能  

   ckeditorcode_gecko.js

     查找:

        var FCKNewPageCommand = function() {

          this.Name = 'NewPage';

        };

    FCKNewPageCommand.prototype.Execute = function() {

         FCKUndo.SaveUndoStep();

        FCK.SetData('');

        FCKUndo.Typing = true;

       FCK.Focus();

    };

    FCKNewPageCommand.prototype.GetState = function() {

        return 0;

   };

   复制上面的代码一份,对照修改为我们自己的:

     var FCKTransExternalImgCommand=function(){

         this.Name='TransExternalImg';

    };

   FCKTransExternalImgCommand.prototype.Execute=function()

     {

       //这里可以定义自己的功能,比如

        alert("测试");

    };

  FCKTransExternalImgCommand.prototype.GetState=function(){return 0;};

这样就能在我们的工具栏中显示了。


这篇关于FckEditor工具栏添加自定义按钮,并实现点击按钮的功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/974833

相关文章

基于Python和Tkinter实现高考倒计时功能

《基于Python和Tkinter实现高考倒计时功能》随着高考的临近,每个考生都在紧锣密鼓地复习,这时候,一款实用的倒计时软件能有效帮助你规划剩余时间,提醒你不要浪费每一分每一秒,今天,我们来聊聊一款... 目录一、软件概述:二、功能亮点:1. 高考倒计时2. 添加目标倒计时3. 励志语句4. 透明度调节与

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

Python实现PDF与多种图片格式之间互转(PNG, JPG, BMP, EMF, SVG)

《Python实现PDF与多种图片格式之间互转(PNG,JPG,BMP,EMF,SVG)》PDF和图片是我们日常生活和工作中常用的文件格式,有时候,我们可能需要将PDF和图片进行格式互转来满足... 目录一、介绍二、安装python库三、Python实现多种图片格式转PDF1、单张图片转换为PDF2、多张图

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

Java实现MD5加密的四种方式

《Java实现MD5加密的四种方式》MD5是一种广泛使用的哈希算法,其输出结果是一个128位的二进制数,通常以32位十六进制数的形式表示,MD5的底层实现涉及多个复杂的步骤和算法,本文给大家介绍了Ja... 目录MD5介绍Java 中实现 MD5 加密方式方法一:使用 MessageDigest方法二:使用

mysql删除无用用户的方法实现

《mysql删除无用用户的方法实现》本文主要介绍了mysql删除无用用户的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 1、删除不用的账户(1) 查看当前已存在账户mysql> select user,host,pa

Nginx配置location+rewrite实现隐性域名配置

《Nginx配置location+rewrite实现隐性域名配置》本文主要介绍了Nginx配置location+rewrite实现隐性域名配置,包括基于根目录、条件和反向代理+rewrite配置的隐性... 目录1、配置基于根目录的隐性域名(就是nginx反向代理)2、配置基于条件的隐性域名2.1、基于条件

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Java实现将Markdown转换为纯文本

《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案... 目录方法一:使用正则表达式(轻量级方案)方法二:使用 Flexmark-Java 库(专业方案)1. 添加依赖(Ma

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis