亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 軟件應用 > 正文

比較不錯的修改FCKEditor的修改方法

2024-09-06 19:16:29
字體:
來源:轉載
供稿:網友

修改后的代碼下載http://www.cnblogs.com/Files/Truly/FCKeditor_Truly.rar
本地下載地址
由于項目需要,近期仔細研究了FCKEditor。發現一下bug,以及缺少的一些東西。

一、防止連續文本導致出現滾動條
        FCKEditor編輯器使用Iframe來處理編輯器內容,可惜不支持文本換行,假如你連續輸入一段英文或數字等,將會出現滾動條,這時我們需要給其增加word-wrap樣式為break-word;

添加方式有很多,我選擇最便捷的修改方式:具體做法是修改fckeditor.html文件,給<iframe id="eEditorArea" 增加事件 onload="window.frames['eEditorArea'].document.body.style.wordWrap='break-word'"

二、增加Media以及Realplay按鈕
      此項工作相對龐大,要修改很多js文件,以及一些圖片和樣式文件。
      a.準備圖片:FCKeditor/editor/css/images下面,添加fck_medialogo.gif和fck_realplaylogo.gif,大小隨意,作為背景居中顯示的。
FCKeditor/editor/skins/default/toolbar/增加media.gif和realplay.gif,其他皮膚類推。
      b.修改css:給FCKeditor/editor/css/fck_internal.css增加

.FCK__Media
{
 border: darkgray 1px solid;
 background-position: center center;
 background-image: url(images/fck_medialogo.gif);
 background-repeat: no-repeat;
 width: 80px ;
 height: 80px ;
}

.FCK__Realplay
{
 border: darkgray 1px solid;
 background-position: center center;
 background-image: url(images/fck_realplaylogo.JPG);
 background-repeat: no-repeat;
 width: 80px ;
 height: 80px ;
}
c。修改js,主要以realplay做示例
FCKeditor/editor/js/fckeditorcode_ie_1.js,在FCKDocumentProcessors.addItem(FCKFlashProcessor);后面增加
// Realplay begin
var FCKRealplayProcessor=new Object();
FCKRealplayProcessor.ProcessDocument=function(A){
    var B=A.getElementsByTagName('EMBED');
    var C;
    var i=B.length-1;

while (i>=0&&(C=B[i--])){
if (C.src.endsWith('.rm',true) || C.src.endsWith('.ram',true) || C.src.endsWith('.ra',true))
{var D=FCKDocumentProcessors_CreateFakeImage('FCK__Realplay',C.cloneNode(true));
D.setAttribute('_fckRealplay','true',0);
FCKRealplayProcessor.RefreshView(D,C);
C.parentNode.insertBefore(D,C);
C.parentNode.removeChild(C);
};
};
};

FCKRealplayProcessor.RefreshView=function(A,B){
    if (B.width>0) A.style.width=FCKTools.ConvertHtmlSizeToStyle(B.width);
    if (B.height>0) A.style.height=FCKTools.ConvertHtmlSizeToStyle(B.height);
};
FCKDocumentProcessors.addItem(FCKRealplayProcessor);
// Realplay end
var FCKMediaProcessor=new Object();
FCKMediaProcessor.ProcessDocument=function(A)
{
    var B=A.getElementsByTagName('EMBED');
    var C;
    var i=B.length-1;
    while (i>=0&&(C=B[i--]))
    {
        if (C.src.endsWith('.avi',true) || C.src.endsWith('.mpg',true) || C.src.endsWith('.mpeg',true))
        {
            var D=FCKDocumentProcessors_CreateFakeImage('FCK__Media',C.cloneNode(true));
            D.setAttribute('_fckmedia','true',0);FCKMediaProcessor.RefreshView(D,C);
            C.parentNode.insertBefore(D,C);C.parentNode.removeChild(C);
        };
    };
};
FCKMediaProcessor.RefreshView=function(A,B)
{
    if (B.width>0) A.style.width=FCKTools.ConvertHtmlSizeToStyle(B.width);
    if (B.height>0) A.style.height=FCKTools.ConvertHtmlSizeToStyle(B.height);
};
FCKDocumentProcessors.addItem(FCKMediaProcessor);

然后修改FCK.GetRealElement方法為下面代碼,該方法為處理編輯器中width和height的調整
FCK.GetRealElement=function(A){
var e=FCKTempBin.Elements[A.getAttribute('_fckrealelement')];

if (A.getAttribute('_fckflash')|| A.getAttribute('_fckrealplay') || A.getAttribute('_fckmedia')){
    if (A.style.width.length>0) e.width=FCKTools.ConvertStyleSizeToHtml(A.style.width);
    if (A.style.height.length>0) e.height=FCKTools.ConvertStyleSizeToHtml(A.style.height);
};
return e;};

