前台界面:

        

后台代码:

namespace _04省市联动
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

private int r = 0;
        private void Form1_Load(object sender, EventArgs e)
        {
            r = 1;
            //所有省份显示到第一个下拉框中
            LoadAreaByAreaPId(0);
        }

private void LoadAreaByAreaPId(int v)
        {

List<Area> list=new List<Area>();
            list.Add(new Area() {AreaId = -1,AreaName = "---请选择---"});
            string sql = "select AreaId,AreaName from TblArea  where AreaPId="+v;
            using (SqlDataReader reader=SqlHelper.ExecuteDataReader(sql))
            {
                if (reader.HasRows)
                {
                    while (reader.Read())
                    {
                        Area a=new Area();
                        a.AreaId = Convert.ToInt32(reader["AreaId"]);
                        a.AreaName = reader["AreaName"].ToString();
                        list.Add(a);
                    }
                }
            }
            if (r==1)
            {
                cbPro.DataSource = list;
                cbPro.DisplayMember = "AreaName";
                cbPro.ValueMember = "AreaId";
            }
            if(r==2)
            {
                cbCity.DataSource = list;
                cbCity.DisplayMember = "AreaName";
            }

}

private void cbPro_SelectedIndexChanged(object sender, EventArgs e)
        {

#region 练习用的代码
            //if (cbPro.SelectedIndex != 0)
            //{
            //    cbCity.Items.Clear();
            //    //获取当前省份的id
            //    int id = Convert.ToInt32(cbPro.SelectedValue);
            //    string sql = "select AreaId,AreaName from TblArea where AreaPId=" + id;
            //    //List<Area> list = new List<Area>();
            //    using (SqlDataReader reader = SqlHelper.ExecuteDataReader(sql))
            //    {
            //        if (reader.HasRows)
            //        {
            //            while (reader.Read())
            //            {
            //                Area a = new Area();
            //                a.AreaId = Convert.ToInt32(reader["AreaId"]);
            //                a.AreaName = reader["AreaName"].ToString();
            //                cbCity.Items.Add(a);  //重写了Area类的ToString()方法   public override string ToString()
                                                                 //否则添加的是类的命名空间          {
                                                                                                                               return this.AreaName;
                                                                                                                        }
            //            }
            //        }
            //    }

//} 
            #endregion

#region 简化写法,使用r变量判断事件
            r = 2;
            if (cbPro.SelectedIndex != 0)
            {
                int id = Convert.ToInt32(cbPro.SelectedValue);
                LoadAreaByAreaPId(id);
            } 
            #endregion

}
    }
}

Ado.Net小练习03(省市联动)的更多相关文章

  1. 微信小程序省市联动

    最近呢刚好做了一个省市联动的功能,今天看到有人问这个怎么做,我就把我做的放上来共享一下: 首先呢,来看看效果,点击文字'点击',弹出选择窗口,点击取消或者确定(取消.确定按钮在选择框上边,截图有些不清 ...

  2. html + ashx 实现Ajax省市联动

    基本思路:1.了解数据库中省和市的表结构及关联主键 2.创建html页面及select标签 3.通过ajax向ashx(一般处理程序)发送后台请求完成联动效果 表结构: 这里,开始创建一个命为demo ...

  3. html css javascript 知识点总结 bom js 操作标签 文本 节点 表格各行变色 悬停变色 省市联动 正则

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  4. jquery省市联动,根据公司需求而写

    //author:guan //2015-05-25 //省市联动 //实用说明,页面引用如下js //<script src="../js/jquery-1.6.3.min.js&q ...

  5. Json 基于jQuery+JSON的省市联动效果

    helloweba.com 作者:月光光 时间:2012-09-12 21:57 标签: jQuery  JSON  Ajax  省市联动     省市区联动下拉效果在WEB中应用非常广泛,尤其在一些 ...

  6. AJAX案例四:省市联动

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

  7. Dynamic CRM 2013学习笔记(八)过滤查找控件 (类似省市联动)

    我们经常要实现类似省市联动一样的功能,常见的就是二个查找控件,一个选择了省后,另一个市的查找控件就自动过滤了,只显示当前省下的市,而不是所有的市.当然这是最简单的,实际工作中还有更复杂的功能要通过过滤 ...

  8. [JS]以下是JS省市联动菜单代码

    以下是JS省市联动菜单代码: 代码一: <html> <head> <title></title> <script language=" ...

  9. 通过Javascript数组设计一个省市联动菜单

    通过Javascript数组设计一个省市联动菜单 使用Option内置类来完成下拉选项的创建 2.使用定时器实现一个时钟程序 3.使用PHP+JSON完成语音验证码 网址:http://yuyin.b ...

随机推荐

  1. ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    测试库一条update语句报错:ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction mysql> ...

  2. ARP

    视频教程 http://baidu.ku6.com/watch/08644463979695746698.html?page=videoMultiNeed arp代理  跨越路由 免费arp  检查i ...

  3. iOS多线程GCD 研究

    Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main queue,通过dispat ...

  4. 查看MYSQL数据库中所有用户及拥有权限

    查看MYSQL数据库中所有用户 mysql> SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM m ...

  5. CustomEditor 自定义预览窗

    using UnityEngine; using System.Collections; public class MyTextureView : MonoBehaviour { public Tex ...

  6. SqlBulkCopy批量写入25万条数据只需3s

    Microsoft SQL Server 提供一个称为 bcp 的流行的命令提示符实用工具,用于将数据从一个表移动到另一个表(表既可以在同一个服务器上,也可以在不同服务器上).SqlBulkCopy  ...

  7. notifyDataSetChanged listview内容没更新的问题

    如红色部分所示,需在Adapter添加setData方法,当 listData中数据更改后,调用setData,为Adapter设置新的数据,此时调用notifyDataSetChanged() 就可 ...

  8. C# 越来越复杂了

    自从三年前来到现在的公司以后,基本上不怎么使用.NET进行开发了.但最近因为公司有个CRM的项目,所以只有重新检起.NET进行开发. 因为近3年没有搞.NET的开发了,因此也不敢乱整个框架,在看了一周 ...

  9. The service ‘xxx’ configured for WCF is not registered with the Autofac container

    最近在使用autofac.wcf时,报如下异常: Exception Details: System.InvalidOperationException: The service 'xxx' conf ...

  10. [设计模式] 7 桥接模式 bridge

    #include<iostream> using namespace std; class AbstractionImp { public: virtual ~AbstractionImp ...