ASP.NETAJAX怎么实现论坛主题搜索

这篇文章主要介绍“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怎么实现论坛主题搜索”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


名称栏目:ASP.NETAJAX怎么实现论坛主题搜索
本文来源:http://bzwzjz.com/article/ijdech.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站设计 定制级高端网站建设 成都网站建设公司 成都网站制作 高端网站设计 成都网站制作 成都网站制作 企业网站设计 网站建设公司 成都网站设计 成都网站制作 成都网站建设 成都定制网站建设 移动网站建设 网站设计公司 营销型网站建设 网站设计 网站设计制作报价 网站制作公司 温江网站设计 网站制作 定制网站制作