Silverlight实用窍门系列:47.Silverlight中元素到元素的绑定,以及ObservableCollection和List的使用区别

简介:

   问题一:在某一些情况下,我们使用MVVM模式的时候,对于某一个字段(AgeField)需要在前台的很多个控件(A、B、C、D、E)进行绑定,但是如何能够让我们后台字段名改变的时候能够非常方便的改变所有使用了这个字段的控件呢?

        回答:使用Element to Element Binding,将AgeFiled绑定到A控件,然后再让B、C、D、E控件绑定A控件的使用AgeField字段的属性。

        例如:字段(AgeField)的数据是年龄大小,A、B、C、D、E控件分别是Ellipse、Label、Slider、TextBox、ProgressBar,这些字段的Width、Value或者Text值按照常规的做法,这几个控件都是在MVVM模式下都是绑定的AgeField。但是这个字段名在后期代码维护的时候修改为Age了,我们就不得不需要一一修改五个控件的绑定值。如果这几个控件还分布在不同位置,那么寻找起来就将更加麻烦。那么这里我们就将使用到Silverlight 3的一个新特性Element to Element Binding。

        实例一:我们在这里有一个TextBox控件tbAge,其Value值假定绑定到某一个字段,然后我们再添加Slider、ProgressBar、Ellipse控件,使用Value="{Binding Text,ElementName=tbAge,Mode=TwoWay}"这样的方式将tbAge的Text值绑定到这几个控件上。下面我们看源码如下:

复制代码
        <!--这里是数据源-->
<TextBox x:Name="tbAge" Text="30" Width="80" Margin="0,87,0,183" Height="30"
HorizontalAlignment
="Left" VerticalAlignment="Top"/>
<!--Silder控件绑定上面的tbAge控件的值-->
<Slider Name="sdAge" Value="{Binding ElementName=tbAge, Path=Text, Mode=TwoWay }"
Minimum
="1" Maximum="100" Height="40" Width="210" HorizontalAlignment="Left"
VerticalAlignment
="Top" Margin="0,145,0,115"></Slider>
<!--ProgressBar控件绑定上面的tbAge控件的值-->
<ProgressBar Value="{Binding Text,ElementName=tbAge,Mode=TwoWay}" Margin="0,27,0,0"
Name
="progressBar1" Height="24" HorizontalAlignment="Left"
VerticalAlignment
="Top" Width="210" />
<!--Ellipse的Width属性绑定sdAge控件的值-->
<Ellipse Width="{Binding Value,ElementName=sdAge,Mode=TwoWay}"
Height
="100" HorizontalAlignment="Left" Margin="0,200,0,0"
Name
="ellipse1" Stroke="Black" StrokeThickness="1" VerticalAlignment="Top" />
复制代码

        问题二:为什么在Silverlight中我们更常用ObservableCollection<T>来作为数据集合绑定到控件中,而不是使用List<T>呢?

        回答:当T继承于INotifyPropertyChanged接口的时候,如果T的属性值发生变化时,ObservableCollection和List都能够让前台UI发生相应的改变。但是当增加一个T的数据行时,List不能及时更新前台UI,而ObservableCollection能够将新增的T数据行马上更新到UI上去。

        实例二:我们拖出两个DataGrid控件分别是ShowListCity和ShowObservableCity,然后分别绑定数据List和Observable数据,再添加一个按钮为这两个数据集合添加集合值。看UI是否变化。下面我们看源码如下:

复制代码
<sdk:DataGrid HorizontalAlignment="Left"  AutoGenerateColumns="False"  Margin="476,12,0,0"
Name
="ShowListCity" VerticalAlignment="Top" Height="169" Width="324" >
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn Header="省会" Binding="{Binding AddrName}" IsReadOnly="True" Width="108"/>
<sdk:DataGridTextColumn Header="城市" Binding="{Binding CityName}" IsReadOnly="True" Width="108"/>
<sdk:DataGridTextColumn Header="电话区号" Binding="{Binding TelNum}" IsReadOnly="True" Width="108"/>
</sdk:DataGrid.Columns>
</sdk:DataGrid>

<sdk:DataGrid HorizontalAlignment="Left" AutoGenerateColumns="False" Margin="476,187,0,0"
Name
="ShowObservableCity" VerticalAlignment="Top" Height="180" Width="324" >
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn Header="省会" Binding="{Binding AddrName}" IsReadOnly="True" Width="108"/>
<sdk:DataGridTextColumn Header="城市" Binding="{Binding CityName}" IsReadOnly="True" Width="108"/>
<sdk:DataGridTextColumn Header="电话区号" Binding="{Binding TelNum}" IsReadOnly="True" Width="108"/>
</sdk:DataGrid.Columns>
</sdk:DataGrid>
<Button Content="添加条目" Height="23" HorizontalAlignment="Left" Margin="364,13,0,0" Name="button1"
VerticalAlignment
="Top" Width="75" Click="button1_Click" />
复制代码

        下面是MainPage.xaml.cs代码

