ASP.NET AJAX示例:論壇主題搜索
ASP.NET AJAX示例:論壇主題搜索
我們要看的***一個(gè)示例是對現(xiàn)有應(yīng)用程序的修改。我***聽到這個(gè)想法是 Josh Ledgard設(shè)想在 MSDN 論壇里添加一個(gè)功能。目的是嘗試幫助用戶自己找到問題的答案,以及限制重復(fù)發(fā)布的數(shù)量。一般來說,用戶在論壇中提出新問題時(shí),他或她會輸入主題和問題。他們通常都不會先進(jìn)行搜索,來查看是否已經(jīng)提出和回答過該問題。輸入 AJAX。用戶輸入主題(并將 Tab 鍵移出該字段)后,我們基于該主題異步搜索論壇,并適時(shí)地向用戶顯示結(jié)果。有時(shí)這些結(jié)果會有幫助,有時(shí)候則不會。
為使結(jié)果有幫助,我們將修改 asp.NETPRO Reader's Choice Award for Best Forum Application, CommunityServer??上螺d的示例中不包含這一部分(或論壇)的代碼,但是您能在 http://communityserver.org/(英文)學(xué)到關(guān)于 CommunityServer 的更多知識,并且可在其中應(yīng)用下面這些代碼片斷。
安裝 CommunityServer 并配置 Ajax.NET(已將引用和處理程序添加到 web.config)后,我們只需要進(jìn)行一些更改就可以獲得所需的功能。首先,我們轉(zhuǎn)到 CommunityServerForums 項(xiàng)目中的 CreateEditPost.cs 文件。將它視為此頁的后面的代碼,其中用戶可以添加新的發(fā)布。下面我們將添加啟用了 AJAX 的函數(shù)。
- //C#:ASP.NET AJAX示例
- [Ajax.AjaxMethod()]
- public static ArrayList Search(string search)
- {
- SearchQuery query = new SearchQuery();
- query.PageIndex = 0; //獲得前 10 個(gè)結(jié)果
- query.PageSize = 10;
- query.UserID = Users.GetUser().UserID;
- query.SearchTerms = search;
- return new ForumSearch().GetSearchResults(query).Posts;
- }
我們能夠利用已經(jīng)在 CommunityServer 中創(chuàng)建的搜索功能,只需要我們的函數(shù)能應(yīng)用它。如往常一樣,類型必須使用 Ajax.NET 注冊。我們將在同一文件的 InitializeSkin 函數(shù)(將其視為 Page_Load)中進(jìn)行此操作。
- //C#:ASP.NET AJAX示例
- Ajax.Utility.RegisterTypeForAjax(typeof(CreateEditPost));
在轉(zhuǎn)跳到 JavaScript 之前,我們需要進(jìn)行***的服務(wù)器端更改。返回到 Ajax.NET 的自定義類(例如我們正在返回的 ArrayList 所包含的 ForumPost)必須標(biāo)有 Serializable 屬性。我們要做的是轉(zhuǎn)到 CommunityServerForums 項(xiàng)目中的 Components/ForumPost.cs 文件,并添加此屬性。
- //C#:ASP.NET AJAX示例
- [Serializable]
- public class ForumPost :Post
- {
- ...
- }
顯示時(shí),我們僅需要修改 CommunityServerWeb 項(xiàng)目中的 Themes/default/Skins/View-EditCreatePost.cs。首先,我們將觸發(fā)主題文本框的 onBlur 事件。
- < asp:textbox onBlur="Search(this.value);"
- id="PostSubject" runat="server" ... />
接著,我們編寫 JavaScript Search 方法,以便調(diào)用服務(wù)器端 Search。
- var oldValue = '';
- function Search(value)
- {
- //不要再次搜索剛搜索過的內(nèi)容
- //如果用戶向后或向前移動 Tab 鍵將會發(fā)生
- if (value != oldValue)
- {
- CreateEditPost.Search(value, Search_CallBack);
- oldValue = value;
- }
- }
***,剩下的就是處理響應(yīng)。由于上一個(gè)示例介紹了在表中顯示結(jié)果的稍微正規(guī)的方式,我們將僅僅創(chuàng)建一些動態(tài)的 HTML,并將它粘貼到虛擬的 DIV 中。
- function Search_CallBack(response)
- {
- //由于沒有結(jié)果時(shí)搜索功能將自動重定向,
- //因此,我們不能使用 response.error。
- var results = response.value;
- //如果我們沒有獲得結(jié)果
- if (results == null)
- {
- return;
- }
- //我們用于放置結(jié)果的 DIV
- var someDiv = document.getElementById("someDiv");
- var html = "";
- for (var i = 0; i < results.length; ++i)
- {
- var result = results[i];
- html += "< a target=_blank href='" + result.PostID
- html += "/ShowPost.aspx'>";
- html += result.Subject;
- html += "< /a>< br />"
- }
- someDiv.innerHTML = html;
- }
通過對 CommunityServer 應(yīng)用程序的三個(gè)文件(加上用于配置的 web.config)稍微進(jìn)行修改,我們可以添加一些非常有用的功能。但是,只向現(xiàn)有的應(yīng)用程序添加啟用 AJAX 功能時(shí)要小心操作。正在進(jìn)行實(shí)際搜索的預(yù)先存在的 ForumSearch 類可能并不是為我們介紹的使用類型設(shè)計(jì)的。我們的代碼很可能會導(dǎo)致執(zhí)行一些額外的搜索,影響可能會很顯著。
以上就是ASP.NET AJAX示例:論壇主題搜索的實(shí)現(xiàn)方法。
【編輯推薦】