重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍“ASP.NET AJAX怎么实现论坛主题搜索”,在日常操作中,相信很多人在ASP.NET AJAX怎么实现论坛主题搜索问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ASP.NET AJAX怎么实现论坛主题搜索”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
成都创新互联公司是一家专注于成都网站建设、成都网站设计与策划设计,矿区网站建设哪家好?成都创新互联公司做网站,专注于网站建设10多年,网设计领域的专业建站公司;建站业务涵盖:矿区等地区。矿区做网站价格咨询:18982081108
我们要看的***一个示例是对现有应用程序的修改。我***听到这个想法是 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 的函数。
//C#:ASP.NET AJAX示例 [Ajax.AjaxMethod()] public static ArrayList Search(string search) { SearchQuery query = new SearchQuery(); query.PageIndex = 0; //获得前 10 个结果 query.PageSize = 10; query.UserID = Users.GetUser().UserID; query.SearchTerms = search; return new ForumSearch().GetSearchResults(query).Posts; }
我们能够利用已经在 CommunityServer 中创建的搜索功能,只需要我们的函数能应用它。如往常一样,类型必须使用 Ajax.NET 注册。我们将在同一文件的 InitializeSkin 函数(将其视为 Page_Load)中进行此操作。
//C#:ASP.NET AJAX示例 Ajax.Utility.RegisterTypeForAjax(typeof(CreateEditPost));
在转跳到 JavaScript 之前,我们需要进行***的服务器端更改。返回到 Ajax.NET 的自定义类(例如我们正在返回的 ArrayList 所包含的 ForumPost)必须标有 Serializable 属性。我们要做的是转到 CommunityServerForums 项目中的 Components/ForumPost.cs 文件,并添加此属性。
//C#:ASP.NET AJAX示例 [Serializable] public class ForumPost :Post { ... }
显示时,我们仅需要修改 CommunityServerWeb 项目中的 Themes/default/Skins/View-EditCreatePost.cs。首先,我们将触发主题文本框的 onBlur 事件。
< asp:textbox onBlur="Search(this.value);" id="PostSubject" runat="server" ... />
接着,我们编写 JavaScript Search 方法,以便调用服务器端 Search。
var oldValue = ''; function Search(value) { //不要再次搜索刚搜索过的内容 //如果用户向后或向前移动 Tab 键将会发生 if (value != oldValue) { CreateEditPost.Search(value, Search_CallBack); oldValue = value; } }
***,剩下的就是处理响应。由于上一个示例介绍了在表中显示结果的稍微正规的方式,我们将仅仅创建一些动态的 HTML,并将它粘贴到虚拟的 DIV 中。
function Search_CallBack(response) { //由于没有结果时搜索功能将自动重定向, //因此,我们不能使用 response.error。 var results = response.value; //如果我们没有获得结果 if (results == null) { return; } //我们用于放置结果的 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 应用程序的三个文件(加上用于配置的 web.config)稍微进行修改,我们可以添加一些非常有用的功能。但是,只向现有的应用程序添加启用 AJAX 功能时要小心操作。正在进行实际搜索的预先存在的 ForumSearch 类可能并不是为我们介绍的使用类型设计的。我们的代码很可能会导致执行一些额外的搜索,影响可能会很显著。
到此,关于“ASP.NET AJAX怎么实现论坛主题搜索”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!