FCKeditor添加自定义按钮


Posted in PHP onMarch 27, 2008

在FCKeditor目录里的fckconfig.js打开,找到FCKConfig.ToolbarSets["Default"] 这里的设置是配置功能按钮的,你需要的留下,不需要的可以删掉,也可以注释掉。

如需要多种配置,可以设置多个FCKConfig.ToolbarSets["你自己命个名name"] 后面跟配置详情。在引用编辑器的时候,以PHP为例:把fckeditor.php复制一个命名fckeditor1.php,在这里可以改配置。($this->ToolbarSet= '你自己命的名name' ;)

<?php 
include("editor/fckeditor1.php") ;//这里调用 
$oFCKeditor = new FCKeditor('FormContent') ;//实例化 
$oFCKeditor->BasePath = 'editor/';//这个路径一定要和上面那个引入路径一致,否则会报错:找不到fckeditor.html页面 
//$oFCKeditor->Value = '' ;  
$oFCKeditor->Width = '100%' ; 
$oFCKeditor->Height = '300' ; 
$oFCKeditor->Create() ; 
?>

下面是其他网友的补充,很详细,也可以参考下:
FCKeditor是一款非常流行的WEB可视化编辑器,其程序的的成熟度也非常高、功能丰富,但是再丰富也无法完全满足我们的实际要求,有时我们还是需要增加一些自己的功能。但FCKeditor的程序结构还是比较复杂的,对JS不是很了解的人很难对其灵活定制,本文就如何为FCKeditor的工具条增加一个打开我的像册的自定义按钮做一介绍。

先看看效果:

增加按钮有以下几步:

1、为按钮增加图片:

FCK的所有按钮图片是存放在一个图片文件里的,这一点比较独特,文件存放在相应皮肤目录下,如:/FCK/skins/silever/fck_strip.gif。通过Fireworks或Phtoshop打开该文件可以发现一个很长的图片,里面包含所有按钮的图片,现在您可以在该图片的最下面增加您自定义的按钮,注意,每个按钮的尺寸是16*16px。

2、为按钮增加功能代码:

增加按钮需要对FCK/editor/js目录中的两个核心文件进行修改:fckeditorcode_gecko.js和fckeditorcode_ie.js,前者是使用于gecko核心的浏览器如Firefox等,而后者应用于以IE为核心的浏览器如MyIE(傲游)等,这两个文件大体是相似的,仅有微小差别,在此我们基本无须担心。

修改的方法非常简单,基本是一个照葫芦画瓢的过程,首先我们找一个与我们将要添加的按钮功能相似的一个按钮,这里我们选择了Newpage,这是一个清空编辑器以备新建一个文件的按钮。首先我们修改fckeditorcode_ie.js,fckeditorcode_gecko.js直接复制更改的代码就可以了。

打开fckeditorcode_ie.js,这里需要说明的是,fckeditorcode_ie.js是多个文件合并经过代码优化的(即去掉了大部分换行、空格、注释等)不是很容易阅读,而且这样一百多K的JS文件用Dreamweaver、ZDE等工具打开后CPU立刻升至100%,相信计算机就变成痴呆一样了,经过一翻比较,发现曾被我认为一文不值的Golive竟然可以轻松打开该文件并快速编辑!不管你用什么软件反正能打开并编辑就行了。以关键词Newpage进行查找,你会发现一个按钮的功能定义分三大部分:

A、功能原型

// 按钮功能原型

var FCKNewPageCommand=function(){this.Name='NewPage';};

FCKNewPageCommand.prototype.Execute=function(){FCKUndo.SaveUndoStep();FCK.SetHTML('');FCKUndo.Typing=true;};

FCKNewPageCommand.prototype.GetState=function(){return FCK_TRISTATE_OFF;};

var FCKMyAlbumCommand=function(){this.Name='DISPLAY: none';};

FCKMyAlbumCommand.prototype.Execute=function(){if(typeof(parent.showMyAlbum)=="function"){parent.showMyAlbum(FCK);}else{alert(FCKLang.NoAlbum);}};

FCKMyAlbumCommand.prototype.GetState=function(){return FCK_TRISTATE_OFF;};

B、功能的实例化

case 'NewPage':B=new FCKNewPageCommand();break;

case 'MyAlbum':B=new FCKMyAlbumCommand();break;

C、按钮的显示

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

case 'MyAlbum':B=new FCKToolbarButton('MyAlbum',FCKLang.MyAlbum,null,null,true,null,67);break;

