zoukankan      html  css  js  c++  java
  • 最近学习Ajax 摘抄记录

     

    Ajax.Net快速入门

    http://www.51cto.com 2006-01-10 09:21 作者:四年 出处:www.cfcxy.net

     

    【导读】本文介绍Ajax.net的使用方法

     

    现在的项目准备用ajax,用ajax.net实现,而不是atlas,所以先看下ajax.netAjax.Net现在的最新版本是AjaxPro5.11.4.2,下载地址是:www.schwarz-interactive.de

    首先我们新建个项目,名字是AjaxPro,我用的是vs2005beta2版本。

    右击站点名字点add reference添加对我们刚刚下载来的那个叫AjaxPro.2.dll的引用,如果你用的是vs2003,则添加对AjaxPro.dll的引用,然后我们在添加个web.config文件(很郁闷的是vs2005不再自动添加web.config文件拉),修改web.config如下:

    <system.web>

    <httpHandlers>

    <add verb="POST,GET" path="ajaxpro/*.ashx" type="AjaxPro.AjaxHandlerFactory, AjaxPro.2"/>

    </httpHandlers>

    意思是所有的ajaxpro/*.ashx请求都由Ajax.PageHandlerFactory处理,而不是由默认的System.Web.UI.PageHandlerFactory处理程序工厂来处理。

    我们现在给Default.aspx.cs文件添加个名字空间namespace MyDemo,这里更加郁闷的是为什么vs2005beta2怎么不给你自动添加名字空间啊?和2003怎么完全不同呢?

    现在我们写个AjaxMethod服务器端方法,他和普通的服务器方法唯一不同的地方就是他必须要在方法的上面添加个[AjaxPro.AjaxMethod],代码如下:

    [AjaxPro.AjaxMethod]

    public DateTime GetServerTime()

    {

    return DateTime.Now;

    }

    [AjaxPro.AjaxMethod]

    public int AddTwo(int firstInt, int secondInt)

    {

    return firstInt + secondInt;

    }

    我们还必须在Page_Load里面把这个类注册下,如下:

    protected void Page_Load(object sender, EventArgs e)

    {

    AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));

    }

     

    这个时候我们还必须修改aspx页面的<%@Page指令行,因为我们在后台搞了个名字空间,如下:Inherits="MyDemo._Default"也就是要把名字空间也写上。我们再写客户端脚本来调用服务器方法。代码里有详细的注释,前台Default.aspx代码:

    <%@ Page Language="C#" AutoEventWireup="true"

    CodeFile="Default.aspx.cs" Inherits="MyDemo._Default" %>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"

    "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

     

    <html xmlns="http://www.w3.org/1999/xhtml" >

    <head runat="server">

    <title>Untitled Page</title>

    </head>

    <body>

    <form id="form1" runat="server">

    <div>

    <input id="Button1" type="button" value="
    获得服务器时间"

    onclick="getServerTime();" />

    <input id="Text1" type="text" />

    <input id="Text2" type="text" />

    <input id="Button2" type="button" value="
    得到两个文本框的和

    " onclick="add(document.getElementById('Text1').value,

    document.getElementById('Text2').value)" />

    </div></form>

    <script type="text/javascript">

    function getServerTime()

    {

    //MyDemo._Default.GetServerTime()
    得到从服务器传来的数据是object,要写.value

    alert(MyDemo._Default.GetServerTime().value);

    }

    function add(a,b)

    {

    //
    把文本框的值转换成int

    var a1 = parseInt(a);

    var b1 = parseInt(b);

    //
    12参数为服务器方法所需要的参数,后面一个是如果服务器返回数据

    //
    客户端要处理这些数据的js函数名,他有个参数就是从服务器传来的数据

    MyDemo._Default.AddTwo(a1,b1,getAdd);

    }

    function getAdd(rel)

    {

    //
    要加上.value

    alert(rel.value);

    }

    </script>

    </body>

    </html>

    后台Default.aspx.cs代码:

     

    using System;

    using System.Data;

    using System.Configuration;

    using System.Web;

    using System.Web.Security;

    using System.Web.UI;

    using System.Web.UI.WebControls;

    using System.Web.UI.WebControls.WebParts;

    using System.Web.UI.HtmlControls;

    namespace MyDemo

    {

    public partial class _Default : System.Web.UI.Page

    {

    protected void Page_Load(object sender, EventArgs e)

    {

    AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));

    }

     

    [AjaxPro.AjaxMethod]

    public DateTime GetServerTime()

    {

    return DateTime.Now;

    }

    [AjaxPro.AjaxMethod]

    public int AddTwo(int firstInt, int secondInt)

    {

    return firstInt + secondInt;

    }

    }

    }

    F5运行结果如下,firefox里面测试通过:

    using System;

    using System.Data;

    using System.Configuration;

    using System.Web;

    using System.Web.Security;

    using System.Web.UI;

    using System.Web.UI.WebControls;

    using System.Web.UI.WebControls.WebParts;

    using System.Web.UI.HtmlControls;

    namespace MyDemo

    {

    public partial class _Default : System.Web.UI.Page

    {

    protected void Page_Load(object sender, EventArgs e)

    {

    AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));

    }

     

    [AjaxPro.AjaxMethod]

    public DateTime GetServerTime()

    {

    return DateTime.Now;

    }

    [AjaxPro.AjaxMethod]

    public int AddTwo(int firstInt, int secondInt)

    {

    return firstInt + secondInt;

    }

    }

    }

  • 相关阅读:
    透明的LISTVIEW
    循序渐进实现仿QQ界面(三):界面调色与控件自绘
    循序渐进实现仿QQ界面(一):园角矩形与双缓冲贴图窗口
    循序渐进实现仿QQ界面(二):贴图按钮的三态模拟
    C#中如何通过点击按钮切换窗口
    jQuery -- 光阴似箭(二):jQuery效果的使用
    jQuery -- 光阴似箭(一):初见 jQuery -- 基本用法,语法,选择器
    JavaScript -- 时光流逝(十三):DOM -- Console 对象
    JavaScript -- 时光流逝(十二):DOM -- Element 对象
    JavaScript -- 时光流逝(十一):DOM -- Document 对象
  • 原文地址:https://www.cnblogs.com/zhuangge/p/447468.html
Copyright © 2011-2022 走看看