国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

輕松實(shí)現(xiàn)無(wú)刷新三級(jí)聯(lián)動(dòng)菜單[VS2005與AjaxPro]

2019-11-18 16:30:28
字體:
供稿:網(wǎng)友

最近做一些網(wǎng)站程序,經(jīng)常要用到多個(gè)下拉菜單選擇,看了介紹開始用AjaxPRo這個(gè)控件,感覺效果不錯(cuò)。以前使用過MagicAjax,很久不用了忘記了,最麻煩的就是在虛擬目錄的時(shí)候比較麻煩,呵呵,在網(wǎng)上也有很多,不過重要的地方經(jīng)常沒提醒新手,俺也是菜鳥,高手請(qǐng)忽略。看到這個(gè)AjaxPro使用比較簡(jiǎn)單,這次使用的是6.x的,最新的是7.x的,覺得6.0系列的方便,就選它了。
在重要的地方都有提示了,相信很容易看懂。
      首先在web.config添加這個(gè)接點(diǎn) 在<system.web>與</system.web>之間,如下:
   <system.web>
    <!--for Ajaxnet-->
    <httpHandlers>
      <add verb="POST,GET" path="ajaxpro/*.ashx" type="AjaxPro.AjaxHandlerFactory, AjaxPro.2"/>
    </httpHandlers>
     <!--其他設(shè)置-->
   </system.web>
     然后把AjaxPro.2.dll丟到bin文件夾,然后引用它就可以了。
    還是發(fā)代碼吧,麻煩死了下面代碼是 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>
    /// 數(shù)據(jù)庫(kù)連接 http://www.survivalescaperooms.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>
    /// 獲取下級(jí)分類
    /// </summary>
    [AjaxPro.AjaxMethod]
    public DataSet getNextClass(string cid)
    {
        //因?yàn)椴幌M?yè)面可以知道字段名稱 所以 as txt,id as vol 如果是sql ser 可以用 =
        //頁(yè)面獲取的 列名稱 必須跟這個(gè)一同樣 而且區(qū)分大小寫 一般都是這個(gè)地方容易疏忽了
        //所以二級(jí)分類沒變化
        string sql = @"select cname as txt,id as vol from webclass where parentid=" + cid;
        try
        {
            return getDs(sql);
        }
        catch
        {
            //throw;
            return null;
        }
    }
   

    /**//// <summary>
    /// 返回一個(gè)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>
    /// //數(shù)據(jù)綁定
    /// </summary>
    private void BindDc()
    {
        //第一個(gè)
        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
        //第二個(gè)
        sql = @"select * from webclass where parentid=" + ddl1.SelectedItem.Value;
        ddl2.DataSource = getDs(sql);
        ddl2.DataTextField = "cname";
        ddl2.DataValueField = "id";
        ddl2.DataBind();
       
        //第三個(gè)
        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內(nèi)容:


<%@ 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實(shí)現(xiàn)無(wú)刷新三級(jí)聯(lián)動(dòng)</title>
</head>
<scr
ipt language="javascript" type="text/Javascript">
      <!--
       // ACLOUD 常用JS函數(shù)
       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("請(qǐng)選擇",0));
                        //加了個(gè)“請(qǐng)選擇”主要為了觸發(fā)onchange事件
                        if(obj=="ddl2"){
                        getBid("ddl3").options.length=0;
                        getBid("ddl3").options.add(new Option("請(qǐng)選擇",0));
                        }           
                        for(var i=0; i<v.Tables[0].Rows.length; i++)
                    {
                        var txt = v.Tables[0].Rows[i].txt; //這個(gè)地方需要注意區(qū)分大小寫
                      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>
              區(qū)域<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>
相關(guān)文件
http://www.survivalescaperooms.com/Files/asboy/AjaxDropDownlist.rar
代碼文件于2005-5-13更新過 列出了取值的方法


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 叙永县| 肇州县| 翁源县| 宁陵县| 靖宇县| 维西| 张家川| 延川县| 顺昌县| 琼结县| 灌云县| 蒲江县| 慈利县| 微博| 包头市| 友谊县| 卢湾区| 文水县| 和田县| 佳木斯市| 鄂伦春自治旗| 昭觉县| 广南县| 秭归县| 土默特左旗| 高密市| 抚顺市| 邓州市| 满洲里市| 和平县| 达州市| 石家庄市| 扶风县| 峨边| 朔州市| 高邑县| 隆子县| 东宁县| 安陆市| 乳源| 德安县|