HtmlArea是一款很簡潔的WTYSWTYG編輯器,以前我用的是FreeTextBox,缺點 很多,運行速度慢,架構太復雜,不支持ajax等等,前面還特地寫了一篇文章《 Ajax中的UpdatePanel與Freetextbox兼容問題的初步解決方法》,現在終於痛下 決心砍了。
HtmlArea是純JS+Html的編輯器,理論上可以套在任何語言平台上,經過實際 使用可以和Asp.Net 2.0 + Ajax 很好的結合,現在本博客系統已經拿它當作文 章編輯器了,下面就是具體安裝步驟。
首先下載HtmlArea3.0,解壓到Web項目的某個目錄。
lang/gb.js 是中文語言文件,官方默認是ANSI編碼的,如果你的web.config 設置為utf-8(默認),則需要用記事本打開gb.js,另存為utf-8格式。
以下是引用片段:
<script type="text/javascript"> _editor_url = "../HtmlArea/"; _editor_lang = "gb";</script>
<script type="text/javascript" src="../HtmlArea/htmlarea.js"></script>
<asp:TextBox ID="HtmlArea" CssClass="htmlarea" runat="server" Height="200px" TextMode="MultiLine" Width="100%"></asp:TextBox>
以下是引用片段:
protected void Page_Load(object sender, EventArgs e){
if (!Page.IsPostBack) {
StringBuilder sb = new StringBuilder();
sb.Append("var editor = null;");
sb.Append("function initEditor() {");
sb.Append("editor = new HTMLArea('" + ArticleBody1.FindControl("HtmlArea").ClientID + "');");
sb.Append("editor.generate();}");sb.Append("document.body.onload=initEditor;");
ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "HtmlAreaScript", sb.ToString(), true);}
}
如果是UpdatePanel提交,則還須在提交後執行下面語句,重新初始化編輯器 :
以下是引用片段:
ScriptManager.RegisterStartupScript (this.Page,this.GetType(),"HtmlAreaScript","initEditor ();",true);