FCKeditor配置中文手冊

性能

首先,FCKEDITOR的性能是很是好的,用戶只需不多的時間就能夠載入FCKEDITOR所需文件.對於其餘在線編輯器來講,這幾乎是個很難解決的難題,由於在開啓編輯器時須要裝載太多的文件.好比CUTEEDITOR,雖然功能比FCKEDITOR還要強大,但是,它自己也夠龐大了,至於FREETEXTBOX等,其易用性與 FCKEDITOR相比,尚有差距,能夠說,FCKEDITOR是一個別具匠心的在線編輯器,它裏面融入了做者高深的面向對象的JAVASCRIPT功力,集易用性與強大的功能與一體.

.與編輯器相關的全部圖像,腳本以及調用頁
.語言文件
.編輯器的皮膚文件
.工具樣的貼圖等

這些將致使在服務器和客戶端間產生至關的流量.若是有許多文件被調用,那麼即使每一個文件很小.也會讓用戶等得不耐煩.

在2.0版中,開發人員有兩種方法來解決這個問題.
那就是指定裝載順序和腳本壓縮

裝載順序
從2.0版開始,編輯器按如下步驟裝載資源:
.基本頁(就是編輯器所在頁)以及裝入編輯器的JS腳本
.用來創建編輯器的腳本
.編輯器的語言和皮膚.
.創建編輯器.
.載入預置的編輯文檔內容.
.從如今開始,用戶能夠閱讀和編輯文檔了,不過,拖拽支持以及工具欄都是不可用的
.載入編輯器引擎腳本
.創建工具欄,而且可用
.從如今開始,編輯器的全部功能都已經完整
.載入工具欄圖標

腳本壓縮

在打包任何新版本時,編輯器的JS腳本將會進行預處理.預處理步驟以下:
.移除全部代碼註釋
.移除全部無用的空白字符.
.將腳本合併成幾個文件

使用上面的方法,咱們能夠將腳本文件的大小壓縮到原來的50%.
壓縮後,原始的代碼仍然存在於一個名爲_Source的文件夾中

如何打包?
編輯器已經自帶了打包程序,它位於FCKEDITOR的根文件夾中_PACKAGER文件夾中,名爲Fckeditor.Packager.exe,將其複製到FCKEDITOR根文件夾中並運行,便可自動將JS腳本打包並壓縮
須要注意的是該程序是一個.NET程序,必須安裝.NET FRAMEWORK才能使用

想要獲取支持?
若是你捐贈15000歐元,你就能夠得到1年的免費技術支持(比較貴的說,至關於人民幣15萬,不過西歐的費用至關驚人)

如何安裝?

1.下載最新版的FCKEDITOR
2.解壓縮到你的站點根文件夾中名爲FCKEDITOR的文件夾中(名稱必須爲FCKEDITOR,由於配置文件中已經使用此名稱來標示出FCKEDITOR的位置)
3.如今,編輯器就可使用了,若是想要查看演示,能夠按下面方法訪問:
http://<your-site>/FCKeditor/_samples/default.html

注意:你能夠將FCKEDITOR放置到任何文件夾,默認狀況下,將其放入到FCKEDITOR文件夾是最爲簡單的方法.若是你放入的文件夾使用別的名稱,請修改配置文件夾中編輯器BasePath參數,以下所示:
oFckeditor.BasePath="/Components/fckeditor/";

另外,FCKEDITOR文件夾中全部如下劃線開頭的文件夾及文件,都是可選的,能夠安全的從你的發佈中刪除.它們並非編輯器運行時必需的

如何將FCKEDITOR整合進個人頁面?

因爲目前的版本提供的FCKEDITOR僅提供了JAVASCRIPT式的整合,所以,這裏僅講述如何應用JAVASCRIPT來整合FCKEDITOR到站點中,固然,其餘各類語言的整合,你能夠參考_samples文件夾中的例子來完成
1,假如編輯器已經安裝在你的站點的/FCKEDITOR/文件夾下.那麼,第一步咱們須要作的就是在頁面的HEAD段中放入SCRIPT標記以引入JAVASCRIPT整合模塊.例如:
<script type="text/javascript" src="/fckeditor/fckeditor.js"></script>

