WPF 数据绑定类属性 和数据更新

WPF中数据绑定是一个非常强大的功能,不仅可以绑定后台数据,还可以进行实时更新。

数据绑定实例 :

在后台创建模型类,然后在标签页面进行导入并绑定。

cs 复制代码
第一步: 
// 在后台创建模型类
public class MyData
{
    public string Name { get; set; } = "李逵";
}

第二步:
// 在标签页面导入实体类
xmlns:c ="clr-namespace:WpfProgram.Entity"

第三步:
// 在标签页面指定数据源
<Grid.Resources>
    <c:MyData x:Key="mydataScource"/>
</Grid.Resources>

第四步:
// 在标签页面设置或着获取参与数据绑定时候的上下文,(通俗来讲以后可以在代码里面获取对象)
<Grid.DataContext>
    <Binding Source="{StaticResource mydataScource}"/>
</Grid.DataContext>

第五步: 
// 在标签页面绑定到目标标签上 label:{Bingding path=对象模型属性}
<Label Content="{Binding Path=Name}" FontSize="20" >
</Label>

数据更新实例:

// 实现数据更新需要再模型类里面添加INotifyPropertyChanged接口

// INotifyPropertyChanged 检查属性是否发生变化的接口

cs 复制代码
数据更新 :  
// 第一步: 在后台设置模型类
public class MyData : INotifyPropertyChanged
{
    public string Name { get; set; } = "李逵";

    // 实现INotifyPropertyChanged这个接口的PropertyChanged属性
    // PropertyChanged类型是委托函数
    public event PropertyChangedEventHandler? PropertyChanged;

    protected void OnPropertyChanged(string propertyName)
    {
        // 当属性修改的时候触发PropertyChanged事件,紧跟着调用该函数
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    }
}

《--第二步: 标签设计并绑定数据--》
<Grid Name="g1">
    <Grid.Resources>
        <c:MyData  x:Key="s1"/>
    </Grid.Resources>
    <Grid.DataContext>
        <Binding Source="{StaticResource s1}" />
    </Grid.DataContext>
    
    <!--把数据绑定给Grid标签,Grid下子标签都可以使用-->
    <Label Width="100"
           Height="40"
           Content="{Binding Path=Name}"
           VerticalAlignment="Top">
    </Label>
</Grid>

// 第三步: 在cs页面创建模型类对象,然后将对象赋值给Grid的DataContext属性 实现数据更新
MyData data = new MyData();
data.Name = "鲁提辖";
this.g1.DataContext = data;

数据更新实例2:

此方法在模型类数据变化时立马调用INotifyPropertyChanged的PropertyChanged函数,比较之前的更新方法此方法更新速度更快,实现数据更新,界面立马更新。

INotifyPropertyChanged接口 :

实现数据更新需要再模型类里面添加INotifyPropertyChanged接口

INotifyPropertyChanged 检查属性是否发生变化的接口。

cs 复制代码
数据更新 : 
// 第一步在后台设置模型类 
public class MyData : INotifyPropertyChanged
{
    private string name = "LIHX";
    public string Name
   {
    get
    {
        return name;
    }
    set
    {
        name= value;
        // 当数据更新时立刻在set里面调用OnProChanged函数
        OnProChanged("Name");
    }
}

    // 实现INotifyPropertyChanged这个接口的PropertyChanged属性
    // PropertyChanged类型是委托函数
    public event PropertyChangedEventHandler? PropertyChanged;

    protected void OnProChanged(string propertyName)
    {
        // 当属性修改的时候触发PropertyChanged事件,紧跟着调用该函数
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    }
}

// 第二步设置标签布局并且进行数据绑定
<Grid Name="g1">
    <Grid.Resources>
        <c:MyData  x:Key="s1"/>
    </Grid.Resources>
    <Grid.DataContext>
        <Binding Source="{StaticResource s1}" />
    </Grid.DataContext>
    
    <!--把数据绑定给Grid标签,Grid下子标签都可以使用-->
    <Label Width="100"
           Height="40"
           Content="{Binding Path=Name}"
           VerticalAlignment="Top">
    </Label>
</Grid>

// 第三步在cs页面创建模型类对象,然后将对象赋值给Grid的DataContext属性 实现数据更新
MyData data = new MyData();
data.Name = "鲁提辖";
this.g1.DataContext = data;
相关推荐
gyx_这个杀手不太冷静2 分钟前
OpenCode 进阶使用指南(第二章:Skills 系统)
前端·ai编程
牛奶5 分钟前
浏览器到底在偷偷帮你做什么?——HTTP缓存与刷新机制
前端·http·浏览器
CodeSheep24 分钟前
“渐渐能理解为何不愿意雇佣35岁以上程序猿。去年换了份工作,组里4位组员其中3位40+,发现其实最大的问题并不是说精力不济卷不动”
前端·后端·程序员
摸鱼的春哥40 分钟前
【实战】吃透龙虾🦞,你写的Agent也能支持Skills渐进式披露
前端·javascript·后端
恋猫de小郭1 小时前
你还用 IDE 吗? AI 狂欢时代下 Cursor 慌了, JetBrains 等 IDE 的未来是什么?
前端·flutter·ai编程
明月_清风1 小时前
拒绝盲目 Git:VS Code 神级插件 GitLens 的 9 个进效杀手锏
前端·git
唐青枫1 小时前
C#.NET SignalR 深入解析:实时通信、Hub 与连接管理实战
c#·.net
孟祥_成都1 小时前
用 AI,0 基础复刻网页顶级特效!😀
前端·javascript·vibecoding
唐宋元明清21887 小时前
.NET Win32磁盘动态卷/跨区卷触发“函数不正确”问题排查
windows·c#·存储
hez20108 小时前
Satori GC:同时做到高吞吐、低延时和低内存占用
c#·.net·.net core·gc·clr