您的位置:首页 > 其它

Silverlight实用窍门系列:64.Silverlight中的DataContext和ItemsSource 推荐

2012-04-23 12:31 519 查看
    在Silverlight中我们经常看到数据绑定源由DataContext或者ItemsSource指定,那么他们之间的区别有哪些呢?

    DataContext:从英文字母意思是数据上下文,在Silverlight中某个父级元素设置了DataContext,那么其子元素将可以继承并且使用DataContext中的属性。DataContext绑定的数据源可以是实体集合、实体、属性等。

    ItemsSource:其数据源通常是实体集合(一列数据),无法让其子元素继承使用。

    下面我们以一个实例主要讲解DataContext的用法,其中在父级元素Grid设置了一个DataContext属性绑定实体,该实体内部有一个属性为实体集合,此实体集合用于Grid的子元素ListBox的ItemsSource属性绑定。代码如下:

    首先我们看两个实体,其中一个实体属性为List<>:

public class ClaModel
{
public ClaModel()
{
ClaName = "五年级三班";
ClaInfo = "全校最好的班级,获得多项荣誉";
StuList = new List<StuModel>()
{
new StuModel(){StuName="刘三", StuAge=15, StuInfo="他很勤奋"},
new StuModel(){StuName="李四", StuAge=14, StuInfo="他很懒惰"},
new StuModel(){StuName="王五", StuAge=16, StuInfo="他很聪明"}
};
}
public string ClaName { get; set; }

public string ClaInfo { get; set; }

public List<StuModel> StuList { get; set; }
}

public class StuModel
{
public string StuName { get; set; }

public int StuAge { get; set; }

public string StuInfo { get; set; }

}


    其次我们来看Xaml代码绑定如下:

<UserControl x:Class="SLDataContext.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:SLDataContext"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="400">
<!--第一种方式-->
<UserControl.Resources>
<local:ClaModel x:Key="ClaSource" />
</UserControl.Resources>
<Grid x:Name="LayoutRoot" Background="White" DataContext="{StaticResource ClaSource}">
<TextBlock FontWeight="Bold" Width="60" Height="30" Text="{Binding ClaName}"
VerticalAlignment="Top" HorizontalAlignment="Left"   />
<TextBlock FontStyle="Italic"  Width="160" Height="30" Text="{Binding ClaInfo}"
VerticalAlignment="Top" Margin="70 0 0 0" HorizontalAlignment="Left"  />
<ListBox Height="239" HorizontalAlignment="Left" Name="lbDetail"
VerticalAlignment="Top" Width="343" ItemsSource="{Binding StuList}"
SelectedValuePath="StuAge" DisplayMemberPath="StuName" Margin="27,61,0,0" />
</Grid>
</UserControl>


    最后我们看看另外一种后台绑定DataContext的方式。

public partial class MainPage : UserControl
{
public MainPage()
{
InitializeComponent();

//第二种方式:也可以用后台代码绑定DataContext
//this.LayoutRoot.DataContext = new ClaModel();
}
}


    如需源码请点击 SLDataContext.zip 下载 ,效果图如下:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