其中路徑是可更改的

2,如今,FCKEDITOR類已經可使用了.有兩個方法在頁面中創建一個FCKEDITOR編輯器:
方法1:內聯方式(建議使用):在頁面的FORM標記內須要插入編輯器的地方置入如下代碼:
script type="text/javascript">
var oFCKeditor = new FCKeditor( 'FCKeditor1' ) ;
oFCKeditor.Create() ;
</script>

方法2:TEXTAREA標記替換法(不建議使用):在頁面的ONLOAD事件中,添加如下代碼以替換一個已經存在的TEXTAREA標記

<html>
<head>
<script type="text/javascript">
window.onload = function()
{
var oFCKeditor = new FCKeditor( 'MyTextarea' ) ;
oFCKeditor.ReplaceTextarea() ;
}
</script>
</head>
<body>
<textarea id="MyTextarea" name="MyTextarea">This is <b>the</b> initial value.</textarea>
</body>
</html>

3.如今,編輯器可使用了

FCKEDITOR類參考:
下面是用來在頁面中創建編輯器的FCKEDITOR類的說明

構造器:
FCKeditor( instanceName[, width, height, toolbarSet, value] )
instanceName:編輯器的惟一名稱(至關於ID)
WIDTH:寬度
HEIGHT:高度
toolbarSet:工具條集合的名稱
value:編輯器初始化內容

屬性:
instanceName:編輯器實例名
width:寬度,默認值爲100%
height:高度,默認值是200
ToolbarSet:工具集名稱,參考FCKCONFIG.JS,默認值是Default
value:初始化編輯器的HTML代碼,默認值爲空
BasePath:編輯器的基路徑,默認爲/Fckeditor/文件夾,注意,儘可能不要使用相對路徑.最好能用相對於站點根路徑的表示方法,要以/結尾
CheckBrowser:是否在顯示編輯器前檢查瀏覽器兼容性,默認爲true
DisplayErrors:是否顯示提示錯誤,默爲true;

集合:
Config[Key]=value;
這個集合用於更改配置中某一項的值,如
oFckeditor.Config["DefaultLanguage"]="pt-br";

方法:
Create()
創建並輸出編輯器

RepaceTextArea(TextAreaName)
用編輯器來替換對應的文本框

如何配置FCKEDITOR?
FCKEDITOR提供了一套用於定製其外觀,特性及行爲的設置集.主配置文件名爲Fckconfig.js
你既能夠編輯主配置文件,也能夠本身定義單獨的配置文件.配置文件使用JAVASCRIPT語法.

修改後,在創建編輯器時,可使用如下語法:
var oFCKeditor = new FCKeditor( 'FCKeditor1' ) ;
oFCKeditor.Config['CustomConfigurationsPath'] = '/myconfig.js' ;
oFCKeditor.Create() ;

提醒:當你修改配置後,請清空瀏覽器緩存以查看效果

配置選項:

