为什么databindings在绑定到属性值的时候,不能自动更新

简介: 在面向对象设计系统的时候,在设计的类的生成对象的后,为了呈现给客户,要绑定对象的属性到窗体,这时我们可以使用控件的databindings方法,如textBox1.DataBindings.Add("Text", cat, "Name"); 这样在textbox1中输入相应的信息后,cat的Name属性就会自然发生变化,这时,我们可以将这个对象持久化到数据库中,或者文本,及本地资源中 但是

在面向对象设计系统的时候,在设计的类的生成对象的后,为了呈现给客户,要绑定对象的属性到窗体,
这时我们可以使用控件的databindings方法,如
textBox1.DataBindings.Add("Text", cat, "Name");

这样在textbox1中输入相应的信息后,cat的Name属性就会自然发生变化,这时,我们可以将这个对象持久化到数据库中,或者文本,及本地资源中

但是一般来说,我们的系统涉及到的业务逻辑不会这么简单(只是数据库的存储)
举一个例子,我们在买东西的时候,在修改购买量的时候,我们希望在我们输入数量后,系统自动显示出总价来
以下是一个简单的例子,这时我们在写程序的时候,无论修改那个量,都可以得到正确的总价
label1.DataBindings.Add("Text",obj,"ItemsMoney");
但是:我们将总价绑定到了label1,在总价发生变化后,label1的text属性是不发生变化的,为什么呢,因为databinding不自动探测对象中属性值的变化
这样看上去,像是做了一半的工作,这个databindings看起来就不那么完美了

public   class  ShopItem
{
    
int  price;
    
int  totalmoney;
    
int  num;
    
public   int  Price
    {
        
get { return  price;}
        
set
        {
            
if (price != value)
            {
                totalmoney
= price * number;
                price
= value;
            }
        }
        
    }

    
public   int  number
    {
        
get {}
        
set
        {
            
if (num != value)
            {
                totalmoney
= price * number;
                num
= value;
            }
        }
    }

    
public   int  ItemsMoney
    {
        
get
        {
            
return  totalmoney;
        }
    }
}

通过反射查看一下databindings的实现机制,起主要做用的就是binding类了,他通过反射取得对象的值,并赋值在控件的相应的属性上
[TypeConverter(typeof(ListBindingConverter))]
public class Binding

我们在程序中修改已经绑定了对象属性值的控件的值,对象的属性值是不会发生变化,说明binding捕获的是用户的输入消息,如wm_char,鼠标,等消息

现在我们来看一下,为什么不自动更新界面信息
如果我们要实现这个自动更新的功能,那么,属性值在发生变化时,必须产生一个消息,由binding处理,然后刷新界面
产生这个消息,我只想到两种方法
第一,修改property的实现机制,property的实现用类似方法的机制实现的,我不懂il所以不知道实现起来有没有困难,反正现在是没有
第二,在每一个属性修改时都引发一个event,然后将这个event交给binding处理
第二种方法,先不说他的代码量,在每一个property中都加入引发事件的语句
单是如何处理就是一个问题
这个binding必须必理所有的对象的属性变化,就是在每一个对象的创建时,都必须将他的propertychaged事件的处理函数交给databing处理,
那么这个binding就是一个全局的静态方法,(有可能会引发线程访问的问题),如果使用对象的话,那么在每一个类中都加入一个显示的部分,那么
业务逻辑与界面显示不完全分离,并且,开销也非常巨大,如果使用池的缓存机制,这样可能会减少一些开销.


所有只有选一个折中的办法,定义一个INotifyPropertyChanged接口,
那么,你想怎么办就怎么办吧

INotifyPropertyChanged接口实现的例子
http://blog.joycode.com/zhanbos/archive/2005/11/06/66492.aspx 

相关文章
|
8月前
|
缓存 JavaScript 数据处理
vue的计算属性、侦听属性和方法
vue的计算属性、侦听属性和方法
47 0
|
4月前
表单的构成与创建、属性
表单的构成与创建、属性。
26 5
|
6月前
|
缓存 编解码 监控
reservedCodecCacheSize属性详解与配置建议
reservedCodecCacheSize属性详解与配置建议
|
8月前
|
JavaScript
表单输入绑定 值绑定
表单输入绑定 值绑定
|
8月前
当监听的属性是对象的引用时,`watch`选项是否会触发监听?
当监听的属性是对象的引用时,`watch`选项是否会触发监听?
43 2
|
JavaScript
vue中监听属性和计算属性的区别
vue中监听属性和计算属性的区别
252 0
|
缓存 JavaScript
Vue常用属性(计算属性和侦听器属性)
Vue常用属性(计算属性和侦听器属性)
|
缓存 JavaScript 数据处理
vue的计算属性与监听属性的区别
vue的计算属性与监听属性的区别
206 0
|
缓存 监控 JavaScript
Vue —— 计算属性 & 监听属性
Vue —— 计算属性 & 监听属性
148 0
|
C#
WPF更新绑定字段
WPF更新绑定字段
110 0