澳门新葡亰娱乐官网FCKeditor添加自定义按钮_php技巧_脚本之家

这里脚本之家小编参考了几篇文章特为大家整理下,用到的朋友多支持一下了。

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

用到MVCfckeditor发现在一些小问题,网上找了资料,解决了,在这里我一并贴出来方便查找;

进行长文章分页,编辑人员在控制分页符的时候手工插入很麻烦,所以修改了FCK的插入分页符的插入字符:修改方法:打开/editor/js/找到fckeditorcode_gecko.js和fckeditorcode_ie.js因为fck有二个js文件。fckeditorcode_gecko.js是针对非ie的。一个是针对ie的。所以我们需要更改二个js的文件。这样方便我们以后插入分页时,就不需要那么一大串的了。找到:var
FCKPageBreakCommand=function(){this.Name=’PageBreak’;};FCKPageBreakCommand.prototype.Execute=function(){FCKUndo.SaveUndoStep();var
e=FCK.EditorDocument.createElement(‘Div’)以及其后字符,修改为你自己的分页符即可

如需要多种配置,可以设置多个FCKConfig.ToolbarSets[“你自己命个名name”]
后面跟配置详情。在引用编辑器的时候,以PHP为例:把fckeditor.php复制一个命名fckeditor1.php,在这里可以改配置。($this->ToolbarSet=
‘你自己命的名name’ ;) 复制代码
代码如下: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;FCKUndo.Typing=true;};
FCKNewPageCommand.prototype.GetState=function(){return
FCK_TRISTATE_OFF;}; var
FCKMyAlbumCommand=function(){this.Name=’DISPLAY: none’;};
FCKMyAlbumCommand.prototype.Execute=function(){if(typeof==”function”){parent.showMyAlbum;}else{alert;}};
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打开我的像册。注意大小写!至此我们的添加工作已完成。

第一:MVCFckeditor在IE9上无法上传图片

fck分页符修改

解决办法:

FKC默认添加的分页符为:div span /span/div

原因是IE9不支持var $=document.getElementById;这样的写法了。
 打开下面这个文件
 fckeditor/editor/js/fckeditorcode_ie.js
 找到第38行的这个方法:FCKTools.RegisterDollarFunction
 将原来的
 FCKTools.RegisterDollarFunction=function(A){A.$=A.document.getElementById;};
 修改方法为:
 FCKTools.RegisterDollarFunction=function(A){A.$=function(v){return
A.document.getElementById(v);}};

对文章的分页,我是运用String.split(“分页符”)方法,将文章以分页符为分割点,返回一个String类型的数组,但是双引号不能够相互嵌套,split方法中的参数就没办法设置。
如何修改默认的分页符:

澳门新葡亰娱乐官网,来自:

