.NET Ajax的无刷新技术实例详解

    作者:课课家更新于: 2015-11-02 11:09:03

    大神带你学编程,欢迎选课
    恍惚恍惚又来到了c语言编程入门文章的学习,想必大家又有很多问题吧!

    C语言视频教程该开发包的新版本还没有来得及体验,估计新版本中会方便一些,C语言培训可能会去掉手动的设置Global.asax的Application_Start事件中加上.Utility.Handlath = "ajax";以及其他麻烦的设置。
    下载一个.net Ajax开发包,该开发包包括2.0和目前ASP1.1版使用的Ajax,详细地址参见http://ajax.schwarz-interactive.de/,接下来,开始。
      1. 新建一个项目,在引用中添加引用Ajax.dll,Ajax.dll位于下载的压缩包里面。
      2.建立HttpHandler,在web.config里面加上:
     
    第13讲 ASP.NET AJAX无刷新数据处理技术 AJAX(Asynchronous JavaScript and XML,异步JavaScript和XML),是一种创建互动式网页应用的网页开发技术。在传统的应用程序中,用户在客户端填写表单,然后提交表单时向服务器发送一个请求。服务器端接到表单后,处理并返回一个新的表单。这种交互方式比较浪费带宽,因为也许前后表单内容变化并不大。如果表单数据太大,客户端就会等待比较长的时间。这种情况下,AJAX技术就流行起来。 AJAX可以只向服务器发送并取回所必需修改的数据,它在客户端采用JavaScript,处理来自服务器的响应。因为服务器和浏览器之间交换的数据大量减少,结果客户端就能感受到更快的响应。同时,很多的处理工作都在客户端机器上完成,所以Web服务器的处理时间也减少了。
    lt;


    system.web>
    lt;
    httpHandlers>
    lt;
    add verb="POST,GET"
    path="ajax/*.ashx"
    type="Ajax.PageHandlerFactory,
    Ajax" />
    lt;
    /httpHandlers>

    lt;
    /configuration>
     

      3.新建一个类DemoMethods,这个类实现获取客户端MAC地址:

    using System;
    using System.Web;
    namespace AjaxSample
    {
    /**////
    /// Summary description for Methods.
    ///
    ublic class DemoMethods
    {
    [Ajax.AjaxMethod]
    ublic string GetCustomerMac(string clientIP)
    //这里输入客户端IP,这个函数知识测试用,
    你也可以写一个其他的简单一点的函数代替
    {
    tring mac = "";
    System.Diagnostics.Process process =
    new System.Diagnostics.Process();
    rocess.StartInfo.FileName = "nbtstat";
    rocess.StartInfo.Arguments = "-a "+clientIP;
    rocess.StartInfo.UseShellExecute = false;
    rocess.StartInfo.CreateNoWindow = true;
    rocess.StartInfo.RedirectStandardOutput = true;
    process.Start();
    string output = process.StandardOutput.ReadToEnd();
    int length = output.IndexOf("MAC Address = ");
    if(length>0)
    {
    mac = output.Substring(length+14, 17);
    }
    process.WaitForExit();
    return mac.Replace("-", "").Trim();
    }
    }}
     

      4.写script,新建一个名为default.js文件如下

    function GetMac()
    {
    var clientIP="192.168.0.1";
    //document.getElementById("Mac").value
    =DemoMethods.GetCustomerMac(clientIP).value
    alert(DemoMethods.GetCustomerMac
    (clientIP).value);
    }
     

      5.在某个Aspx页面放上一个html 的button在页面上中引用default.js :

    lt;
    script language=""
    src="default.js">

     

      在INPUT的onclick事件中加上

    onclick="javascript:GetMac()"
    lt;
    INPUT style="Z-INDEX: 101;
    LEFT: 392px; POSITION: absolute;
    TOP: 176px" type="button"
     
      value="客户端获取IP" onclick="javascript:GetMac();">
      6.在page页面的Page_Load事件中加上
    private void Page_Load
    (object sender, System.EventArgs e)
    {
    // 在此处放置用户代码以初始化页面
    Ajax.Utility.RegisterTypeForAjax
    (typeof(AjaxSample.DemoMethods));
    }
     

      注意:typeof(AjaxSample.DemoMethods)中,AjaxSample是命名空间,DemoMethods是要包含要调用方法的类,即上面第3步.新建类DemoMethods
    7.修改Global.asax的Application_Start事件,设置Ajax的HandlerPath :

    protected void Application_Start
    (Object sender, EventArgs e)
    {
    Ajax.Utility.HandlerPath = "ajax";
    }
     
     
      运行看看效果。是不是没有刷新就在服务器端取到客户端的MAC地址?
      需要注意的是:该版本的.net Ajax需要手工在中Global.asax加上Ajax.Utility.HandlerPath = "ajax"; 配置文件web.config必须加上HttpHandler的配置信息!
      该开发包的新版本还没有来得及体验,估计新版本中会方便一些,可能会去掉手动的设置Global.asax的Application_Start事件中加上Ajax.Utility.HandlerPath = "ajax";以及其他麻烦的设置!

    以上为全部内容。如果你想了解更多相关信息,可前往课课家官方网查看相关

课课家教育

未登录