基于.NET平台的Windows编程实战(六)—— 题目管理功能的实现

系列文章导航:

基于.NET平台的Windows编程实战(一)——前言

基于.NET平台的Windows编程实战(二)—— 需求分析与数据库设计

基于.NET平台的Windows编程实战(四)—— 数据库操作类的编写

基于.NET平台的Windows编程实战(五)—— 问卷管理功能的实现

基于.NET平台的Windows编程实战(六)—— 题目管理功能的实现


  申明:本系列课程是专为新手们写来入门练习用的,目的是想通过一个完整的问卷调查管理系统的案例开发来让新手们了解、加深或是熟悉软件项目的开发流程及在.NET平台上使用VS2005和C# 进行Windows方面的编程;在整个课程的设计上,我尽量避开或是根本不讨论底层的以及性能优化等方面的东西,故高手完全可以无视本系列课程。 

今天下班回来前查看了下早上放出去的第五课的课程,看到一朋友的评论,说实话当时不好受,想想自己每晚写课程到深夜,竟然被人说成白痴文章!于是带着几分冲动草草的回复之后,便带着疑惑与思考回家了。刚才重新看了下昨晚写的第五课的课程,果真发现了不少“白痴”的地方:概念模糊,思路不明,无整体模型,杂乱无章…… 如此之文章,新手如何看懂?如何练习?……自责、自问、自思之后,我决定改变一下后面课程的写作方式,即先写设计思路[流程图],再动手实验并讲解一些相关的实现原理[挑几个比较有代表性的地方进行讲解],之后再把源码放出来供大家参考练习;这样,我想对新手来说应该会更加容易理解一些吧。当然,在这里要感谢一下那位发表评论的朋友,因为是他(她)提醒了我,并使我重新去思考整个课程的设计,在此我向这位朋友说声:谢谢!同时也希望他(她)以及更多的朋友能在以后的课程中提出更多的建议、指导以及批评 ^_^ 我将万分感谢!你们的支持是我最大的动力!

  本课将带领大家一起来实现题目管理:添加、编辑、查看、删除、存入题库;以及题库管理:添加、编辑、查看、删除、插入到问卷等功能。

  一、设计思路

我们知道:一份问卷是由若干条不同的题目组合而成的,而这些题目又是由用户一条一条添加进去的。那么我们来分析一下:假如需要对A区域做一份问卷调查试题,且这份问卷要求包含100条题目,于是我们通过系统[假设这个系统只具有添加/编辑/删除/预览问卷及添加题目的功能]创建好一份名为“A区域试题”的问卷,并向此问卷里输入添加了100条的题目;几天后,我们发现这份问卷有些地方做的不好,需要进行修改,于是我们为了方便操作,便给系统增加了题目编辑、检查[查看]、排序、删除等题目管理功能;再过了几天后,我们又需要对B区域及C区域各做一份包含100条试题的问卷,于是我们打开原来的系统,并创建了二份名为“B区域试题”与“C区域试题”的问卷,但当我们往里面添加题目的时候,我们发现三份问卷有许多相同或相似的题目,于是我们就会想:如果有一个题库能将这些相同或相似的题目存起来,那么当我们需要创建新的问卷的时候,我们直接从题库里面把题目插入进去不就可以了吗?多方便呀!于是我们就有了建立一个题库来存放题目的想法了,并且这个题目应该具有编辑、查看、插入到问卷、删除等功能……

好,现在我们来设计一下流程图:

 

  图6-1

  简单的解释一下添加试题的过程:

  用户向问卷中添加题目时,先在所要添加的问卷中查找是否已经存在了该题,如果存在了则提示,如果不存在,则去题库中进行查找是否存有该题了,如存在则提示从题库中插入该题,

  否则直接添加进问卷中,并提示是否将该存入到题库中去。

  到这里相信大家应该明白或是大致知道了整个的设计思路了吧!下面我们就来动手做做吧。

  二、动手实验及相关原理讲解

  下面我挑选添加题目、排序以及窗口间的相互关联中的部分设置或代码来进行动手实验及原理的讲解,其余的请大家自行下载本课程源码参考练习。

  首先,我们来创建一个添加题目的窗口(创建方法请参见前面的课程),命名为 “TitleAdd”,并使其继承于“SurveyWin”母窗口,方法为将:

  public partial class TitleAdd :From

改成:

  public partial class TitleAdd :SurveryWin

  并将其设置成如下图6-2所示[具体的属性设置请参见本课程源码]: 

  图6-2

  其次,我们给这个窗口中的输入题目标题文本框添加了一个鼠标离开事件,以便提示用户所输入的题目是否已经存在于本问卷或题库中了。

  其实现原理是这样的:当用户往标题文本框中输入标题后,鼠标离开其文本框时,将用户所输入的标题作为条件在其问卷与题库中进行相似题目的查询,

  如查出则给出相关提示,否则作为新题添加进问卷或题库中。其实现的代码如下所示:

 

         private void TRichTitleText_MouseLeave(object sender, EventArgs e)
{
if (TRichTitleText.Text.Trim() != "")//判断是否为空,如不为空,则执行如下操作
{
//在问卷与题库中分别进行查找,看是否已经存在了?
string stSql = "Select Count(*) From Lj_TitleStorage Where TitleSt_Title like '" + TRichTitleText.Text.Trim() + "'";

string tcontent = TRichTitleText.Text.Trim() + "(" + TCombBtn.SelectedItem.ToString() + ")";
string istSql = "Select Count(*) From Lj_Title Where Title_Content like '" + tcontent + "'";

if (dboperate.ExcuteScrSql(istSql) > 0) //如果已经存在于问卷中了,则执行如下操作
{
IsStorageCoMBox.SelectedIndex
= 1;
IsStorageCoMBox.Enabled
= false;//将是否存入题库设为不可选择
TAddBtn.Enabled = false;//将添加按钮设为不可用
IsStorageLab.Visible = true;//显示提示标签
IsStorageLab.Text = "*该题已在此问卷中存在!请重新输入!";
}
else if (dboperate.ExcuteScrSql(istSql) == 0 && dboperate.ExcuteScrSql(stSql) > 0)//
如果已经存在于题库中了,则执行如下操作
{
IsStorageCoMBox.SelectedIndex
= 1;
IsStorageCoMBox.Enabled
= false;
IsStorageLab.Visible
= true;
IsStorageLab.Text
= "*题库中已经存在该题了!";
LookStLinkLab.Enabled
= true; //将"点击查看"按钮设为可用可见,以便用户点击连接到题
库中题目进行查看或插入操作
LookStLinkLab.Visible = true;
}
else
{
IsStorageCoMBox.SelectedIndex
= 0;
IsStorageCoMBox.Enabled
= true;
TAddBtn.Enabled
= true;
IsStorageLab.Visible
= false;
LookStLinkLab.Enabled
= false;
LookStLinkLab.Visible
= false;
}
}
}

NET技术基于.NET平台的Windows编程实战(六)—— 题目管理功能的实现,转载需保留来源!

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。