亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

輕松實現無刷新三級聯動菜單[VS2005與AjaxPro]

2019-11-18 16:30:28
字體:
來源:轉載
供稿:網友

最近做一些網站程序,經常要用到多個下拉菜單選擇,看了介紹開始用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>
    /// 數據庫連接 http://www.49028c.com
    /// </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" "

<html xmlns="<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>AjaxPro實現無刷新三級聯動</title>
</head>
<scr
ipt 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>
相關文件
http://www.49028c.com/Files/asboy/AjaxDropDownlist.rar
代碼文件于2005-5-13更新過 列出了取值的方法


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲综合av影视| 91夜夜未满十八勿入爽爽影院| 欧美日本啪啪无遮挡网站| 精品一区二区三区电影| 国产日产久久高清欧美一区| 国产区精品在线观看| 国产最新精品视频| 精品色蜜蜜精品视频在线观看| 国产精品草莓在线免费观看| 成人综合国产精品| 日本精品视频在线观看| zzjj国产精品一区二区| 在线看国产精品| 日韩电影免费在线观看中文字幕| 日韩欧美在线免费观看| 国产综合福利在线| 庆余年2免费日韩剧观看大牛| 欧美巨乳美女视频| 色婷婷成人综合| 亚洲国产精品久久久久久| 亚洲高清一区二| 久久久久久久久久久91| 欧美成人手机在线| 国产区精品视频| 欧美成人免费一级人片100| 欧美性猛交xxxxx水多| 日韩视频免费在线| 国产精品爱啪在线线免费观看| 日韩在线观看av| 国产精品丝袜一区二区三区| 77777少妇光屁股久久一区| 日本高清+成人网在线观看| 国产视频久久久| 日韩经典中文字幕在线观看| 国产精品三级在线| 精品国产一区二区三区久久狼黑人| 性欧美长视频免费观看不卡| 久久久久久久电影一区| 在线午夜精品自拍| 亚洲欧美资源在线| 亚洲va欧美va国产综合剧情| 久久久亚洲欧洲日产国码aⅴ| 欧美电影《睫毛膏》| 狠狠色香婷婷久久亚洲精品| 久久精品视频亚洲| 精品国产一区二区三区久久久狼| 成人在线激情视频| 亚洲成人av中文字幕| 亚洲国产成人久久| 成人午夜在线观看| 国产成人综合一区二区三区| 97免费中文视频在线观看| 欧美情侣性视频| 国产日韩欧美在线看| 国产性色av一区二区| 国产精品无码专区在线观看| 国产区亚洲区欧美区| 久久精品久久精品亚洲人| 中文字幕亚洲一区在线观看| 欧洲成人午夜免费大片| 国产精品777| 亚洲精品一区av在线播放| 国产欧美精品日韩精品| 日日狠狠久久偷偷四色综合免费| 成人免费网站在线看| 亚洲精品国精品久久99热一| 欧美在线xxx| 欧美在线播放视频| 狠狠色狠狠色综合日日五| 日韩激情视频在线| 久久91精品国产91久久跳| 久久久久久久网站| 国产ts一区二区| 久久久久久久久久国产| 亚洲女同精品视频| 人人爽久久涩噜噜噜网站| 欧美日韩人人澡狠狠躁视频| 日韩有码在线播放| 欧美日韩国产精品一区二区不卡中文| 中文字幕日本欧美| 91av网站在线播放| 欧美另类极品videosbestfree| 精品国产一区二区三区久久| 日本最新高清不卡中文字幕| 96pao国产成视频永久免费| 国产精品女主播视频| 欧美午夜精品久久久久久人妖| 久久91精品国产91久久久| 97色在线视频观看| 欧美最猛黑人xxxx黑人猛叫黄| 日本欧美中文字幕| 91精品国产自产在线观看永久| 亚洲精品电影在线| 日韩高清a**址| 国产精品成人播放| 国产精品69久久| 亚洲大胆人体视频| 午夜精品免费视频| 欧美日韩xxx| 韩国日本不卡在线| 欧美麻豆久久久久久中文| 欧美日韩不卡合集视频| 在线电影中文日韩| 91中文字幕在线| 欧美精品成人在线| 欧美性在线观看| 成人av色在线观看| 日韩日本欧美亚洲| 555www成人网| 欧美激情视频在线免费观看 欧美视频免费一| 久久久久久久色| 欧美一性一乱一交一视频| 成人黄色短视频在线观看| 亚洲黄一区二区| 色综合久久久久久中文网| 亚洲va码欧洲m码| 中文字幕日韩在线视频| 7777精品久久久久久| 激情成人在线视频| 亚洲精品电影网| 日韩美女免费视频| 中文字幕亚洲一区| 国产日本欧美一区二区三区| 欧美大片免费观看| 亚洲电影第1页| 人妖精品videosex性欧美| 欧美理论片在线观看| 成人中文字幕+乱码+中文字幕| 日韩久久午夜影院| 高清欧美性猛交xxxx| 久久国产精品久久国产精品| 国产一区二区三区在线观看网站| 日韩欧中文字幕| 国内精品中文字幕| 欧洲成人性视频| 国产精品96久久久久久又黄又硬| 亚洲色图第三页| 欧美影院成年免费版| 亚洲国产美女久久久久| 91精品国产亚洲| 在线看欧美日韩| 国产69久久精品成人| 亚洲一区二区在线| 国产精品一区二区女厕厕| 日韩欧美中文字幕在线观看| 亚洲精品国产精品自产a区红杏吧| 亚洲精品电影久久久| 亚洲精品视频播放| 在线视频欧美性高潮| 这里只有精品丝袜| 懂色av一区二区三区| 国产精品一区=区| 亚洲精品中文字| 欧美成人激情图片网| 亚洲精品99久久久久| 日韩经典一区二区三区| 丰满岳妇乱一区二区三区| 国产精品欧美日韩| 国产va免费精品高清在线| 最近2019中文字幕在线高清| 欧美电影免费观看电视剧大全| 国产成人精品一区二区三区| 国产91|九色| 久青草国产97香蕉在线视频|