silverlight子窗体操作数据库后刷新父窗体

 

后面一段日子可能时间比较急迫,于是这两天写代码比较赶,大概两天加起来代码写了20来个小时,17000行的样子。在这期间主要就碰到一个比较纠结的问题,专门调试了很久都没有解决,却在吃饭时想着代码一下子豁然开朗了。

一直没有系统地学习Silverlight开发的相关知识,是因为以前有学过Flex方面的RIA开发,所以也就感觉没有必要再花时间学Silverlight细节知识了。直接开始写代码,遇到了这么个最终让我无语凝咽的问题。下面我以我以时间顺序来讲述此问题。

为了讲得更清楚,我先描述一下此问题的“外貌”:

相关背景:父窗体是一个对员工信息的查询窗体,在此窗体点击“编辑”或“增加”按钮后弹出子窗体,在子窗体对某条员工信息进行访问数据库后,父窗体中的DataGrid(sivlerlight中表格数据的展现控件)却始终无法正常得到刷新(有时增加员工后会马上多出一条记录,有时却不会)。

开始时我的代码是这样的(仅列出关键代码):

#region 父窗体中的编辑、添加、删除按钮的点击事件处理程序

private void Edit_Click(object sender, RoutedEventArgs e)

{

if (selectedID == "")

{

MessageBox.Show("请先选定一行记录");

return;

}

EditOrAddEmployee eoa = new EditOrAddEmployee(selectedID);

eoa.Closed += new EventHandler(eoa_Closed);

eoa.Show();

}
public void eoa_Closed(object sender, EventArgs e)
{
Search(GetKeshiID(cb_keshi.SelectedItem), this.txt_GongHao.Text,
txt_EmployeeName.Text, txt_Race.Text, txt_BirthPlace.Text, txt_Duty.Text,
txt_WorkType.Text, txt_Remark.Text);//刷新页面.
lb_info.Content = "操作成功";
lb_info.Visibility = Visibility.Visible;
}

子窗体对应的操作数据库方法相关代码如下:

        private void OKButton_Click(object sender, RoutedEventArgs e)
{
if (CheckInfo() == true)
{
if (dp_birthday.SelectedDate == null)
{
dp_birthday.SelectedDate = System.DateTime.Today;
}
try
{
DBO.InsertUpdateEmployeeByIDCompleted += new EventHandler (InsertUpdateEmployeeByIDCompleted);
DBO.InsertUpdateEmployeeByIDAsync(GetKeshiID(cb_KeshiID.SelectedItem), txt_gonghao.Text,
txt_name.Text, txt_identfiycard.Text, cb_sex.SelectionBoxItem.ToString(),
txt_race.Text, dp_birthday.SelectedDate.ToString(),
txt_birthplace.Text, txt_duty.Text,txt_dutylevel.Text,txt_worktype.Text,txt_remark.Text);//添加用户
}
catch (Exception ee)
{
MessageBox.Show("OKbutton_click出错"+ee.Message);
}
}
this.DialogResult = true;
}

在上述代码中,在子窗体操作数据库后,子窗体关闭触发父窗体中的eoa_Closed方法,在此方法中进行控件中数据的刷新。可是实际上这种刷新时灵时不灵,这次添加员工刷新了DataGrid,下次删除员工又没有刷新。如此周而复始,始终找不到规律。
调试许久始终找不到哪里出了问题,无奈之下暂时在父窗体中添加了一个label提示“操作后数据可能不能及时刷新,若需要请手动刷新。”但这始终不是办法。
结果在吃饭时不由自主地想到了这个错误,思考为什么会出现有时刷新数据有时不刷新的情况,突然间想到,莫非是通过Web Service访问数据库时效率有快有慢,或许父窗体在子窗体传递的操作数据库请求还未完成时就已进行数据刷新,自然无法取到最新的数据了。迅速吃完饭回来一试,果然如此。我便彻底地了解了Web Service访问数据库的令人尴尬之处:子窗体关闭之时,可能其调用的操作数据库方法还未彻底完成。更普遍地说,Web Service访问的异步特性,让父窗体可能在子窗体异步请求调用完成之前就进行了数据刷新。
正确的代码:
父窗体中代码不需要变化。
子窗体中相关代码如下:

        private void OKButton_Click(object sender, RoutedEventArgs e)
{
if (CheckInfo() == true)
{
if (dp_birthday.SelectedDate == null)
{
dp_birthday.SelectedDate = System.DateTime.Today;
}
try
{
DBO.InsertUpdateEmployeeByIDCompleted += new EventHandler(InsertUpdateEmployeeByIDCompleted);
DBO.InsertUpdateEmployeeByIDAsync(GetKeshiID(cb_KeshiID.SelectedItem), txt_gonghao.Text,
txt_name.Text, txt_identfiycard.Text, cb_sex.SelectionBoxItem.ToString(),
txt_race.Text, dp_birthday.SelectedDate.ToString(),
txt_birthplace.Text, txt_duty.Text,txt_dutylevel.Text,txt_worktype.Text,txt_remark.Text);//添加用户
}
catch (Exception ee)
{
MessageBox.Show("OKbutton_click出错"+ee.Message);
}
}
} public void InsertUpdateEmployeeByIDCompleted(object sender,InsertUpdateEmployeeByIDCompletedEventArgs e)
{
this.DialogResult = true;//完成后,才关闭子窗体。触发父窗体中设定的委托,进行数据刷新。
}

