zoukankan      html  css  js  c++  java
  • 轻松实现无刷新三级联动菜单[VS2005与AjaxPro]【转】

    最近做一些网站程序,经常要用到多个下拉菜单选择,看了介绍开始用AjaxPro这个控件,感觉效果不错。以前使用过MagicAjax,很久不用了忘记了,最麻烦的就是在虚拟目录的时候比较麻烦,呵呵,在网上也有很多,不过重要的地方经常没提醒新手,俺也是菜鸟,高手请忽略。看到这个AjaxPro使用比较简单,这次使用的是6.x的,最新的是7.x的,觉得6.0系列的方便,就选它了。
    在重要的地方都有提示了,相信很容易看懂。
          首先在web.config添加这个接点 在<system.web>与</system.web>之间,如下:
       <system.web>
        <!--for Ajaxnet-->
        <httpHandlers>
          <add verb="POST,GET" path="ajaxpro/*.ashx" type="AjaxPro.AjaxHandlerFactory, AjaxPro.2"/>
        </httpHandlers>
         <!--其他设置-->
       </system.web>
         然后把AjaxPro.2.dll丢到bin文件夹,然后引用它就可以了。
        还是发代码吧,麻烦死了下面代码是 Default.aspx.cs的


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

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

        /**//// <summary>
        /// 数据库连接
        /// </summary>
        /// <returns></returns>
        public OleDbConnection myConn()
        {
            string ConnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["dbpath"]);
            OleDbConnection conn = new OleDbConnection(ConnStr);
            try
            {
                conn.Open();
                return conn;
            }
            catch
            {
                throw;
            }
        }
       
        /**//// <summary>
        /// 获取下级分类
        /// </summary>
        [AjaxPro.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;
            }
        }
       

        /**//// <summary>
        /// 返回一个DataSet
        /// </summary>
        /// <param name="SQL"></param>
        /// <returns></returns>
        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;
            }

        }
        /**//// <summary>
        /// //数据绑定
        /// </summary>
        private void BindDc()
        {
            //第一个
            string sql = @"select * from webclass where Parentid=0";
            ddl1.DataSource = getDs(sql);
            ddl1.DataTextField = "cname";
            ddl1.DataValueField = "id";
            ddl1.DataBind();
            if (ddl1.DataSource != null) ddl1.Attributes.Add("onchange", "showNext(this.options[selectedIndex].value,'ddl2');");

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

    default.aspx内容:


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

    <!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">
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
        <title>AjaxPro实现无刷新三级联动</title>
    </head>
    <script language="javascript" type="text/javascript">
          <!--
           // ACLOUD 常用JS函数
           function getBid(s){
              return document.getElementById(s);
            }
            function getBmc(s){
              return document.getElementByName(s);
            }
           
           //显示分类列表
           function showNext(sid,obj)
            {
              if(sid==null || sid=="" || sid.length<1)return;
              var slt =getBid(obj);
              var v = _Default.getNextClass(sid).value; // 类的名称
              //alert(v);
              //return;
              if (v != null){     
              if(v != null && typeof(v) == "object" && v.Tables != null)
                        {       
                            slt.length = 0;
                            slt.options.add(new Option("请选择",0));
                            //加了个“请选择”主要为了触发onchange事件
                            if(obj=="ddl2"){
                            getBid("ddl3").options.length=0;
                            getBid("ddl3").options.add(new Option("请选择",0));
                            }           
                            for(var i=0; i<v.Tables[0].Rows.length; i++)
                        {
                            var txt = v.Tables[0].Rows[i].txt; //这个地方需要注意区分大小写
                          var vol = v.Tables[0].Rows[i].vol; //跟dataset表的列名称要一致
                          slt.options.add(new Option(txt,vol));
                        }
                        }
               }   
               return;
            }
            -->
    </script>
    <body>
        <form id="form1" runat="server">
        <div>
          <table width="500" border="0" align="center" cellpadding="0" cellspacing="0">
            <tr>
              <td width="99">&nbsp;</td>
              <td width="401">
                  城市<asp:DropDownList ID="ddl1" runat="server">
                  </asp:DropDownList>
                  区域<asp:DropDownList ID="ddl2" runat="server">
                  </asp:DropDownList>
                  花园<asp:DropDownList ID="ddl3" runat="server">
                  </asp:DropDownList></td>
            </tr>
            <tr>
              <td>&nbsp;</td>
              <td>&nbsp;</td>
            </tr>
            <tr>
              <td>&nbsp;</td>
              <td>&nbsp;</td>
            </tr>
          </table>
       
        </div>
        </form>
    </body>
    </html>
    相关文件
    https://files.cnblogs.com/asboy/AjaxDropDownlist.rar
    代码文件于2005-5-13更新过 列出了取值的方法

  • 相关阅读:
    Linux 文件权限
    spak数据倾斜解决方案
    逻辑时钟
    kafka入门
    深入学习MySQL事务:ACID特性的实现原理
    程序员的诗
    java技术突破要点
    一个请求过来都经历了什么
    如何保持长时间高效学习
    你的系统如何支撑高并发
  • 原文地址:https://www.cnblogs.com/Godblessyou/p/1779157.html
Copyright © 2011-2022 走看看