上面代码中第一部分是Newpage的原代码,后一部分是我们自定义的代码,您一看应该明白怎么回事了吧?仅红色部分和名称不同而已!而红色部分就是我们的自定义功能。

FCKLang是语言包对象,您只要打开FCK/editor/lang/下面的相应语言包添加相应的名称属性就可以了,比如:MyAlbum打开我的像册。注意大小写!至此我们的添加工作已完成。

PHP 相关文章推荐
用ODBC的分页显示
Oct 09 PHP
UCenter中的一个可逆加密函数authcode函数代码
Jul 20 PHP
深入PHP内存相关的功能特性详解
Jun 08 PHP
解析php常用image图像函数集
Jun 24 PHP
php实现过滤表单提交中html标签的方法
Oct 17 PHP
CI框架中site_url()和base_url()的区别
Jan 07 PHP
php+html5基于websocket实现聊天室的方法
Jul 17 PHP
PHP中使用substr()截取字符串出现中文乱码问题该怎么办
Oct 21 PHP
PHP+Jquery与ajax相结合实现下拉淡出瀑布流效果【无需插件】
May 06 PHP
Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解决办法
Nov 03 PHP
ThinkPHP中图片按比例切割的代码实例
Mar 08 PHP
小程序微信支付功能配置方法示例详解【基于thinkPHP】
May 05 PHP
php,ajax实现分页
Mar 27 #PHP
PHP 5.0对象模型深度探索之类的静态成员
Mar 27 #PHP
PHP 5.0对象模型深度探索之对象复制
Mar 27 #PHP
PHP 5.0对象模型深度探索之属性和方法
Mar 27 #PHP
php简单静态页生成过程
Mar 27 #PHP
优化PHP代码的53条建议
Mar 27 #PHP
PHP连接access数据库
Mar 27 #PHP
You might like
PHP原生模板引擎 最简单的模板引擎
2012/04/25 PHP
php中unlink()、mkdir()、rmdir()等方法的使用介绍
2012/12/21 PHP
php注册审核重点解析(数据访问)
2017/05/23 PHP
php和html的区别点详细总结
2019/09/24 PHP
判断日期是否能跨月查询的js代码
2014/07/25 Javascript
node.js中的fs.chmod方法使用说明
2014/12/18 Javascript
Javascript实现的Map集合工具类完整实例
2015/07/31 Javascript
JavaScript中iframe实现局部刷新的几种方法汇总
2016/01/06 Javascript
BootStrap下拉框在firefox浏览器界面不友好的解决方案
2016/08/18 Javascript
微信小程序 Audio API详解及实例代码
2016/09/30 Javascript
bootstrap中模态框、模态框的属性实例详解
2017/02/17 Javascript
微信小程序 开发之滑块视图容器(swiper)详解及实例代码
2017/02/22 Javascript
JavaScript数据结构之二叉树的遍历算法示例
2017/04/13 Javascript
vue实现动态列表点击各行换色的方法
2018/09/13 Javascript
vue单页缓存存在的问题及解决方案(小结)
2018/09/25 Javascript
vuex中store存储store.commit和store.dispatch的用法
2020/07/24 Javascript
[01:07:22]2014 DOTA2华西杯精英邀请赛 5 24 DK VS VG加赛
2014/05/26 DOTA
pymongo实现多结果进行多列排序的方法
2015/05/16 Python
python制作花瓣网美女图片爬虫
2015/10/28 Python
django中模板的html自动转意方法
2018/05/27 Python
python微元法计算函数曲线长度的方法
2018/11/08 Python
python分割一个文本为多个文本的方法
2019/07/22 Python
python 哈希表实现简单python字典代码实例
2019/09/27 Python
python django中8000端口被占用的解决
2019/12/17 Python
Python3获取cookie常用三种方案
2020/10/05 Python
python批量检查两个对应的txt文件的行数是否一致的实例代码
2020/10/31 Python
selenium设置浏览器为headless无头模式(Chrome和Firefox)
2021/01/08 Python
HTML5学习笔记之html5与传统html区别
2016/01/06 HTML / CSS
护理学毕业生求职信
2013/11/14 职场文书
水电工岗位职责
2014/02/12 职场文书
写求职信要注意什么问题
2014/04/12 职场文书
社区综治宣传月活动总结
2014/07/02 职场文书
见习报告的格式
2014/10/31 职场文书
2014年宣传部个人工作总结
2014/12/06 职场文书
撤回我也能看到!教你用Python制作微信防撤回脚本
2021/06/11 Python
基于python定位棋子位置及识别棋子颜色
2021/07/26 Python