复制代码
    public partial class MainPage : UserControl
{
public MainPage()
{
InitializeComponent();
ListCity
= new List<CityInformation>()
{
new CityInformation(){ AddrName="四川", CityName="成都", TelNum="028"},
new CityInformation(){ AddrName="北京", CityName="北京", TelNum="010"},
new CityInformation(){ AddrName="广东", CityName="广州", TelNum="021"}
};
ObservableCity
= new ObservableCollection<CityInformation>()
{
new CityInformation(){ AddrName="四川", CityName="成都", TelNum="028"},
new CityInformation(){ AddrName="北京", CityName="北京", TelNum="010"},
new CityInformation(){ AddrName="广东", CityName="广州", TelNum="021"}
};
this.ShowListCity.ItemsSource = ListCity;
this.ShowObservableCity.ItemsSource = ObservableCity;
}

private List<CityInformation> _ListCity;
/// <summary>
/// 城市集合
/// </summary>
public List<CityInformation> ListCity
{
get { return _ListCity; }
set { _ListCity = value; }
}

private ObservableCollection<CityInformation> _ObservableCity;
/// <summary>
/// 城市集合
/// </summary>
public ObservableCollection<CityInformation> ObservableCity
{
get { return _ObservableCity; }
set { _ObservableCity = value; }
}
private void button1_Click(object sender, RoutedEventArgs e)
{
ListCity.Add(
new CityInformation() { AddrName = "重庆", CityName = "重庆", TelNum = "022" });
ObservableCity.Add(
new CityInformation() { AddrName = "重庆", CityName = "重庆", TelNum = "022" });
}
}
复制代码

         下面我们来看CityInformation实例类代码如下:

复制代码
    /// <summary>  
/// 城市信息的实体类
/// </summary>
public class CityInformation
{
private string _AddrName;
private string _CityName;
private string _TelNum;
/// <summary>
/// 地址名
/// </summary>
public string AddrName
{
get { return _AddrName; }
set { _AddrName = value; }
}
/// <summary>
/// 城市名
/// </summary>
public string CityName
{
get { return _CityName; }
set { _CityName = value; }
}
/// <summary>
/// 区号
/// </summary>
public string TelNum
{
get { return _TelNum; }
set { _TelNum = value; }
}
}
复制代码

          最后我们来看看运行效果如何,另外如需源码请点击 SLElement.zip 下载 .

 



本文转自程兴亮博客园博客,原文链接:http://www.cnblogs.com/chengxingliang/archive/2011/07/18/2108732.html,如需转载请自行联系原作者


相关文章
|
5月前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
5月前
|
索引
【Qt 学习笔记】Qt常用控件 | 多元素控件 | List Widget的说明及介绍
【Qt 学习笔记】Qt常用控件 | 多元素控件 | List Widget的说明及介绍
574 3
|
5月前
|
存储 Java 索引
|
5月前
|
Java
【Java基础面试四十六】、 List<? super T>和List<? extends T>有什么区别?
这篇文章阐述了Java泛型中的List<? super T>和List<? extends T>的区别,解释了通配符的使用规则,以及Java泛型设计原则确保了编译时无警告则运行时无ClassCastException异常。
|
7月前
|
存储 Python
Python中list, tuple, dict,set的区别和使用场景
Python中list, tuple, dict,set的区别和使用场景
266 2
|
7月前
|
存储 NoSQL 安全
Redis第六弹-List列表-(相当于数组/顺序表)Lpush key element-一次可以插入多个元素(假如key已经存在,并且key对应的value并非是list,则会报错)
Redis第六弹-List列表-(相当于数组/顺序表)Lpush key element-一次可以插入多个元素(假如key已经存在,并且key对应的value并非是list,则会报错)
|
6月前
|
NoSQL Java Redis
Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推
Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推
|
7月前
|
存储 安全 程序员
老程序员分享:List、Map、Set之间的联系与区别:
老程序员分享:List、Map、Set之间的联系与区别:
|
8月前
|
Python
【Python 基础】列表(list)和元组(tuple)有什么区别?
【5月更文挑战第6天】【Python 基础】列表(list)和元组(tuple)有什么区别?
|
7月前
|
存储 NoSQL Redis
Redis第四弹,Redis实现list时候做出的优化ziplist(压缩链表,元素少的情况),可更好的节省空间list——(内部编码:quicklist)Object encoding
Redis第四弹,Redis实现list时候做出的优化ziplist(压缩链表,元素少的情况),可更好的节省空间list——(内部编码:quicklist)Object encoding

热门文章

最新文章