Silverlight索引器应用示例--通用字典数据集服务

Silverlight索引器应用示例--通用字典数据集服务,第1张

概述  现在的silverlight客户端绑定支持索引器方式,比如VM有属性: public Dictionary<string,string> KeyValues{get;set;} 在后台CS中我们要访问某个key的值的方式是:KeyValues["XXXX"],其中XXXX是key.而在xaml中可以如下访问: Text="{Bindings Path=KeyValues[XXXX]}" 只要索  

现在的silverlight客户端绑定支持索引器方式,比如VM有属性:
public Dictionary<string,string> keyvalues{get;set;}
在后台CS中我们要访问某个key的值的方式是:keyvalues["XXXX"],其中XXXX是key.而在xaml中可以如下访问:
Text="{Bindings Path=keyvalues[XXXX]}"
只要索引器本身支持get,set还可以实现双向绑定。但这个双向有一个缺陷,就是如果keyvalues["XXXX"]的值中途改变,没法通知到页面也随之改变。这其实很好理解,虽然keyvalues本身可以是一个INotifyPropertyChanged对象的可通知属性,但索引器值本身无法通知到属性改变.因此要做通用字典数据绑定,还需要进行一定的改变才行。
另外,由于Silverlight在于服务端交互的时候都是异步的,服务端的值不能直接返回给调用方,这也要求在数据绑定时采用一定的技巧。
1)一般来讲,系统的字典性数据都具有相当大的共性,字典值包括关键字,代码,描述等有限的信息,因为是讲解,这里是简单的字典值实体类:

public class DicItemVal
{
public string Key{get;set;}
public string Desc{get;set;}
public string Code{get;set;}

}
2) 字典实体:
public class DictItem
{
public string DictCode{get;set;}
public string Dictname{get;set;}
public List<DicItemVal> Values{get;set;}
}
上面的字典可以从服务端获取,在客户端能够访问,并适应异步处理,需要稍加包装:
3)字典包装:
public class DictBindingItem : INotifyPropertyChanged
{
public string DictCode{get;set;}
public string Dictname{get;set;}
private DictItem _Dict;
public DictItem Dict
{
get{return _Dict;}
set{

if(_Dict!=value)
{
_Dict = Value;
RaisePropertyChanged("Dict");
}
}
}

public event PropertyChangedEventHandler PropertyChanged;
protected voID RaisePropertyChanged(string propertyname)
{
var handler = PropertyChanged;
if (handler != null)
{
handler(this,new PropertyChangedEventArgs(propertyname));
}
}
}

4) 字典管理,提供给VM使用,这里没有做成静态的类,并提供管理主要是为了预先加载等处理方便,而且不同VM间可互不影响:
public class DictMgmt
{
private Dictionary<string,DictBindingItem> _Dicts = new Dictionary<string,DictBindingItem>();
public DictBindingItem this[string DictCode]
{
get
{
DictBindingItem theDict = null;
if(_Dicts.ContainsKey(DictCode)==false)
{
theDict = New DictBindingItem();
theDict.DictCode = DictCode;
_Dicts.Add(theDict);
}
else
{
theDict = _Dicts[DictCode];
}
if(theDict.Dict==null || theDict.Dict.Values==null || theDict.Dict.Values.Length<=0)
{
LoadDict(theDict);//如果字典数据没有,则自动加载一次.
}
}
}
public voID LoadDict(DictBindingItem ADict)
{
//DictServices 是服务端提供字典加载服务的客户端对应的代理类,大家可以自己实现。GetDict返回DictItem(包含Values),一个参数是DictCode.
DictServices theSrv = new DictServices();
theSrv.GetDict(ADict.DictCode,op=>{
if(op.HasError==false)
{
ADict.Dict= op.Value;
}
},null);
}

}

5、使用很简单,可以在VM里面定义一个DictMgmt类型的属性:
private DictMgmt _dictSource = new DictMgmt ();
public DictMgmt DictSource{get;}
在页面绑定语法:{Bindings Path=DictSource[xxxx].Dict.Values}
这种处理下,可以大大简化VM的工作量,对于页面使用也非常简单。当然大家还可以扩展实现自动预先加载等功能。这种处理方式非常适合大型系统中的字典数据加载处理。
说明一下:以上代码未经测试,机理上不会有问题,如果有错误,除字典服务未实现外,其它的应该都是语法错误,简单改一下应该没问题。


原文链接: http://www.voidcn.com/article/p-drjdsmqp-bcq.html 总结

以上是内存溢出为你收集整理的Silverlight索引器应用示例--通用字典数据集服务全部内容,希望文章能够帮你解决Silverlight索引器应用示例--通用字典数据集服务所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1069370.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-26
下一篇 2022-05-26

发表评论

登录后才能评论

评论列表(0条)

保存