WPF 数据绑定,界面刷新的两种方法-----INotifyPropertyChanged
.Netformwork4.0及以下版本 -------INotifyPropertyChanged
命名空间: System.ComponentModel
后台代码
public partial class DvrWnd : UserControl
{
public DvrWnd()
{
InitializeComponent();
} private void InitInfo()
{
for (int i = 0; i < 10; i++)
{
DvrInfo dvrInfo = new DvrInfo();
dvrInfo.strDvrName = "编码器" + i.ToString();
dvrInfo.strDvrIp = "10.10.13.10" + i.ToString();
dvrInfo.strDvrPort = "506" + i.ToString();
dvrInfo.strDvrType = "Type " + i.ToString();
dvrInfo.strDvrCode = "340201030002150000" + i.ToString();
dvrInfoList.Items.Add(dvrInfo);
}
} private void UserControl_Loaded(object sender, RoutedEventArgs e)
{
dvrInfoList.Items.Clear();
InitInfo();
} //编码器信息, 只要改了类中的属性, 就能随便用
public class DvrInfo : INotifyPropertyChanged
{
private string m_strDvrIp = string.Empty;
private string m_strDvrPort = string.Empty;
private string m_strDvrName = string.Empty;
private string m_strDvrType = string.Empty;
private string m_strDvrCode = string.Empty;
public string strDvrIp
{
set
{
if (m_strDvrIp != value)
{
m_strDvrIp = value;
}
OnPropertyChanged("strDvrIp");
}
get
{
return m_strDvrIp;
}
}
public string strDvrPort
{
set
{
if (m_strDvrPort != value)
{
m_strDvrPort = value;
OnPropertyChanged("strDvrPort");
}
}
get
{
return m_strDvrPort;
}
}
public string strDvrName
{
set
{
if (m_strDvrName != value)
{
m_strDvrName = value;
OnPropertyChanged("strDvrName");
}
}
get
{
return m_strDvrName;
} }
public string strDvrType
{
set
{
if (m_strDvrType != value)
{
m_strDvrType = value;
OnPropertyChanged("strDvrType");
}
}
get
{
return m_strDvrType;
} }
public string strDvrCode
{
set
{
if (m_strDvrCode != value)
{
m_strDvrCode = value;
OnPropertyChanged("strDvrCode");
}
}
get
{
return m_strDvrCode;
}
} public event PropertyChangedEventHandler PropertyChanged;
private void OnPropertyChanged(string strPropertyInfo)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(strPropertyInfo));
}
}
}
前端代码绑定
<UserControl x:Class="testDevice.DvrWnd"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Background="White"
Loaded="UserControl_Loaded"
>
<Grid>
<DataGrid Name="dvrInfoList" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTextColumn Header="编码器名" IsReadOnly="True" Width="2*" Binding ="{Binding strDvrName}" />
//红色标记部分为OnPropertyChanged("strDvrName");中strDvrName, 并不是DvrInfo.strDvrName中的strDvrName <DataGridTextColumn Header="编码器IP" Width="*" IsReadOnly="True" Binding="{Binding strDvrIp}"/> <DataGridTextColumn Header="编码器Port" Width="*" IsReadOnly="True" Binding="{Binding strDvrPort}"/> <DataGridTextColumn Header="编码器类型" Width="*" IsReadOnly="True" Binding="{Binding strDvrType}"/> <DataGridTextColumn Header="编码器编码" Width="2*" IsReadOnly="True" Binding="{Binding strDvrCode}" />
</DataGrid.Columns>
</DataGrid>
</Grid>
</UserControl>
.Netformwork4.5及以上版本 -------INotifyPropertyChanged,CallerMemberName
命名空间: System.ComponentModel
System.Runtime.CompilerServices
后台代码:
public CvrWnd()
{
InitializeComponent();
} private void InitInfo()
{
for (int i = 0; i < 10; i++)
{
CvrInfo cvrInfo = new CvrInfo();
cvrInfo.strCvrName = "磁盘阵列" + i.ToString();
cvrInfo.strCvrIP = "10.10.13.10" + i.ToString();
cvrInfo.strCvrPort = "506" + i.ToString();
cvrInfo.strCvrType = "Type " + i.ToString();
cvrInfo.strCvrCode = "340201030002150000" + i.ToString();
cvrInfoList.Items.Add(cvrInfo);
}
} private void UserControl_Loaded(object sender, RoutedEventArgs e)
{
cvrInfoList.Items.Clear();
InitInfo();
} //磁盘阵列信息
public class CvrInfo : INotifyPropertyChanged
{
private string m_strCvrIP = string.Empty;
private string m_strCvrPort = string.Empty;
private string m_strCvrName = string.Empty;
private string m_strCvrType = string.Empty;
private string m_strCvrCode = string.Empty; public string strCvrIP
{
set
{
UpdateProperty(ref m_strCvrIP, value);
}
get
{
return m_strCvrIP;
}
}
public string strCvrPort
{
set
{
UpdateProperty(ref m_strCvrPort, value);
}
get
{
return m_strCvrPort;
}
}
public string strCvrName
{
set
{
UpdateProperty(ref m_strCvrName, value);
}
get
{
return m_strCvrName;
}
}
public string strCvrType
{
set
{
UpdateProperty(ref m_strCvrType, value);
}
get
{
return m_strCvrType;
}
}
public string strCvrCode
{
set
{
UpdateProperty(ref m_strCvrCode, value);
}
get
{
return m_strCvrCode;
}
} private void UpdateProperty<T>(ref T properValue, T newValue, [CallerMemberName] string propertyName = "")
{
if (object.Equals(properValue, newValue))
{
return;
}
properValue = newValue; OnPropertyChanged(propertyName);
} public event PropertyChangedEventHandler PropertyChanged;
protected void OnPropertyChanged([CallerMemberName]string propertyName = "")
{
PropertyChangedEventHandler handler = PropertyChanged;
if (handler != null)
{
handler(this, new PropertyChangedEventArgs(propertyName));
}
} }
}
前台代码:
<Grid>
<DataGrid Name="cvrInfoList" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTextColumn Header="磁盘阵列名" Width="*" Binding="{Binding strCvrName}" />
//strCvrName 为CvrInfo.strCvrName
<DataGridTextColumn Header="磁盘阵IP" Width="*" Binding="{Binding strCvrIP}" />
<DataGridTextColumn Header="磁盘阵Port" Width="*" Binding="{Binding strCvrPort}" />
<DataGridTextColumn Header="磁盘阵类型" Width="*" Binding="{Binding strCvrType}" />
<DataGridTextColumn Header="磁盘阵编码" Width="*" Binding="{Binding strCvrCode}" />
</DataGrid.Columns>
</DataGrid>
</Grid>
以上两种方法都可以进行数据绑定(datagrid, treeview等控件都行), 界面刷新, 第一种方法是在.netfromwork中的4.0的版本支持, 该方法的缺点是当类的属性多了, 如果后期突然改动一下OnPropertyChanged(value)中的value, 界面就不能同步, 而且感觉每个属性都要那么一行代码总感觉怪怪的, 第二种方法是在.netformwork4.5版本支持,避过了方法一种所有的缺点,GG
WPF 数据绑定,界面刷新的两种方法-----INotifyPropertyChanged的更多相关文章
- JqueryMobile动态生成listView并实现刷新的两种方法
本篇文章主要是对JqueryMobile动态生成listView并实现刷新的两种方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助 JqueryMobile动态生成listView并实现刷新 ...
- 上拉刷新和下拉刷新的两种方法(包括使用第三方库MJRefresh)
一.使用苹果原生的方法 1.下拉刷新 2.上拉刷新 (1 首先要新建一个footer得XIB文件,当然同时包括对应的控制器文件,例如在XIB文件中可以如下拖拉对应的控件 (2 然后在代码文件中写一个实 ...
- iframs刷新的两种方法
<iframe src="a1.html" id="iframe1Id" name="iframe1Name" width=" ...
- WPF中打开网页的两种方法
1.浏览器打开 Process proc = new System.Diagnostics.Process(); proc.StartInfo.FileName = "http://www. ...
- WPF程序将DLL嵌入到EXE的两种方法
WPF程序将DLL嵌入到EXE的两种方法 这一篇可以看作是<Visual Studio 版本转换工具WPF版开源了>的续,关于<Visual Studio 版本转换工具WPF版开源了 ...
- WPF多线程UI更新——两种方法
WPF多线程UI更新——两种方法 前言 在WPF中,在使用多线程在后台进行计算限制的异步操作的时候,如果在后台线程中对UI进行了修改,则会出现一个错误:(调用线程无法访问此对象,因为另一个线程拥有该对 ...
- 在vc6.0下编的对话框界面如果没做过其他处理,往往显的很生硬,怎么样才能使他有Windows XP的风格呢,其实也很简单,我们来看看下面两种方法。
在vc6.0下编的对话框界面如果没做过其他处理,往往显的很生硬,怎么样才能使他有Windows XP的风格呢,其实也很简单,我们来看看下面两种方法. 方法一: 1.首先确认你在Windows ...
- 用easyui实现查询条件的后端传递并自动刷新表格的两种方法
用easyui实现查询条件的后端传递并自动刷新表格的两种方法 搜索框如下: 通过datagrid的load方法直接传递参数并自动刷新表格 通过ajax的post函数传递参数并通过loadData方法将 ...
- centos lamp/lnmp阶段复习 以后搬迁discuz论坛不需要重新安装,只需修改配置文件即可 安装wordpress 安装phpmyadmin 定时备份mysql两种方法 第二十五节课
centos lamp/lnmp阶段复习 以后搬迁discuz论坛不需要重新安装,只需修改配置文件即可 安装wordpress 安装phpmyadmin 定时备份mysql两种方法 第二十五节 ...
随机推荐
- fiverr无法注册的解决办法,fiverr注册教程
转载 https://www.wok99.com/450.html
- 详解XOR(异或)运算加密
逻辑运算之中,除了 AND 和 OR,还有一种 XOR 运算,中文称为"异或运算".它的定义是:两个值相同时,返回false,否则返回true.也就是说,XOR可以用来判断两个值是 ...
- 如何解决RIP的问题
如何解决RIP的问题 RIP的问题 优化或解决的方式 收敛慢,故障恢复时间长 触发更新 缺少对全局网络拓扑的了解 路由器基于拓扑信息,独立计算路由 存在选择次优路径的风险 将链路带宽作为选路参考 ...
- 【03】Kubernets:K8S 操作入门
写在前面的话 经过上一节,我们顺利将 K8S 集群搭建了起来,在其中我也简单的谈了一下关于 K8S 的网络.那么这一节我们主要谈谈如何来简单的使用 K8S 的命令.当然这些命令有很多,我们只是通过一个 ...
- excel中统计列中的值在其他列出现的次数多个条件
excel中统计列中的值在其他列出现的次数多个条件 =COUNTIFS(E2:E373,"=VIP经销商",J2:J373,K2) 解释 E列的第二行到第373行中值 等于 VIP ...
- C# LDAP认证登录类参考
public class LDAPHelper { private DirectoryEntry _objDirectoryEntry; /// <sum ...
- c# 合并两个DataTable
当两个DataTable 结构相同可以用自带方法(Merge)合并 // // 摘要: // 将指定的 System.Data.DataTable 与当前的 DataTable 合并,指示是否在当前的 ...
- C# ??(两个问号)的表达式使用详解
今天有人问我C#中两个问号是什么意思,怎么使用,于是乎有了这篇随笔 有时候我们需要判断某个对象是否为null,一般的做法是 if(x=null){....} 若想让自己的代码更简洁,可以这样写: st ...
- 简单讲解Asp.Net Core自带IOC容器ServiceCollection
一. 理解ServiceCollection之前先要熟悉几个概念:DIP.IOC.DI.Ioc容器: 二. 接下来先简单说一下几个概念问题: 1.DIP(依赖倒置原则):六大设计原则里面一种设计原 ...
- SQLServer日常bug记录
问题1:如下图所示 原因分析:同时操作数据库中的两条数据引起的 解决方法:新建查询语句 delete 数据库名字.表名 where 引起错误的字段=引起错误的字段值