找到js文件:在/fckeditor/editor/js/目录下,需要修改的有两个js文件:fckeditorcode_ie.js(针对IE浏览器的配置)、fckeditorcode_gecko.js(针对非IE浏览器的配置)。
在js文件中找到如下代码,并做修改:

 

 var FCKPageBreakCommand=function() {this.Name='PageBreak';}; FCKPageBreakCommand.prototype.Execute=function() {FCKUndo.SaveUndoStep(); var e=FCK.EditorDocument.createElement('DIV'); //这里是创建div标签,此处不用修改 e.style.pageBreakAfter='always'; //这里是为div添加样式,把它删掉; e.innerHTML='span /span'; //这里是在div中添加的内容,修改一下; 我的是修改为e.innerHTML='[jb51page]'; 也就是仅有一个空格;

第二问题:修改字体与字体大小

保存,重新添加文章,添加文章时看不出变化,保存看查看数据,分页符的位置变为:
div[jb51page]/div
为文章分页就可以用split(“div[jb51page]/div”)方法进行拆分显示了;

解决办法:

以下是参考了dedecms的方法:大家在修改的时候一定要看清原来的fckeditor分页的写法,千万不要直接覆盖,容易出问题。

  1. 在fckconfig.js文件中找到FCKConfig.FontNames
    ,在字体中加入想要的字体就行了。

dedecms的方法:

FCKConfig.FontNames=
‘宋体;黑体;隶书;幼圆;仿宋_GB2312;楷体_GB2312;Arial;Comic Sans
MS;Courier New;Tahoma;Times New Roman;Verdana’
;然后在editor/css/fck_editorarea.css的43行修改font-family:
宋体,黑体,楷体,仿宋,Arial, Verdana, sans-serif;

复制代码 代码如下:var
FCKPageBreakCommand=function(){this.Name=’PageBreak’;};FCKPageBreakCommand.prototype.Execute=function(){FCKUndo.SaveUndoStep();var
e=FCK.EditorDocument.createElement(‘P’);e.innerHTML='[jb51page]’;

FCKConfig.FontSizes= ’12px;14px;16px;18px;24px;26px;28px;32px;’
;//这个是修改字体大小

脚本之家用的方法:

来自: 

复制代码 代码如下:var
FCKPageBreakCommand=function(){this.Name=’PageBreak’;};FCKPageBreakCommand.prototype.Execute=function(){FCKUndo.SaveUndoStep();FCK.EditorDocument.selection.createRange().text='[jb51page]’;

 

注意:由于我们使用的版本,有FCKUndo.SaveUndoStep();如果不带出现了编辑器无法显示的情况。大家根据需要修改。

第三问题:添加行距功能:

后面发现了dedecms增加的小功能,里面的函数不错可以参考下

解决办法:

var FCKLineBrCommand=function(){this.Name='LineBr';};FCKLineBrCommand.prototype.Execute=function(){FCK.EditorDocument.selection.createRange().pasteHTML("br/");};FCKLineBrCommand.prototype.GetState=function(){return 0;}var FCKQuoteCommand=function(){this.Name='Quote';};FCKQuoteCommand.prototype.Execute=function(){var quoteString = "table style='border-right: #cccccc 1px dotted; table-layout: fixed; border-top: #cccccc 1px dotted; border-left: #cccccc 1px dotted; border-bottom: #cccccc 1px dotted' cellspacing=0 cellpadding=6 width='95%' align=center border=0/r/n"; quoteString += "trtd style='word-wrap: break-word' bgcolor='#fdfddf'/r/nfont color='#FF0000'以下为引用的内容:/fontbr/r/n"; quoteString += "/td/tr/table/r/n";FCK.EditorDocument.selection.createRange().pasteHTML(quoteString);};FCKQuoteCommand.prototype.GetState=function(){return 0;}

 1、FCKCONFIG.JS中104行FCKConfig.ToolbarSets中设定工具栏得加上LineHeight

 

2、在fckeditoreditorplugins文件夹下建立新文件夹lineHeight,并在其中创建fckplugin.js文件,在其文件中办输入代码:
FCKCommands.RegisterCommand(‘LineHeight’,new FCKLineHeightCommand());
FCKToolbarItems.RegisterItem( ‘LineHeight’, new
FCKToolbarLineHeightCombo( null, FCK_TOOLBARITEM_ONLYTEXT ) ) ;

 3、在文件fckeditoreditorjsfckeditorcode_ie.js

76行添加代码如下:
var
FCKLineHeightCommand=function(){};FCKLineHeightCommand.prototype={Name:’LineHeight’,Execute:FCKStyleCommand.prototype.Execute,GetState:FCKFormatBlockCommand.prototype.GetState};
98行添加代码(FCKToolbarItems那一行的
switch 语句中):
case ‘LineHeight’:B=new FCKLineHeightCommand();break;
111行处:
var
FCKToolbarLineHeightCombo=function(A,B){this.CommandName=’LineHeight’;this.Label=this.GetLabel();this.Tooltip=A?A:this.Label;this.Style=B?B:2;this.DefaultLabel=FCKConfig.DefaultFontLabel||”;};FCKToolbarLineHeightCombo.prototype=new
FCKToolbarFontFormatCombo(false);FCKToolbarLineHeightCombo.prototype.GetLabel=function(){return
FCKLang.LineHeight;};FCKToolbarLineHeightCombo.prototype.GetStyles=function(){var
A=FCKStyles.GetStyle(‘_FCK_LineHeight’);if (!A){alert(“The
FCKConfig.CoreStyles[‘Size’] setting was not found. Please check the
fckconfig.js file”);return {};};var B={};var
C=FCKConfig.LineHeights.split(‘;’);for (var i=0;i<C.length;i++){var
D=C[i].split(‘/’);var E=D[0];var F=D[1]||E;var
G=FCKTools.CloneObject(A);G.SetVariable(‘Font’,E);G.Label=F;B[F]=G;};return
B;};FCKToolbarLineHeightCombo.prototype.RefreshActiveItems=FCKToolbarStyleCombo.prototype.RefreshActiveItems;FCKToolbarLineHeightCombo.prototype.StyleCombo_OnBeforeClick=function(A){A.DeselectAll();var
B=FCKSelection.GetBoundaryParentElement(true);if (B){var C=new
FCKElementPath(B);for (var i in A.Items){var D=A.Items[i];var
E=D.Style;if (E.CheckActive(C)){A.SelectItem(D);return;}}}};

4、在文件fckeditoreditorlangzh-cn.js的

117行添加代码如下:
LineHeight:”行距”,
//此处主要是添加资源代码,这里只针对于中文,所以只修改了zh-cn.js文件
在fckconfig.js文件夹的98行添加:
FCKConfig.Plugins.Add( ‘lineHeight’ ) ;
153行处(FCKConfig.FontSizes属性的后面,其实任何行都可以):
FCKConfig.LineHeights = ‘50%;100%;150%;200%’ ; //.net dll得相应变化 A处

247行处(FCKConfig.CoreStyles属性中):
‘LineHeight’ :
       {
              Element          : ‘span’,
              Styles             : { ‘line-height’ : ‘#(“Font”)’ },
              Overrides       : [ { Element : ‘font’, Attributes : {
‘size’ : null } } ]
       },

注:上面所添加的就直接拷贝。
来自:

 

 第四个问题

其实这也不是什么问题,只是操作方式不一样

解决fckeditor回车间距过大问题

CKeditor文字换行问题 FCKeditor Enter(回车键)换行时间距过大。

按住Shift+Enter换行时(间距会小)也就是说它默认直接敲回车是一个键,而按Shift+回车则是键。

那一般人的习惯都是直接就敲回车的了,查看了下它的配置文件发现是可以解决的。

还有二种方法

一,修改fckconfig.js FCKConfig.EnterMode = ‘p’ ; // p | div | br
FCKConfig.ShiftEnterMode = ‘br’ ; // p | div | br
将ShiftEnterMode与EnterMode的值换一下,EnterMode=br SHIFTENTERMODE=P
就可以解决了。

 

二,在fckconfig.js文件中查找UseBROnCarriageReturn。把FCKConfig.UseBROnCarriageReturn
= false ; 改为FCKConfig.UseBROnCarriageReturn = true ;
不过这方式可能只有IE支持,不建议使用。
我也很想告诉百度管理员,让他也来看看这篇文章,百度空间的编辑器正是fckeditor,也是如些,真的很不方便。

 

You can leave a response, or trackback from your own site.

Leave a Reply

网站地图xml地图