使用AjaxPro实现无刷新数据检测

使用AjaxPro实现无刷新数据检测

Ajax(Asynchronous JavaScript and XML,异步JavaScript 和XML)的应用,可以创建更好、更快、以及交互性更强的 Web 应用程序。利用AjaxPro可以轻松创建Ajax应用。本文主要总结一下AjaxPro的使用步骤,并实现Ajax无刷新检测数据的简单功能。

在传统方式中,用户注册的时候,常常需要用户填写完整个表单,再提交给服务器。当系统检测该用户名已存在,便返回提示用户,并需要重新填写整个表单,用户体验很不好。

而使用Ajax技术,在用户注册过程中,当用户输入了想注册的用户名后,鼠标离开编辑框,系统就检测该用户名是否存在,并立即提示用户该用户名是否可用。现在的网站基本都采取了这种方法,避免传统方式的弊端,提升用户体验。如图所示,163邮箱的注册界面。

   Ajax的实现方式,通常可以分为以下三种:

  1、利用纯粹的JavaScript实现;

  2、利用微软自带的Ajax控件库实现;

  3、利用第三方类库实现,如AjaxPro;  这里介绍第三种方法,使用AjaxPro实现无刷新数据检测。

我要实现的是一个添加单词的功能,当鼠标离开单词输入框时,检测单词数据库中是否已存在该单词,并给出相应提示。(同用户注册原理一致)。

1、获取AjaxPro

AjaxPro是免费的Ajax类库,官网是ajaxpro.info,现在搬到了微软的开源托管网站CodePlex上,即ajaxpro.codeplex.com。

当前***版为9.2.17.1,单击Download,下载完成后,解压9.2.17.1_DLL.zip,得到如图所示的五个文件。我们将使用AjaxPro.2.dll和web.config配置文件。

2、添加引用

为项目添加AjaxPro的引用。右键项目下的“引用”目录,添加引用,浏览找到AjaxPro.2.dll,确定。

3、配置web.config

为网站的web.config添加AjaxPro的配置信息,主要添加三部分内容(具体代码参考AjaxPro压缩包中的web.config文件)。

1)在webconfig —— —— 节点下,添加如下代码:

 
 
 
 
  1.   
  2.   
  3.     type="AjaxPro.AjaxSettingsSectionHandler,AjaxPro.2"
  4.     requirePermission="false"
  5.     restartOnExternalChanges="true"
  6. />

2)在webconfig —— 节点下,添加ajaxNet节点,即如下代码:

 
 
 
 
  1.   
  2.     
  3.       
  4.     
  5.     
  6.       
  7.     
  8.     
  9.     
  10.     
  11.     
  12.     
  13.     
  14.     
  15.   

3)在webconfig —— 节点下,添加location节点,即如下代码:

 
 
 
 
  1.   
  2.     
  3.       
  4.     
  5.     
  6.     
  7.   

4、注册AjaxPro

导入AjaxPro命名空间,并在Page_Load事件处理中添加AjaxPro注册代码。

 
 
 
 
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.UI;
  6. using System.Web.UI.WebControls;
  7. using AjaxPro;
  8. namespace HujiangDict.Admin
  9. {
  10.     public partial class Addword : System.Web.UI.Page
  11.     {
  12.         protected void Page_Load(object sender, EventArgs e)
  13.         {
  14.             //注册AjaxPro,我的页面是Addword.aspx,typeof中的类名就是Addword
  15.             AjaxPro.Utility.RegisterTypeForAjax(typeof(Addword), this);
  16.         }
  17.     }
  18. }

5、编写前台代码及客户端方法

关键点是TextBox的onblur事件处理,调用的是 JS函数 checkWord()。(我在这里添加了ASP.NET验证控件和客户端字符验证的JS函数,可以不考虑)

 
 
 
 
  1.     单 词
  2.         onkeypress="return JudgeChar(event.keyCode)">
  3.             
  4.                 ErrorMessage="请输入单词" class="message">
  5.         

JS函数,checkWord(),用于同后台异步通信。该函数将服务器返回的结果,设置为id=msg消息框div的InnerHTML,即填充div,显示出验证信息。

 
 
 
 
  1.     function checkWord() {
  2.         var word = document.getElementById('tb_word').value;
  3.         if (word != '') {
  4.             var result = HujiangDict.Admin.Addword.CheckWord(word).value;
  5.             document.getElementById('msg').innerHTML = result;
  6.         }
  7.     }

 在JS调用后台Ajax方法时,要参考页面所继承的类的完整名称,这里是HujiangDict.Admin.Addword。

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Addword.aspx.cs" Inherits="HujiangDict.Admin.Addword" %>

6、编写服务端Ajax方法

后台Ajax方法,要加上[AjaxMethod]标记,这是提供给前台JS调用的方法。该方法类型为string类型,这里返回的结果是一段html,及显示验证结果的消息框。

 
 
 
 
  1. /// 
  2. /// AjAx方法 检查单词是否存在
  3. /// 
  4. /// 
  5. /// 
  6. [AjaxMethod]
  7. public string CheckWord(string word)
  8. {
  9.     string result;
  10.     WordHelper wordHelper = new WordHelper();
  11.     //如果检测数据库中存在该单词
  12.     if (wordHelper.ExistsWord(word))
  13.     {
  14.         result = "" +
  15.                             "词库中已存在单词 "+word+",您可以到 单词管理 中编辑该单词。
";
  •     }
  •     else
  •     {
  •         result = "" +
  •                             "数据库中尚无该单词 "+word+",可以添加!^_^
  • ";
  •     }
  •     return result;
  • }
  • 运行结果

    添加一个单词库中不存在的单词,鼠标离开编辑框时,提示“可以添加”。

    添加单词库中已存在的单词home时,提示“已存在”。

     本文供刚学习Ajax的同学参考,高手请轻拍。AjaxPro现在已经有点过时了,Ajax的实现,目前比较流行的还是JQuery。但是多一种实现的方式,也就多一种思考的方式。

    分享名称:使用AjaxPro实现无刷新数据检测
    当前网址:http://www.csdahua.cn/qtweb/news10/354110.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

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

    成都快上网为您推荐相关内容

    品牌网站设计知识

    各行业网站