實現兩級下拉框的聯動

1.實現兩級下拉框的聯動。

? 功能:實現點擊年級下拉框,加載對應科目的下拉框。

第一步:首先要加載年級下拉框中的數據。

01.在GradeDAL層(數據訪問層)寫一個方法,查詢所有年級的信息。

/// <summary>/// 從數據庫中獲取年級信息/// </summary>/// <returns>List的集合:年級編號,年級名稱</returns>public List<Grade> SelectGradeInfo(){List<Grade> list = new List<Grade>();string sql = "select * from Grade";DataTable dt= SQLHelper.ExecuteDataTable(sql);foreach (DataRow item in dt.Rows){//一個item代表一個行對象Grade grade = new Grade();grade.GradeId = Convert.ToInt32(item["GradeID"]);grade.GradeName=item["GradeName"].ToString();list.Add(grade);}return list;}

02.在GradeBLL層(業務邏輯層)調用數據訪問層的方法,返回給UI層來調用。

 public class GradeBLL{GradeDAl gd = new GradeDAl();/// <summary>/// 從數據庫中獲取年級信息/// </summary>/// <returns>List的集合:年級編號,年級名稱</returns>public List<Grade> SelectGradeInfo(){return gd.SelectGradeInfo();}}

03.在UI層(表示層)調用GradeBLL層的方法,用List<Grade>類型接收,綁定到下拉框中,實現年級下拉框的綁定。

//加載年級下拉框方法,在Load事件做調用public void Loadingcbograde(){//調用BLL層的方法,用list集合接收List<Grade> list = gb.SelectGradeInfo();//綁定顯示值。cbograde.DisplayMember = "gradename";//綁定隱藏值。cbograde.ValueMember = "gradeid";//綁定數據源cbograde.DataSource = list;}

第二步:在年級下拉框中的SelectedIndexChanged(屬性值更改時觸發的事件)通過調用BLL層的方法來加載該年級下對應的科目信息。

01.在SubjectDAL層寫一個方法,根據選擇的年級獲取該年級的隱藏值(也就是年級編號)來查詢該年級的科目信息,返回一個subject對象的集合。

?

  /// <summary>/// 根據選中的年級編號查詢該年級下的科目/// </summary>/// <returns>科目對象集合</returns>public List<Subject> SelectSubjectInfos(int id){//根據年級編號查詢科目信息string sql = "select subjectid,subjectname from subject where gradeid=@gradeid";SqlParameter sp = new SqlParameter("@gradeid", id);DataTable dt = SQLHelper.ExecuteDataTable(sql,sp);List<Subject> list = new List<Subject>();foreach (DataRow item in dt.Rows){Subject subject = new Subject();subject.SubjectId = Convert.ToInt32(item["Subjectid"]);subject.SubjectName = item["Subjectname"].ToString();list.Add(subject);}return list;}

02.在SubjectBLL層調用數據訪問層的方法,返回給UI層來調用。

   /// <summary>/// 根據選中的年級編號查詢該年級下的科目/// </summary>/// <returns>科目對象集合</returns>public List<Subject> SelectSubjectInfos(int id){return sd.SelectSubjectInfos(id);}

03.在年級下拉框中的SelectedIndexChanged(屬性值更改時觸發的事件)調用SubjectBLL層的方法

 //實例化SubjectBLLSubjectBLL sb = new SubjectBLL();//年級下拉框屬性更改值觸發的事件private void cbograde_SelectedIndexChanged(object sender, EventArgs e){//獲取年級編號    int id= Convert.ToInt32(cbograde.SelectedValue);//調用BLL層的方法用Subject類型的集合接收List<Subject> list= sb.SelectSubjectInfos(id);//在科目下來框中添加一項全部。list.Insert(0, new Subject {SubjectId=-1, SubjectName="全部" });//清空下拉框數據cbosubject.DataSource = null;//綁定顯示值cbosubject.DisplayMember = "subjectname";//綁定隱藏值cbosubject.ValueMember = "subjectid";//綁定數據源cbosubject.DataSource = list;}

?

???????

轉載于:https://www.cnblogs.com/hyjj/p/5341376.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/373323.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/373323.shtml
英文地址,請注明出處:http://en.pswp.cn/news/373323.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

System.nanoTime()背后是什么?

在Java世界中&#xff0c;對System.nanoTime&#xff08;&#xff09;的理解非常好。 總有一些人說它是快速&#xff0c;可靠的&#xff0c;并且在可能的情況下&#xff0c;應該使用它代替System.currentTimemillis&#xff08;&#xff09;進行計時。 總的來說&#xff0c;他絕…

python連接SQL Server取多個結果集:Pymssql模塊

基本的用法可以參考&#xff1a;python連接SQL Server&#xff1a;Pymssql模塊 和上一篇文章中的代碼&#xff0c;只取一個結果集不同&#xff0c;這次會一次運行2個sql語句&#xff0c;然后分別取出2個結果集&#xff0c;打印輸出。 代碼中有詳細的注釋&#xff0c;一看就明白…

狀態不屬于代碼

Web應用程序中的“狀態”是什么&#xff1f; 它就是要存儲的數據&#xff08;無論目的地是什么—內存&#xff0c;數據庫&#xff0c;文件系統&#xff09;。 應用程序本身不得在代碼中存儲任何狀態。 這意味著您的類應僅包含帶有無狀態對象的字段。 換句話說&#xff0c;在程序…

Xen安全架構sHype/ACM策略配置圖文教程

實驗要求 1. 熟悉Xen虛擬化平臺部署&#xff1b; 2. Xen sHype/ACM安全架構中的Simple TE和Chinese Wall策略及事實上現機制的分析與驗證。 第1章 Xen環境部署 1.1 版本號選擇 因為Ubuntu使用廣泛。軟件包易于下載。我們選擇Ubuntu系統進行Xen部署…

Python 辨異 —— __init__ 與 __new__

__init__ 更多的作用是初始化屬性&#xff0c;__new__ 進行的是創建對象&#xff0c;顯然 __new__ 要早于 __init__ 發生。 考慮一個繼承自 tuple 的類&#xff0c;顯然在 __init__ 無法對其成員進行修改&#xff1b; class Edge(tuple):def __new__(cls, e1, e2):return tuple…

java彈出虛擬鍵盤_JS實現電腦虛擬鍵盤的操作

本文實例為大家分享了JS實現電腦虛擬鍵盤的具體代碼&#xff0c;供大家參考&#xff0c;具體內容如下需求&#xff1a;1.當輸入框光標聚焦時&#xff0c;電腦虛擬鍵盤彈出2.在輸入框輸入內容時&#xff0c;鍵盤跟著變化具體實現代碼如下&#xff1a;Html部分&#xff1a;電腦鍵…

Apache Mahout:入門

最近&#xff0c;我有一個有趣的問題要解決&#xff1a;如何使用自動化對不同來源的文本進行分類&#xff1f; 前一段時間&#xff0c;我讀到一個有關該項目以及許多其他文本分析工作的項目– Apache Mahout 。 盡管它不是一個非常成熟的版本&#xff08;當前版本為0.4 &#x…

Javascript中最常用的55個經典技巧(轉)

1. οncοntextmenu"window.event.returnValuefalse" 將徹底屏蔽鼠標右鍵 <table border οncοntextmenureturn(false)><td>no</table> 可用于Table 2. <body onselectstart"return false"> 取消選取、防止復制 3. οnpaste"…

向數組添加元素 java_java如何向數組里添加元素

向數組里添加一個元素怎么添加&#xff0c;這兒總結有三種方法&#xff1a;1、一般數組是不能添加元素的&#xff0c;因為他們在初始化時就已定好長度了&#xff0c;不能改變長度。但有個可以改變大小的數組為ArrayList&#xff0c;即可以定義一個ArrayList數組&#xff0c;然后…

JBoss Drools –入門

這篇文章是關于我如何掌握JBoss Drools的 。 其背后的原因是&#xff1a;SAP收購了我公司當前的規則引擎&#xff0c;而Drools是我們將尋找的另一種選擇&#xff0c;只要有人掌握了概念驗證的技能即可。 盡管似乎有大量的文檔&#xff0c;但是我總是會通過示例來發現它是有幫助…

android使用bintray發布aar到jcenter

前言 這兩天心血來潮突然想把自己的android library的aar放到jcenter里面&#xff0c;這樣一來自己便可以在任何時間任何地點通過internet得到自己的library的引用了&#xff0c;況且現在android studio已經默認使用jcenter的repositories作為依賴來源&#xff0c;以前的mavenc…

Java不是文明語言嗎?

幾周前&#xff0c;我有機會學習iOS編程。 我的老板認為我更像是“計算機科學家”&#xff0c;而不是開發人員&#xff0c;這意味著我可以將自己的知識應用于開發一兩個iPad應用程序–我要做的就是學習Objective-C&#xff0c; iOS SDK&#xff1a;到底有多難&#xff1f; 盡管…

PHP 進程詳解

PHP 進程詳解PHP 進程詳解 如下內容從《操作系統精髓與設計原理》中總結提煉得出&#xff0c;刪除了大部分對于理解進程有干擾的文字&#xff0c;對進程知識結構進行的梳理。幾乎所有內容為按照書本上摘抄下來的&#xff0c;我目前還總結提煉不出像作者這么深刻的見解。那么就先…

35. Search Insert Position

public class Solution {public int searchInsert(int[] nums, int target) {int lennums.length;int i0;for(;i<len;i){if(nums[i]>target)break;}return i;} } 轉載于:https://www.cnblogs.com/aguai1992/p/5351442.html

MySQL 后from多個表_MYSQL回顧(多表查詢相關)

前言簡單的數據我們可以直接從一個表中獲取&#xff0c;但在真實的項目中查詢符合條件的數據通常需要牽扯到多張表&#xff0c;這就不得不使用多表查詢。多表查詢分為多表連接查詢、符合條件鏈接查詢、子查詢。多表連接查詢包括內連接、外連接、全連接。符合條件連接查詢本質上…

玩! 框架+ Google Guice

在我目前正在工作的項目中&#xff0c;我們開始使用Google Guice。 對于那些不知道的人&#xff0c; Google Guice是一個依賴項注入框架。 依賴項注入背后的基本思想是提供一個它依賴的類&#xff0c;而不是使依賴類負責實例化它所依賴的對象。 Play具有用于整合Guice的模塊&am…

java都要caps標點_第 1 章 管理 Java CAPS 用戶

第 1 章 管理 Java CAPS 用戶在此處列出的主題提供了有關如何管理 Sun JavaTM Composite Application Platform Suite (Java CAPS) 中的用戶的信息。如果您有任何問題&#xff0c;請參見 http://goldstar.stc.com/ 中的 Java CAPS Web 站點。管理系統信息庫用戶此類別包含以下用…

基于OpenCV 的美顏相機推送直播流

程序流程&#xff1a; 1.圖像采集 先從opencv&#xff08;2.4.10版本&#xff09;采集回來攝像頭的圖像&#xff0c;是一幀一幀的 每一幀圖像是一個矩陣&#xff0c;opencv中的mat 數據結構。 2.人臉的美化 人臉美化&#xff0c;我們用的皮膚檢測&#xff0c;皮膚在顏色空間是特…

Linux驅動開發常用頭文件

頭文件目錄中總共有32個.h頭文件。其中主目錄下有13個&#xff0c;asm子目錄中有4個&#xff0c;linux子目錄中有10個&#xff0c;sys子目錄中有5個。這些頭文件各自的功能如下&#xff1a; 1、主目錄 <a.out.h>&#xff1a;a.out頭文件&#xff0c;定義了a.out執行文件格…

Spring線程池服務

線程池對于執行同步和異步過程非常重要。 本文介紹如何使用Spring開發和監視線程池服務。 創建線程池已通過兩種替代方法進行了說明。 二手技術 &#xff1a; JDK 1.6.0_21 Spring3.0.5 Maven的3.0.2 步驟1&#xff1a;建立已完成的專案 創建一個Maven項目&#xff0c;如下…