大家应该已经看到区别,仅有的一处变化是:将this.DialogResult = true;语句放置到访问数据库操作的完成事件委托之中。
含义即:在子窗体操作数据库的异步请求彻底完成,并返回至事件猥琐处的时候,再进行this.DialogResult = true;(该语句会将子窗体关闭,从而调用父窗体中的数据刷新委托方法eoa_Closed。)

记下来以留作备用,并希望能帮助到需要的人。: )

silverlight子窗体操作数据库后刷新父窗体的更多相关文章

  1. Jbox 弹出窗口 子页面操作完成后关闭 父页面刷新

    父页面js //父页面js <script> var isFreshFlag = '1'; //添加会议活动 function addMeetingAct(){ var attendVip ...

  2. Winfrom子窗体刷新父窗体

    本人比较懒,直接从网上转载了一篇比较合适的文章,只是文章格式有点乱,地址是 http://aspnet.blog.163.com/blog/static/17515510920121126104433 ...

  3. Winform子窗体刷新父窗体

    调用窗体(父):Form1,被调用窗体(子):Form2方法1:   所有权法//Form1://需要有一个公共的刷新方法public   void   Refresh_Method(){//...} ...

  4. js实现非模态窗口增加数据后刷新父窗口数据

    父窗口是由两个部分组成,一个html的table,一部分是extjs的gird. 点击grid面板[增加]按钮将会弹出非模态窗口进行新数据的编辑页面 下面是按钮的触发函数代码: var a = win ...

  5. winform打开子窗体后,在子窗体中刷新父窗体,或者关闭子窗体刷新父窗体

    winform打开子窗体后,在子窗体中刷新父窗体,或者关闭子窗体刷新父窗体,搜集了几个方法,列举如下: 一 . 所有权法 父窗体,名称为“fuForm”,在父窗体中有个公共刷新方法,也就是窗体数据初始 ...

  6. Winform中如何实现子窗体刷新父窗体

    原理:利用委托和事件,本文将以图文并茂的例子讲述,告诉我们So Easy --------------------------------------------------------------- ...

  7. Winform 子窗体设置刷新父窗体

    方法1:所有权法 父窗体:Form1    子窗体:Form2 //Form1:窗体代码 //需要有一个公共的刷新方法 public void Refresh_Method() { //... } / ...

  8. js后台提交成功后 关闭当前页 并刷新父窗体(转)

    原文地址:http://www.cnblogs.com/chenghu/p/3696433.html 后台提交成功后 关闭当前页 并刷新父窗体 this.ClientScript.RegisterSt ...

  9. js后台提交成功后 关闭当前页 并刷新父窗体

    后台提交成功后 关闭当前页 并刷新父窗体 this.ClientScript.RegisterStartupScript(this.GetType(), "message", &q ...

随机推荐

  1. mybatis插件 mybatis插件-------从dao快速定位到mapper的sql语句

    步骤一:打开settings,点击plugins 快捷键ctrl+alt+s打开settings 步骤二.点击ClearCase Integration,并点击下面中间的按钮(browse repos ...

  2. 洛谷P1432 倒水问题

    题目背景 In the movie "Die Hard 3", Bruce Willis and Samuel L. Jackson were confronted with th ...

  3. 飞行路线(BZOJ 2763)

    题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的 ...

  4. [APIO2012] 派遣 dispatching

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 4580  Solved: 2348 Description 在一个忍者的帮派里,一些忍者们被选中派遣给 ...

  5. 《TCP/IP详解卷1:协议》——第1章:概述(转载)

    1.引言 很多不同的厂家生产各种型号的计算机,它们运行完全不同的操作系统,但TCP/IP协议族允许它们互相进行通信.TCP/IP起源于60年代末美国政府资助的一个分组交换网络研究项目,到90年代已发展 ...

  6. Educational Codeforces Round 50 (Rated for Div. 2) E. Covered Points

    注释上都有解析了,就不写了吧,去重的问题就用set解决,并且呢第i个线段最多和其他线段产生i-1个交点,n^2logn. #include <cmath> #include <cst ...

  7. [NOI2012(bzoj2879)(vijos1726)]美食节 (费用流)

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 2288  Solved: 1207[Submit][Status ...

  8. Java添加、提取、替换和删除PDF图片

    (一)简介 这篇文章将介绍在Java中添加.提取.删除和替换PDF文档中的图片. 工具使用: Free Spire.PDF for JAVA 2.4.4(免费版) Intellij IDEA Jar包 ...

  9. jquery 关于ajax 及其son

    <%@ page language="java" pageEncoding="UTF-8"%><%@include file="/c ...

  10. Spring的@Qualifier注解

    以下内容引用自http://wiki.jikexueyuan.com/project/spring/annotation-based-configuration/spring-qualifier-an ...