网站首页 > 网络编程教程 > Ajax教程 > 轻松实现无刷新三级联动菜单[VS2005与AjaxPro]

轻松实现无刷新三级联动菜单[VS2005与AjaxPro]

  • 作者:互联网
  • 时间:2009-07-06 16:38:54

最近做一些网站程序,经常要用到多个下拉菜单选择,看了介绍开始用AjaxPro这个控件,感觉效果不错。以前使用过MagicAjax,很久不用了忘记了,最麻烦的就是在虚拟目录的时候比较麻烦,呵呵,在网上也有很多,不过重要的地方经常没提醒新手,俺也是,高手请忽略。看到这个AjaxPro使用比较简单,这次使用的是6.x的,最新的是7.x的,觉得6.0系列的方便,就选它了。
在重要的地方都有提示了,相信很容易看懂。
      首先在we***onfig添加这个接点 在<sy***m.web>与sy***m.web>之间,如下:
   <sy***m.web>
   
   
      aj***ro/*.ashx" type="Aj***ro.AjaxHandlerFactory, Aj***ro.2"/>
   

    
   sy***m.web>
     然后把Aj***ro.2.dll丢到bin文件夹,然后引用它就可以了。
    还是发代码吧,麻烦死了下面代码是 De***lt.aspx.cs


using System;
using Sy***m.Data;
using Sy***m.Configuration;
using Sy***m.Data.OleDb;
using Sy***m.Web;
using Sy***m.Web.UI;
using Sy***m.Web.UI.WebControls;
using Sy***m.Web.UI.WebControls.WebParts;
using Sy***m.Web.UI.HtmlControls;

public partial class _Default : Sy***m.Web.UI.Page
{  
   
    protected void Page_Load(object sender, EventArgs e)
    {
        Aj***ro.Utility.RegisterTypeForAjax(typeof(_Default)); //必要的
        if(!IsPostBack)BindDc();
    }

    /**////


    /// 数据库连接 http://www.downcodes.com
    ///

    ///
    public OleDbConnection myConn()
    {
        string ConnStr = "Pr***der=Microsoft.Jet.OLEDB.4.0;Data Source=" + Sy***m.Web.HttpContext.Current.Server.MapPath(Co***gurationManager.AppSettings["dbpath"]);
        OleDbConnection conn = new OleDbConnection(ConnStr);
        try
        {
            co***Open();
            return conn;
        }
        catch
        {
            throw;
        }
    }
   
    /**////
    /// 获取下级分类
    ///

    [Aj***ro.AjaxMethod]
    public DataSet getNextClass(string cid)
    {
        //因为不希望页面可以知道字段名称 所以 as txt,id as vol 如果是sql ser 可以用 =
        //页面获取的 列名称 必须跟这个一同样 而且区分大小写 一般都是这个地方容易疏忽了
        //所以二级分类没变化
        string sql = @"select cname as txt,id as vol from webclass where parentid=" + cid;
        try
        {
            return getDs(sql);
        }
        catch
        {
            //throw;
            return null;
        }
    }
   

    /**////


    /// 返回一个DataSet
    ///

    ///
    ///
    public DataSet getDs(string SQL)
    {
        OleDbConnection conn = myConn();
        DataSet Ds = new DataSet();
        OleDbDataAdapter Da = new OleDbDataAdapter(SQL, conn);
        try
        {  
            Da.Fill(Ds);
            return Ds;
        }
        catch
        {
            return null;
            //throw;
        }

    }
    /**////


    /// //数据绑定
    ///

    private void BindDc()
    {
        //第一个
        string sql = @"select * from webclass where Parentid=0";
        dd***DataSource = getDs(sql);
        dd***DataTextField = "cname";
        dd***DataValueField = "id";
        dd***DataBind();
        if (dd***DataSource != null) dd***Attributes.Add("onchange", "showNext(th***options[selectedIndex].value,'ddl2');");

      
        //可以先判断 Dr***ownList.SelectedItem.Value
        //第二个
        sql = @"select * from webclass where parentid=" + dd***SelectedItem.Value;
        dd***DataSource = getDs(sql);
        dd***DataTextField = "cname";
        dd***DataValueField = "id";
        dd***DataBind();
       
        //第三个
        if (dd***DataSource != null) dd***Attributes.Add("onchange", "showNext(th***options[selectedIndex].value,'ddl3');");
        sql = @"select * from webclass where parentid=" + dd***SelectedItem.Value;
        dd***DataSource = getDs(sql);
        dd***DataTextField = "cname";
        dd***DataValueField = "id";
        dd***DataBind();
   
    }
}

de***lt.aspx内容:


<%@ Page Language="C#" AutoEventWireup="true" CodeFile="De***lt.aspx.cs" Inherits="_Default" %>

http://ww***.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">http://ww***.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

http://ww***.org/1999/xhtml">http://ww***.org/1999/xhtml" >

   
    AjaxPro实现无刷新三级联动



   


   

     
       
         
         
       
       
         
         
       
       
         
         
       
     
 
              城市
             

              区域
             

              花园
             
  
  

   
   

   



相关文件

上一篇: ajax的server部分(php版)

下一篇: ASP.NET AJAX 客户端生命周期事件