AutoDetectLanguage=true/false 自動檢測語言
BaseHref="" _fcksavedurl="""" 相對連接的基地址
ContentLangDirection="ltr/rtl" 默認文字方向
ContextMenu=字符串數組,右鍵菜單的內容
CustomConfigurationsPath="" 自定義配置文件路徑和名稱
Debug=true/false 是否開啓調試功能,這樣,當調用FCKDebug.Output()時,會在調試窗中輸出內容
DefaultLanguage="" 缺省語言
EditorAreaCss="" 編輯區的樣式表文件
EnableSourceXHTML=true/false 爲TRUE時,當由可視化界面切換到代碼頁時,把HTML處理成XHTML
EnableXHTML=true/false 是否容許使用XHTML取代HTML
FillEmptyBlocks=true/false 使用這個功能,能夠將空的塊級元素用空格來替代
FontColors="" 設置顯示顏色拾取器時文字顏色列表
FontFormats="" 設置顯示在文字格式列表中的命名
FontNames="" 字體列表中的字體名
FontSizes="" 字體大小中的字號列表
ForcePasteAsPlainText=true/false 強制粘貼爲純文本
ForceSimpleAmpersand=true/false 是否不把&符號轉換爲XML實體
FormatIndentator="" 當在源碼格式下縮進代碼使用的字符
FormatOutput=true/false 當輸出內容時是否自動格式化代碼
FormatSource=true/false 在切換到代碼視圖時是否自動格式化代碼
FullPage=true/false 是否容許編輯整個HTML文件,仍是僅容許編輯BODY間的內容
GeckoUseSPAN=true/false 是否容許SPAN標記代替B,I,U標記
IeSpellDownloadUrl=""下載拼寫檢查器的網址
ImageBrowser=true/false 是否容許瀏覽服務器功能
ImageBrowserURL="" 瀏覽服務器時運行的URL
ImageBrowserWindowHeight="" 圖像瀏覽器窗口高度
ImageBrowserWindowWidth="" 圖像瀏覽器窗口寬度
LinkBrowser=true/false 是否容許在插入連接時瀏覽服務器
LinkBrowserURL="" 插入連接時瀏覽服務器的URL
LinkBrowserWindowHeight=""連接目標瀏覽器窗口高度
LinkBrowserWindowWidth=""連接目標瀏覽器窗口寬度
Plugins=object 註冊插件
PluginsPath="" 插件文件夾
ShowBorders=true/false 合併邊框
SkinPath="" 皮膚文件夾位置
SmileyColumns=12 圖符窗列數
SmileyImages=字符數組 圖符窗中圖片文件名數組
SmileyPath="" 圖符文件夾路徑
SmileyWindowHeight 圖符窗口高度
SmileyWindowWidth 圖符窗口寬度
SpellChecker="ieSpell/Spellerpages" 設置拼寫檢查器
StartupFocus=true/false 開啓時FOCUS到編輯器
StylesXmlPath="" 設置定義CSS樣式列表的XML文件的位置
TabSpaces=4 TAB鍵產生的空格字符數
ToolBarCanCollapse=true/false 是否容許展開/摺疊工具欄
ToolbarSets=object 容許使用TOOLBAR集合
ToolbarStartExpanded=true/false 開啓是TOOLBAR是否展開
UseBROnCarriageReturn=true/false 當回車時是產生BR標記仍是P或者DIV標記

如何自定義樣式列表呢?
FCKEDITOR的樣式工具欄中提供了預約義的樣式,樣式是經過XML文件定義的,默認的XML樣式文件存在於FCkEditor根文件夾下的FckStyls.xml文件中
這個XML文件的結構分析以下:
<?xml version="1.0" encoding="utf-8" ?>
<Styles >
<Style name="My Image" element="img">
<Attribute name="style" value="padding: 5px" />
<Attribute name="border" value="2" />
</Style >
<Style name="Italic" element="em" />
<Style name="Title" element="span">
<Attribute name="class" value="Title" />
</Style >
<Style name="Title H3" element="h3" />
</Styles>

每個STYLE標記定義一種樣式,NAME是顯示在下拉列表中的樣式名,ELEMENT屬性指定此樣式所適用的對象,由於FCKEDITOR中的樣式是上下文敏感的,也就是說,選擇不一樣的對象,僅會顯示針對這類對象定義的樣式

拼寫檢查

FCKEDITOR 帶了兩種拼寫檢查工具,一種是ieSpell,默認狀況下使用這種,使用這種方式的拼寫檢查,要求客戶下載並安裝iespell這個小軟件,另外,也提供 SpellPager的方式來進行拼寫檢查,不過,因爲SPELLPAGER是由PHP編寫的服務器端腳本,所以,要求你的WEB服務器必須支持PHP腳本語言方可
更改拼寫檢查器的方式請參見有關配置文件的詳細說明

壓縮腳本

爲了提供腳本載入的效率,FCKEDITOR採用如下方法對腳本儘可能壓縮以減小腳本尺寸:
1,移除掉腳本中的註釋
2.移除掉腳本中全部無心義的空白
另外,FCKEDITOR還提供了一個專門用於壓縮腳本的工具以便 你在發佈時能減少文件尺寸,
你能夠將_Packager文件夾中的Fckeditor.Packager.exe複製到FCKEDITOR根文件夾來運行並壓縮腳本

本地化FCKEDITOR
若是FCKEDITOR沒有提供您所須要的語言(實際上全有了),你也能夠自行製做新的語言
,你只須要複製出EN.JS,而後在其基礎上進行翻譯.另外,語言名稱與對應的腳本文件名必須遵循RFC 3066標準,可是,須要小寫,例如:Portuguess Language對應的腳本文件名必須爲pt.js
若是須要針對某個國家的某種語系,則能夠在語系縮寫後加上橫線及國家縮寫便可

在使用時,系統會自動偵測客戶端語系及國別而運用適當的界面語言.

當創建一種新的語言後,你必須在"Edit/lang/fcklanguagemanager.js"中爲其創建一個條目,以下所示:
FCKLanguageManager.AvailableLanguages =
{

en : 'English',
pt : 'Portuguese'
}

須要提醒的是,文件必須保存爲UTF-8格式

如何與服務器端腳本進行交互?
請查看例子以獲得相關內容

另外,在ASP.NET中以如下步驟使用
1.把FCKEDITOR添中到工具箱
2.託拽FCKEDITOR控件到頁面
3.爲其指定名稱
4.FCKEDITOR 類的全部屬性不光能夠在代碼中使用,並且能夠做爲FCKEDITOR控件的屬性直接使用,例如,要改變皮膚,能夠在UI頁面中指定SkinPath= "/fckeditor/editor/skins/office2003"便可,其實FCKEDITOR的ASP.NET版本能夠作得更好,你能夠找到 FCKEDITOR ASP.NET 2.1的源文件,而後修改該控件的設計,爲其暴露更多有用的屬性,從新編譯便可
5,POSTBACK後的數據,使用FCKEDITOR控件的value屬性得到
6. 因爲默認狀態下,ASP.NET不容許提交含有HTML及JAVASCRIPT的內容,所以,你必須將使用FCKEDITOR的頁面的 ValidateRequest設爲false.(<%@page validteRequest="false" %>便可)javascript

--------------------------------------------------------php

附:html

1、如何設置上傳文件語言java

把FCKeditor根目錄下面的fckconfig.js文件裏

var _FileBrowserLanguage     = 'asp' ;     // asp | aspx | cfm | lasso | perl | php | py
var _QuickUploadLanguage     = 'asp' ;     // asp | aspx | cfm | lasso | php

這兩行中改爲您所須要調用的編輯器語言,如用asp.net則改成aspx;web

2、解決中文的問題:
在web.config中加入:
<globalization requestEncoding="GB2312" responseEncoding="GB2312"/>
這樣設置後能夠顯示中文的文件,但URL地址也是中文的;
若是服務器對中文地址的解析很差,可能致使圖片沒法瀏覽;
因此修改:editor\filemanager\browser\default\frmresourceslist.html
中的OpenFile函數,把
window.top.opener.SetUrl( fileUrl ) ;
修改成:
window.top.opener.SetUrl( escape(fileUrl) ) ;數組


三.設置上傳的目錄:
1:在web.config中設置:
<appSettings>
     <add key="FCKeditor:UserFilesPath" value="/fck/UpLoad/" />
</appSettings>瀏覽器

2:在Session中設置:
在editor\filemanager\browser\default\connectors\aspx\connector.aspx中加入如下代碼:
<script runat="server" language="C#">
protected override void OnInit(EventArgs e)
{
   Session["FCKeditor:UserFilesPath"] = "/fck/UpLoad1/";
}
</script>緩存

附:如何在asp.net中動態設置上傳圖片的路徑?安全

1.在javascript中修改FCKConfig.ImageBrowserURL的值,修改方式以下:
FCKConfig.ImageBrowserURL += "?Path=要上傳的文件路徑";
如:要把文件上傳到站點根目錄的UploadFile文件夾中,則設置爲:
FCKConfig.ImageBrowserURL += "?Path=/UploadFile";
2.在"editor\filemanager\browser\default\connectors\aspx\connector.aspx"文件最後中增長如下程序:
<script runat="server" language="C#">
    protected override void OnInit(EventArgs e)
    {
if( Request.QueryString["Path"]==null ){
   Session["FCKeditor:UserFilesPath"] = "/UpLoadFiles/"; //設置默認值
}else{
   Session["FCKeditor:UserFilesPath"] = Request.QueryString["Path"];
}
    }
</script>服務器

相關文章
相關標籤/搜索