天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

AJAX FCKEditor Rich Editor整合篇第1/2頁

(http://www.fckeditor.NETJavaEye的編輯器也是采用的FCKEditor,XX所見略同?呵呵),它OpenSource(免費啊,可以直接改源代碼啊,呵呵),功能強大(幾乎就是一個office word的web版),提供了對各種服務器端的支持(雖然它完全是一個純客戶端的東東, 但是目前提供了與.NET, php, Java, Coldfusion, Perl, Lasso, Python各種服務器端腳本的緊密集成),支持國際化(漢化做的非常棒),可更換皮膚(office 2000的風格簡直可以亂真),內嵌文件上傳(Java版本支持這個),保持一定的更新狀態(目前版本為2.3.2),如此等等。當然它還有N多功能,不過我還沒仔細去研究,如果有哪位用到的,可以告知一二。

至于FCKEditor的各種用法我就不在這里一一列舉,網上有很多相關的文章,它也自帶了不錯的sample,可以非常容易加入到我們自己的項目中去。

不過在Ajax應用中如何使用FCKEditor控件呢?這個FCKEditor好像沒有提供相應的答案,因為Ajax都是采用的無刷新提交,而FCKEditor只能在Form提交方式下使用,為什么這樣說呢,那我們還得從FCKEditor的執行流程說起。

FCKEditor的編輯器實際上是一個IFrame,每次在創建一個FCKEditor實體的時候,都會新建一個IFrame,然后各種toolbar和編輯區都塞到這個IFrame中去了,在IFrame外面必須有一個對應的input元素(這個一般是一個textarea,FCKEditor中稱之為LinkedField),這樣就可以將textarea中的已有的內容導入到編輯器中,或者將編輯好的內容更新到LinkedField中。那FCKEditor中的內容是何時保存到對應的LinkedField中去的呢?開始我沒有看源碼,以為是在FCKEditor中的內容發生改變的時候同時更新LinkedField的,后來發現不是,如果是這樣的話,那我們就可以很容易在ajax中使用FCKEditor了。那到底是什么時候做到與LinkedField同步的呢?答案肯定是在form執行submit事件之前,要在submit之前做到更新唯一的方式就是通過attachEvent方式將更新的回調函數綁定到onsubmit事件上,然后通過一定的方式在submit之前調用綁定的函數。因此就在FCKEditor提供的核心js文件中查找onsubmit,后來在fckeditorcode_ie.js文件找到了onsubmit關鍵字(這里不得不提到的一點,FCKEditor雖然做到了開源,但是對于他們的Javascript源代碼還是有所保留的,里面的很多核心js文件都進行了混淆重排,不過這個也不能怪人家不厚道,為了方便查看源代碼,吐血推薦采用MyEclipse的document format功能進行格式化處理,這樣基本上可以對里面的結構一目了然了)。

相關代碼如下,首先是在FCKEditor初始化的時候:
復制代碼 代碼如下:
function FCK_EditingArea_OnLoad() {
FCK.EditorWindow = FCK.EditingArea.Window;
FCK.EditorDocument = FCK.EditingArea.Document;
FCK.InitializeBehaviors();
FCK.OnAfterSetHTML();
if (FCK.Status != FCK_STATUS_NOTLOADED) {
return;
}
FCK.ResetIsDirty();
FCKTools.AttachToLinkedFieldFormSubmit(FCK.UpdateLinkedField); // 開始做綁定
FCK.SetStatus(FCK_STATUS_ACTIVE);
}

然后是submit提交前的處理:
復制代碼 代碼如下:
FCKTools.AttachToLinkedFieldFormSubmit = function (A) {
var B = FCK.LinkedField.form;
if (!B) {
return;
}
if (FCKBrowserInfo.IsIE) {
B.attachEvent("onsubmit", A); // 將更新處理綁定到form的onsubmit事件上
} else {
B.addEventListener("submit", A, false);
}
if (!B.updateFCKeditor) {
B.updateFCKeditor = new Array();
}
B.updateFCKeditor[B.updateFCKeditor.length] = A;
if (!B.originalSubmit && (typeof (B.submit) == "function" || (!B.submit.tagName && !B.submit.length))) {
B.originalSubmit = B.submit;
B.submit = FCKTools_SubmitReplacer;
}
};

jsp技術AJAX FCKEditor Rich Editor整合篇第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 91区国产福利在线观看午夜 | 天天狠狠弄夜夜狠狠躁·太爽了 | 儿媳妇完整版视频播放免费观看 | 久久综合视频网站 | 国产高清精品国语特黄A片 国产高清国内精品福利色噜噜 | 欧美亚洲日本日韩在线 | 午夜福到在线2019 | 午夜噜噜噜私人影院在线播放 | 亚洲欧美日韩国产手机在线 | 2019久久这里只精品热在线观看 | 日本A级作爱片金瓶双艳 | 影视先锋男人无码在线 | YELLOW免费观看完整视频 | 精品国产在线手机在线 | 久久足恋网 | 黄色三级图片 | 日本bbwhd | 97在线播放 | 久久精品18 | 国内自拍 在线 亚洲 欧美 | 快插我我好湿啊公交车上做 | 国内精品久久久久影院老司 | 公粗挺进了我的密道在线播放贝壳 | 国产精品单位女同事在线 | 久久www免费人成_看片高清 | 黄色天堂在线 | 伊人精品视频直播 | 竹菊影视一区二区三区 | 伸到同桌奶罩里捏她胸h | 久久这里的只有是精品23 | 中文乱码35页在线观看 | 新影音先锋男人色资源网 | 国产综合自拍 偷拍在线 | 亲胸揉胸膜下刺激视频网站APP | 出轨的妻子在线观看 | 中文字幕精品AV内射夜夜夜 | 亚洲 欧美 国产 综合五月天 | 在线二区 中文 无码 | 秋霞电影网午夜鲁丝片 | 精品夜夜澡人妻无码AV蜜桃 | 亚洲中文无码亚洲人在线观看- |