AJAx 具体案例。

1.在项目中添加此dll的应用,同时需要在 webconfig的 <system.web> 里面 加上

<httpHandlers>
  <add verb="POST,GET" path="ajax/*.ashx" type="Ajax.PageHandlerFactory,Ajax"></add>
</httpHandlers>

2.在应用页面的Page_Load中添加
Ajax.Utility.RegisterTypeForAjax(typeof(页面名));

3.在要调用的后台方法前加ajax的声明

①操作session时
  [Ajax.AjaxMethod(Ajax.HttpSessionStateRequirement.Read)]
  public void GetBranchSelectIndex(int selectIndex)
  {
  Session["BranchSelIndex"] =selectIndex;
  }

②其他操作的时候
  [Ajax.AjaxMethod()]
  public DataTable DependLineGetBranch(string strLineCD)
  {
  clsMainDB mdbBranch = new clsMainDB();
  dtBranchInfo = mdbBranch.GetBreadBranchInfo(strLineCD);
  int i=dtBranchInfo.Rows.Count;
  return dtBranchInfo;
  }

4.在前台的js中写function中调用此方法
 var abc=页面名.方法名(参数).value;//有返回值
页面名.方法名(参数);//没有返回值


③注意点
(1).不可以读取 cookie的值,但是可读session的值 不能使用Request去参数值,不能使用控件名字
(2)方法中不能出现后台的控件,比如 this.xxxx 会提示[未定义]
(3)不能调用重载方法,如果重载方法将调用失败。

案例代码如下

前台代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="AjaxExample.aspx.cs" Inherits="AjaxExample" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>无标题页</title>
    <script>
    function AClick()
    {
         alert('The AjaxMethod start ');
         var msg= AjaxExample.WriteText().value;
         alert(msg);
         alert('The AjaxMethod end ');
    }
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    <a href="javascript: AClick();">请点击这里</a>
    <asp:Literal ID="ltrTree" runat="server"></asp:Literal>
    </div>
        <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
    </form>
</body>
</html>

后台代码:
using System;
using System.Data;
using System.Configuration;
using System.Collections;
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;
public partial class AjaxExample : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        Ajax.Utility.RegisterTypeForAjax(typeof(AjaxExample),Page);
    }
    [Ajax.AjaxMethod()]
    public string WriteText()
    {
        //ChangeLabel();
        //Response.Write("ok");
        //return Request["str"];
        //Page.RegisterStartupScript("", "<script>alert('2');</script>");
        return "后台方法成功调用!";
    }
    public void ChangeLabel()
    {
        Label1.Text = "abcdef";
    }
}



经典案例,带数据库脚本、Java源文件和页面源文件。有演示效果,也可以自己部署看效果。以下是案例的目录。 1-1.EXE 动态加载的FAQ实例演示 1-2.EXE 根据邮政编码获取地区信息实例演示 1-3.EXE 动态树形列表实例演示 1-4.EXE 多级联动菜单实例演示 1-5.EXE 条件设置向导实例演示 1-6.EXE 页面关键词提示实例演示 2-1.EXE 无刷新显示回帖实例演示 2-2.EXE 输入内容前提示实例演示 2-3.EXE 带进度的文件上传实例演示 2-4.EXE 大量数据动态浏览查询实例演示 2-5.EXE 信息排序实例演示 2-6.EXE 切换标签页实例演示 3-1.EXE 注册表单验证实例演示 3-2.EXE 购物车实例演示 3-3.EXE 产品快速检索实例演示 3-4.EXE 系列产品特性速查实例演示 3-5.EXE 邮件订阅实例演示 3-6.EXE 产品评级实例演示 4-1.EXE 简单计算器实例演示 4-2.EXE 文章拼写检查实例演示 4-3.EXE 拼词游戏实例演示 4-4.EXE 在线词典实例演示 4-5.EXE 远程网页源代码读取实例演示 5-1.EXE 相册浏览实例演示 5-2.EXE 幻灯片实例演示 5-3.EXE 灯箱效果实例演示 5-4.EXE 聊天室实例演示 6-1.EXE 自动登录实例演示 6-2.EXE 自动保存草稿实例演示 6-3.EXE 实时更新的股价实例演示 6-4.EXE 提前加载分页文章实例演示 7-1.EXE 获取服务器当前时间实例演示 7-2.EXE 远程PING服务器实例演示 7-3.EXE 服务器监测系统实例演示 7-4.EXE 使用滑动栏设置参数实例演示 8-1.EXE RSS阅读器实例演示 8-2.EXE 天气情况查询实例演示 8-3.EXE 访问搜索服务实例演示 8-4.EXE 读取Amazon产品目录实例演示 9-1.EXE 名片册实例演示 9-2.EXE 自定义个人门户实例演示 9-3.EXE 个人任务管理实例演示 9-4.EXE 许愿墙实例演示 9-5.EXE 日程表实例演示 9-6.EXE 考试系统实例演示
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值