ASP.NETAJAX示例:论坛主题搜索

ASP.NET AJAX示例:论坛主题搜索

我们要看的***一个示例是对现有应用程序的修改。我***听到这个想法是 Josh Ledgard设想在 MSDN 论坛里添加一个功能。目的是尝试帮助用户自己找到问题的答案,以及限制重复发布的数量。一般来说,用户在论坛中提出新问题时,他或她会输入主题和问题。他们通常都不会先进行搜索,来查看是否已经提出和回答过该问题。输入 AJAX。用户输入主题(并将 Tab 键移出该字段)后,我们基于该主题异步搜索论坛,并适时地向用户显示结果。有时这些结果会有帮助,有时候则不会。

为使结果有帮助,我们将修改 asp.NETPRO Reader's Choice Award for Best Forum Application, CommunityServer。可下载的示例中不包含这一部分(或论坛)的代码,但是您能在 http://communityserver.org/(英文)学到关于 CommunityServer 的更多知识,并且可在其中应用下面这些代码片断。

安装 CommunityServer 并配置 Ajax.NET(已将引用和处理程序添加到 web.config)后,我们只需要进行一些更改就可以获得所需的功能。首先,我们转到 CommunityServerForums 项目中的 CreateEditPost.cs 文件。将它视为此页的后面的代码,其中用户可以添加新的发布。下面我们将添加启用了 AJAX 的函数。

 
 
 
  1. //C#:ASP.NET AJAX示例  
  2. [Ajax.AjaxMethod()]  
  3. public static ArrayList Search(string search)  
  4. {  
  5. SearchQuery query = new SearchQuery();  
  6. query.PageIndex = 0; //获得前 10 个结果  
  7. query.PageSize = 10;  
  8. query.UserID = Users.GetUser().UserID;  
  9. query.SearchTerms = search;  
  10. return new ForumSearch().GetSearchResults(query).Posts;  
  11. }  

我们能够利用已经在 CommunityServer 中创建的搜索功能,只需要我们的函数能应用它。如往常一样,类型必须使用 Ajax.NET 注册。我们将在同一文件的 InitializeSkin 函数(将其视为 Page_Load)中进行此操作。

 
 
 
  1. //C#:ASP.NET AJAX示例  
  2. Ajax.Utility.RegisterTypeForAjax(typeof(CreateEditPost));  

在转跳到 JavaScript 之前,我们需要进行***的服务器端更改。返回到 Ajax.NET 的自定义类(例如我们正在返回的 ArrayList 所包含的 ForumPost)必须标有 Serializable 属性。我们要做的是转到 CommunityServerForums 项目中的 Components/ForumPost.cs 文件,并添加此属性。

 
 
 
  1. //C#:ASP.NET AJAX示例  
  2. [Serializable]  
  3. public class ForumPost :Post  
  4. {  
  5.  ...  
  6. }  

显示时,我们仅需要修改 CommunityServerWeb 项目中的 Themes/default/Skins/View-EditCreatePost.cs。首先,我们将触发主题文本框的 onBlur 事件。

 
 
 
  1. < asp:textbox onBlur="Search(this.value);" 
  2. id="PostSubject" runat="server" ... /> 

接着,我们编写 JavaScript Search 方法,以便调用服务器端 Search。

 
 
 
  1. var oldValue = '';  
  2. function Search(value)  
  3. {   
  4. //不要再次搜索刚搜索过的内容  
  5. //如果用户向后或向前移动 Tab 键将会发生  
  6. if (value != oldValue)  
  7.   {  
  8. CreateEditPost.Search(value, Search_CallBack);  
  9. oldValue = value;  
  10.   }  
  11. }  

***,剩下的就是处理响应。由于上一个示例介绍了在表中显示结果的稍微正规的方式,我们将仅仅创建一些动态的 HTML,并将它粘贴到虚拟的 DIV 中。

 
 
 
  1. function Search_CallBack(response)  
  2. {  
  3. //由于没有结果时搜索功能将自动重定向,  
  4. //因此,我们不能使用 response.error。  
  5. var results = response.value;  
  6. //如果我们没有获得结果  
  7. if (results == null)  
  8.  {  
  9. return;  
  10.  }  
  11. //我们用于放置结果的 DIV  
  12. var someDiv = document.getElementById("someDiv");  
  13. var html = "";  
  14. for (var i = 0; i <  results.length; ++i)  
  15.  {  
  16. var result = results[i];  
  17. html += "< a target=_blank href='" + result.PostID  
  18. html += "/ShowPost.aspx'>";     
  19. html += result.Subject;  
  20. html += "< /a>< br />" 
  21.  }  
  22. someDiv.innerHTML = html;  
  23. }  

通过对 CommunityServer 应用程序的三个文件(加上用于配置的 web.config)稍微进行修改,我们可以添加一些非常有用的功能。但是,只向现有的应用程序添加启用 AJAX 功能时要小心操作。正在进行实际搜索的预先存在的 ForumSearch 类可能并不是为我们介绍的使用类型设计的。我们的代码很可能会导致执行一些额外的搜索,影响可能会很显著。

以上就是ASP.NET AJAX示例:论坛主题搜索的实现方法。

【编辑推荐】

  1. ASP.NET AJAX示例:文档锁定程序
  2. ASP.NET AJAX示例:下拉列表
  3. AJAX.NET安装配置全指南
  4. Ajax.Net快速入门
  5. ASP.NET AJAX软件下载

分享名称:ASP.NETAJAX示例:论坛主题搜索
标题链接:http://www.mswzjz.cn/qtweb/news48/313198.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能