----------
FCKeditor/editor/js/fckeditorcode_ie_2.js
FCKCommands.GetCommand方法增加
case 'Media':B=new FCKDialogCommand('Media',FCKLang.DlgMediaTitle,'dialog/fck_Media.html',450,400);
break;
case 'Realplay':B=new FCKDialogCommand('Realplay',FCKLang.DlgMediaTitle,'dialog/fck_Realplay.html',450,400);
break;

FCKToolbarItems.GetItem方法增加

case 'Media':B=new FCKToolbarButton('Media',FCKLang.InsertMediaLbl,FCKLang.InsertMedia);
break;
case 'Realplay':B=new FCKToolbarButton('Realplay',FCKLang.InsertRealplayLbl,FCKLang.InsertRealplay);
break;
FCKContextMenu._GetGroup方法增加
case 'Media':return new FCKContextMenuGroup(true,this,'Media',FCKLang.MediaProperties,true);
case 'Realplay':return new FCKContextMenuGroup(true,this,'Realplay',FCKLang.RealplayProperties,true);   // truly

FCKContextMenu.RefreshState方法增加
if (this.Groups['Media'])   this.Groups['Media'].SetVisible(B=='IMG'&&A.getAttribute('_fckmedia'));
if (this.Groups['Realplay'])  this.Groups['Realplay'].SetVisible(B=='IMG'&&A.getAttribute('_fckrealplay'));


然后要增加'dialog/fck_Media.html'和'dialog/fck_Realplay.html'頁面,具體我懶得再寫了,自己到我的源碼下載里看,我是在2。1的基礎上改的,2.2要做一些調整!

fckconfig.js也有較多調整,但是這個文件非常簡單,自己去看我的源碼吧。
然后就是lang目錄中對常量的定義,搜索一下就很容易得到,沒什么可講。

在然后就可以了,:)。



三、添加刪除按鈕列,類似sina的blog中的編輯控件

四、修改上傳路徑
        默認是根目錄/UserFiles,有多種方式進行修改,先看一下它的源碼:
protected string UserFilesPath
{
 get
 {
  if ( sUserFilesPath == null )
  {
   // Try to get from the "Application".
   sUserFilesPath = (string)Application["FCKeditor:UserFilesPath"] ;

   // Try to get from the "Session".
   if ( sUserFilesPath == null || sUserFilesPath.Length == 0 )
   {
    sUserFilesPath = (string)Session["FCKeditor:UserFilesPath"] ;

    // Try to get from the Web.config file.
    if ( sUserFilesPath == null || sUserFilesPath.Length == 0 )
    {
     sUserFilesPath = System.Configuration.ConfigurationSettings.AppSettings["FCKeditor:UserFilesPath"] ;

     // Otherwise use the default value.
     if ( sUserFilesPath == null || sUserFilesPath.Length == 0 )
      sUserFilesPath = DEFAULT_USER_FILES_PATH ;

     // Try to get from the URL.
     if ( sUserFilesPath == null || sUserFilesPath.Length == 0 )
     {
      sUserFilesPath = Request.QueryString["ServerPath"] ;
     }
    }
   }

   // Check that the user path ends with slash ("/")
   if ( ! sUserFilesPath.EndsWith("/") )
    sUserFilesPath += "/" ;
  }
  return sUserFilesPath ;
 }
}

由此,可以在Global里或者程序任意位置(加載fckeditor前可以運行到的位置)設置Application["FCKeditor:UserFilesPath"] ,或者Session,或者Webconfig,或者action中的請求參數等。


to be continued...


附:js版FCKEditor下載:http://prdownloads.sourceforge.net/fckeditor/FCKeditor_2.2.zip
.net版
http://prdownloads.sourceforge.net/fckeditor/FCKeditor.Net_2.2.zip
所有版本列表
http://prdownloads.sourceforge.net/fckeditor

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久国产| 国产精品成人观看视频国产奇米| 久久精品视频99| 亚洲激情视频在线观看| 日韩中文字幕欧美| 久99久在线视频| 亚洲精品小视频| 国产深夜精品福利| 国产精品电影观看| 美女扒开尿口让男人操亚洲视频网站| 亚洲色在线视频| 久久韩剧网电视剧| 亚洲电影在线看| 亚洲精品美女视频| 久久香蕉国产线看观看av| 国产成人91久久精品| 欧美一区二区.| 国产精品成人一区二区| 久久久免费观看| 欧美黑人性生活视频| 激情成人中文字幕| 亚洲一二在线观看| 亚洲国产精品va在线观看黑人| 亚洲福利在线视频| 日韩欧美一区二区三区久久| 国产精品成人观看视频国产奇米| 欧美资源在线观看| 4p变态网欧美系列| 日韩免费在线免费观看| 亚洲成人a级网| 精品国产乱码久久久久酒店| 亚洲韩国日本中文字幕| 91精品国产免费久久久久久| 日韩中文在线中文网在线观看| 91国自产精品中文字幕亚洲| 68精品国产免费久久久久久婷婷| 91精品久久久久久久久久久久久| 国产不卡精品视男人的天堂| 久久人人爽国产| 伊人久久男人天堂| 国产在线精品成人一区二区三区| 久久激情五月丁香伊人| 九九精品在线播放| 久久久久久久久综合| 色yeye香蕉凹凸一区二区av| 日韩欧美亚洲成人| 欧美午夜影院在线视频| 国产主播精品在线| 欧美日本在线视频中文字字幕| 亚洲第一精品久久忘忧草社区| 2019中文字幕免费视频| 亚洲丝袜一区在线| 一区二区成人av| 亚洲精品网址在线观看| 中文字幕日韩av综合精品| 亚洲一区久久久| 97久久精品视频| 91国产精品电影| 一个人看的www久久| 久久青草福利网站| 亚洲国产小视频| 中文字幕一精品亚洲无线一区| 亚洲福利精品在线| 国产专区精品视频| 97国产suv精品一区二区62| 深夜福利亚洲导航| 国产91在线播放精品91| 亚洲毛片在线观看.| 亚洲男子天堂网| 日日狠狠久久偷偷四色综合免费| 日韩av大片免费看| 92国产精品久久久久首页| 亚洲精品久久久久中文字幕二区| 成人天堂噜噜噜| 亚洲成人1234| 亚洲在线观看视频网站| 成人性生交大片免费看视频直播| 成人免费看吃奶视频网站| 中文字幕亚洲综合久久| 日韩在线观看网址| 国产精品偷伦一区二区| 国产不卡一区二区在线播放| 欧美一级成年大片在线观看| y97精品国产97久久久久久| 91久久久久久久久久| 久久色在线播放| 91免费在线视频| 午夜欧美大片免费观看| 国产综合久久久久| 成人性生交大片免费看小说| 成人h片在线播放免费网站| 尤物tv国产一区| 91欧美视频网站| 91久久夜色精品国产网站| 中文字幕国产亚洲| 日韩小视频在线| 大胆人体色综合| 国产丝袜一区二区| 欧美激情免费在线| 亚洲黄色www| 精品国产一区二区三区在线观看| 在线观看中文字幕亚洲| 欧美性做爰毛片| 亚州精品天堂中文字幕| 欧美成人中文字幕在线| 一区二区三区四区在线观看视频| 亚洲性av在线| 色无极影院亚洲| 伊人伊成久久人综合网站| 欧美一级免费视频| 亚洲www在线观看| 8090理伦午夜在线电影| 91免费高清视频| 国产精品电影一区| 亚洲春色另类小说| 78m国产成人精品视频| 在线看日韩av| 久久偷看各类女兵18女厕嘘嘘| 韩国日本不卡在线| 中文字幕国产精品久久| 国产成人精品免费视频| 久久精品在线播放| 亚洲午夜精品视频| 欧美精品videos性欧美| 国产精品第七十二页| 中文字幕视频在线免费欧美日韩综合在线看| 午夜精品久久久久久99热| 亚洲激情视频在线播放| 992tv成人免费影院| 久久久久久网址| 影音先锋欧美在线资源| 成人av电影天堂| 国产亚洲人成a一在线v站| 一区二区三区高清国产| 国产区精品视频| 亚洲激情在线视频| 欧美丰满少妇xxxx| 欧美日韩国产色视频| 欧美大片在线影院| 日韩av在线网址| 国产精品入口福利| 亚洲第一区中文字幕| 日韩av免费观影| 精品一区二区电影| 久久免费在线观看| 国产精品日韩在线播放| 欧美极品在线播放| 国产精品国产亚洲伊人久久| 欧美午夜丰满在线18影院| 九九热精品视频| 97在线免费观看| 在线观看日韩www视频免费| 亚洲欧美国产日韩天堂区| 久久久久这里只有精品| 亚洲石原莉奈一区二区在线观看| 欧美大片免费观看在线观看网站推荐| 日韩成人中文电影| 国产精品va在线播放| 国产精品一区二区久久| 中文字幕精品在线| 欧美老少做受xxxx高潮| 久久精品国产v日韩v亚洲| 亚洲性生活视频在线观看| 91久久久国产精品|